From ab93b9469b81c41fa658846efc18fe0ebeefc415 Mon Sep 17 00:00:00 2001 From: Geoff Hutchison Date: Wed, 25 Oct 2023 19:07:00 -0400 Subject: [PATCH] Fix #1193 for real this time Only create the widget when needed, only connect the signal as-needed Prevents a query for a layer before there's even a molecule Signed-off-by: Geoff Hutchison --- .../qtplugins/selectiontool/selectiontool.cpp | 26 +++++++++++-------- .../qtplugins/selectiontool/selectiontool.h | 2 +- .../selectiontool/selectiontoolwidget.cpp | 10 ++++--- 3 files changed, 23 insertions(+), 15 deletions(-) diff --git a/avogadro/qtplugins/selectiontool/selectiontool.cpp b/avogadro/qtplugins/selectiontool/selectiontool.cpp index fa066fa1dd..32a69db782 100644 --- a/avogadro/qtplugins/selectiontool/selectiontool.cpp +++ b/avogadro/qtplugins/selectiontool/selectiontool.cpp @@ -22,10 +22,10 @@ #include #include +#include #include #include #include -#include #include #include @@ -43,8 +43,7 @@ namespace Avogadro::QtPlugins { SelectionTool::SelectionTool(QObject* parent_) : QtGui::ToolPlugin(parent_), m_activateAction(new QAction(this)), - m_molecule(nullptr), m_renderer(nullptr), - m_toolWidget(new SelectionToolWidget(qobject_cast(parent_))), + m_molecule(nullptr), m_renderer(nullptr), m_toolWidget(nullptr), m_drawSelectionBox(false), m_doubleClick(false), m_initSelectionBox(false), m_layerManager("Selection Tool") { @@ -57,16 +56,19 @@ SelectionTool::SelectionTool(QObject* parent_) "Right Mouse: \tClick outside the molecule to clear selection\n" "Use Ctrl to toggle the selection and shift to add to the selection.\n" "Double-Click: \tSelect an entire fragment.")); - - connect(m_toolWidget, SIGNAL(colorApplied(Vector3ub)), this, - SLOT(applyColor(Vector3ub))); - connect(m_toolWidget, SIGNAL(changeLayer(int)), this, SLOT(applyLayer(int))); } SelectionTool::~SelectionTool() {} QWidget* SelectionTool::toolWidget() const { + if (m_toolWidget == nullptr) { + m_toolWidget = new SelectionToolWidget(qobject_cast(parent())); + connect(m_toolWidget, SIGNAL(colorApplied(Vector3ub)), this, + SLOT(applyColor(Vector3ub))); + connect(m_toolWidget, SIGNAL(changeLayer(int)), this, + SLOT(applyLayer(int))); + } return m_toolWidget; } @@ -132,7 +134,7 @@ QUndoCommand* SelectionTool::mouseReleaseEvent(QMouseEvent* e) } } } - if (anySelect) { + if (anySelect && m_toolWidget != nullptr) { m_toolWidget->setDropDown(m_layerManager.getLayerID(selectedIndex), m_layerManager.layerCount()); } @@ -262,7 +264,8 @@ void SelectionTool::applyLayer(int layer) layer = layerInfo.maxLayer(); // update the menu too - m_toolWidget->setDropDown(layer, m_layerManager.layerCount()); + if (m_toolWidget != nullptr) + m_toolWidget->setDropDown(layer, m_layerManager.layerCount()); changes |= Molecule::Layers | Molecule::Added; } @@ -360,7 +363,8 @@ void SelectionTool::setMolecule(QtGui::Molecule* mol) maxLayers = m_layerManager.layerCount(); } - m_toolWidget->setDropDown(currentLayer, maxLayers); + if (m_toolWidget != nullptr) + m_toolWidget->setDropDown(currentLayer, maxLayers); } -} // namespace Avogadro +} // namespace Avogadro::QtPlugins diff --git a/avogadro/qtplugins/selectiontool/selectiontool.h b/avogadro/qtplugins/selectiontool/selectiontool.h index 699d75756c..422a254773 100644 --- a/avogadro/qtplugins/selectiontool/selectiontool.h +++ b/avogadro/qtplugins/selectiontool/selectiontool.h @@ -63,7 +63,7 @@ private slots: QAction* m_activateAction; QtGui::Molecule* m_molecule; Rendering::GLRenderer* m_renderer; - SelectionToolWidget* m_toolWidget; + mutable SelectionToolWidget* m_toolWidget; bool m_drawSelectionBox; bool m_doubleClick; bool m_initSelectionBox; diff --git a/avogadro/qtplugins/selectiontool/selectiontoolwidget.cpp b/avogadro/qtplugins/selectiontool/selectiontoolwidget.cpp index 8a41ef0c6b..e1f8b1dce3 100644 --- a/avogadro/qtplugins/selectiontool/selectiontoolwidget.cpp +++ b/avogadro/qtplugins/selectiontool/selectiontoolwidget.cpp @@ -17,8 +17,6 @@ SelectionToolWidget::SelectionToolWidget(QWidget* parent) setDropDown(0, 1); connect(m_ui->applyColorButton, SIGNAL(clicked()), this, SLOT(userClickedColor())); - connect(m_ui->changeLayerDropDown, SIGNAL(currentIndexChanged(int)), this, - SIGNAL(changeLayer(int))); } SelectionToolWidget::~SelectionToolWidget() @@ -28,6 +26,8 @@ SelectionToolWidget::~SelectionToolWidget() void SelectionToolWidget::setDropDown(size_t current, size_t max) { + // disconnect the signal so we don't send it accidentally + disconnect(m_ui->changeLayerDropDown, nullptr, nullptr, nullptr); m_ui->changeLayerDropDown->clear(); for (size_t i = 0; i < max; ++i) { m_ui->changeLayerDropDown->addItem(QString::number(i + 1)); @@ -35,6 +35,10 @@ void SelectionToolWidget::setDropDown(size_t current, size_t max) m_ui->changeLayerDropDown->addItem(tr("New Layer")); if (current != m_ui->changeLayerDropDown->currentIndex()) m_ui->changeLayerDropDown->setCurrentIndex(current); + + // reconnect the signal + connect(m_ui->changeLayerDropDown, SIGNAL(currentIndexChanged(int)), this, + SIGNAL(changeLayer(int))); } void SelectionToolWidget::userClickedColor() @@ -59,4 +63,4 @@ void SelectionToolWidget::userClickedColor() } } -} // namespace Avogadro +} // namespace Avogadro::QtPlugins