From ee1fc58ac1da02efddbb1478e1ce1b55a045792c Mon Sep 17 00:00:00 2001 From: kantundpeterpan Date: Mon, 6 Jul 2020 12:31:00 +0200 Subject: [PATCH] updated automatic update of constraints Signed-off-by: kantundpeterpan --- .../constraints/.#constraintsdialog.cpp | 1 - .../constraints/constraintsdialog.cpp | 32 +++++++++---------- .../constraints/constraintsextension.cpp | 5 +-- 3 files changed, 19 insertions(+), 19 deletions(-) delete mode 120000 avogadro/qtplugins/constraints/.#constraintsdialog.cpp diff --git a/avogadro/qtplugins/constraints/.#constraintsdialog.cpp b/avogadro/qtplugins/constraints/.#constraintsdialog.cpp deleted file mode 120000 index a0ca7487e7..0000000000 --- a/avogadro/qtplugins/constraints/.#constraintsdialog.cpp +++ /dev/null @@ -1 +0,0 @@ -kantundpeterpan@haina-Ubs19.5479:1593976063 \ No newline at end of file diff --git a/avogadro/qtplugins/constraints/constraintsdialog.cpp b/avogadro/qtplugins/constraints/constraintsdialog.cpp index 94440e856d..442de90781 100644 --- a/avogadro/qtplugins/constraints/constraintsdialog.cpp +++ b/avogadro/qtplugins/constraints/constraintsdialog.cpp @@ -61,31 +61,31 @@ namespace Avogadro { { m_plugin->m_molecule->atom(i).setSelected(false); } - // get currently selected constraint - QModelIndex idx = ui->ConstraintsTableView->selectionModel()->currentIndex(); - // extract constraint from ConstraintModel - QtPlugins::Constraint* c = &m_plugin->m_molecule->constraints->ConstraintsList[idx.row()]; - // iterate over involved uniqueAtomIDs - for (int i = 0; i < c->Atoms.size(); i++) + if (m_plugin->m_molecule->constraints->ConstraintsList.size()>0) { - // get atom by uniqueID and set selected - m_plugin->m_molecule->atomByUniqueId(c->Atoms[i]).setSelected(true); - qDebug() << "Set selected"; + // get currently selected constraint + QModelIndex idx = ui->ConstraintsTableView->selectionModel()->currentIndex(); + // extract selected constraint from ConstraintModel + QtPlugins::Constraint* c = &m_plugin->m_molecule->constraints->ConstraintsList[idx.row()]; + // iterate over involved uniqueAtomIDs + for (int i = 0; i < c->Atoms.size(); i++) + { + // get atom by uniqueID and set selected + m_plugin->m_molecule->atomByUniqueId(c->Atoms[i]).setSelected(true); + qDebug() << "Set selected"; + } + //emit molecule changes + m_plugin->m_molecule->emitChanged(Molecule::Atoms); } - m_plugin->m_molecule->emitChanged(Molecule::Atoms); } } void ConstraintsDialog::setModel() { ui->ConstraintsTableView->setModel(m_plugin->m_molecule->constraints); + connectHighlight(ui->checkHighlight->checkState()); connect( m_plugin->m_molecule, SIGNAL( changed(unsigned int)), m_plugin->m_molecule->constraints, SLOT (emitDataChanged())); - /* - connect( ui->ConstraintsTableView, SIGNAL( selectionChanged(const QItemSelection &selected, - const QItemSelection &deselected)), - this, SLOT(highlightSelected())); - */ } void ConstraintsDialog::acceptConstraints() @@ -123,7 +123,7 @@ namespace Avogadro { void ConstraintsDialog::deleteAllConstraints() { m_plugin->m_molecule->constraints->clear(); - this->update(); + // this->update(); } } diff --git a/avogadro/qtplugins/constraints/constraintsextension.cpp b/avogadro/qtplugins/constraints/constraintsextension.cpp index 6f4af1aa3d..dac9ff068f 100644 --- a/avogadro/qtplugins/constraints/constraintsextension.cpp +++ b/avogadro/qtplugins/constraints/constraintsextension.cpp @@ -48,13 +48,14 @@ namespace Avogadro { if (mol != m_molecule) { m_molecule = mol; - dialog->setModel(); - dialog->connectHighlight(0); + // dialog->connectHighlight(0); } + if (!m_molecule->constraints) { m_molecule->constraints = new ConstraintsModel(m_molecule); } + dialog->setModel(); } bool ConstraintsExtension::readMolecule(QtGui::Molecule& mol){