source: src/UIElements/Views/Qt4/QtMoleculeList.cpp@ 4d6662

Action_Thermostats Add_AtomRandomPerturbation Add_FitFragmentPartialChargesAction Add_RotateAroundBondAction Add_SelectAtomByNameAction Added_ParseSaveFragmentResults AddingActions_SaveParseParticleParameters Adding_Graph_to_ChangeBondActions Adding_MD_integration_tests Adding_ParticleName_to_Atom Adding_StructOpt_integration_tests AtomFragments Automaking_mpqc_open AutomationFragmentation_failures Candidate_v1.5.4 Candidate_v1.6.0 Candidate_v1.6.1 Candidate_v1.7.0 ChangeBugEmailaddress ChangingTestPorts ChemicalSpaceEvaluator CombiningParticlePotentialParsing Combining_Subpackages Debian_Package_split Debian_package_split_molecuildergui_only Disabling_MemDebug Docu_Python_wait EmpiricalPotential_contain_HomologyGraph EmpiricalPotential_contain_HomologyGraph_documentation Enable_parallel_make_install Enhance_userguide Enhanced_StructuralOptimization Enhanced_StructuralOptimization_continued Example_ManyWaysToTranslateAtom Exclude_Hydrogens_annealWithBondGraph FitPartialCharges_GlobalError Fix_BoundInBox_CenterInBox_MoleculeActions Fix_ChargeSampling_PBC Fix_ChronosMutex Fix_FitPartialCharges Fix_FitPotential_needs_atomicnumbers Fix_ForceAnnealing Fix_IndependentFragmentGrids Fix_ParseParticles Fix_ParseParticles_split_forward_backward_Actions Fix_PopActions Fix_QtFragmentList_sorted_selection Fix_Restrictedkeyset_FragmentMolecule Fix_StatusMsg Fix_StepWorldTime_single_argument Fix_Verbose_Codepatterns Fix_fitting_potentials Fixes ForceAnnealing_goodresults ForceAnnealing_oldresults ForceAnnealing_tocheck ForceAnnealing_with_BondGraph ForceAnnealing_with_BondGraph_continued ForceAnnealing_with_BondGraph_continued_betteresults ForceAnnealing_with_BondGraph_contraction-expansion FragmentAction_writes_AtomFragments FragmentMolecule_checks_bonddegrees GeometryObjects Gui_Fixes Gui_displays_atomic_force_velocity ImplicitCharges IndependentFragmentGrids IndependentFragmentGrids_IndividualZeroInstances IndependentFragmentGrids_IntegrationTest IndependentFragmentGrids_Sole_NN_Calculation JobMarket_RobustOnKillsSegFaults JobMarket_StableWorkerPool JobMarket_unresolvable_hostname_fix MoreRobust_FragmentAutomation ODR_violation_mpqc_open PartialCharges_OrthogonalSummation PdbParser_setsAtomName PythonUI_with_named_parameters QtGui_reactivate_TimeChanged_changes Recreated_GuiChecks Rewrite_FitPartialCharges RotateToPrincipalAxisSystem_UndoRedo SaturateAtoms_findBestMatching SaturateAtoms_singleDegree StoppableMakroAction Subpackage_CodePatterns Subpackage_JobMarket Subpackage_LinearAlgebra Subpackage_levmar Subpackage_mpqc_open Subpackage_vmg Switchable_LogView ThirdParty_MPQC_rebuilt_buildsystem TrajectoryDependenant_MaxOrder TremoloParser_IncreasedPrecision TremoloParser_MultipleTimesteps TremoloParser_setsAtomName Ubuntu_1604_changes stable
Last change on this file since 4d6662 was 25e18e7, checked in by Frederik Heber <heber@…>, 12 years ago

FIX: Required qRegisterMetaType of bond::ptr.

  • Property mode set to 100644
File size: 6.0 KB
RevLine 
[bcf653]1/*
2 * Project: MoleCuilder
3 * Description: creates and alters molecular systems
[0aa122]4 * Copyright (C) 2010-2012 University of Bonn. All rights reserved.
[94d5ac6]5 *
6 *
7 * This file is part of MoleCuilder.
8 *
9 * MoleCuilder is free software: you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation, either version 2 of the License, or
12 * (at your option) any later version.
13 *
14 * MoleCuilder is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
18 *
19 * You should have received a copy of the GNU General Public License
20 * along with MoleCuilder. If not, see <http://www.gnu.org/licenses/>.
[bcf653]21 */
22
[b47bfc]23/*
[0eb7bf3]24 * QtMoleculeList.cpp
[b47bfc]25 *
26 * Created on: Jan 21, 2010
27 * Author: crueger
28 */
29
[bf3817]30// include config.h
31#ifdef HAVE_CONFIG_H
32#include <config.h>
33#endif
[bbbad5]34
[0eb7bf3]35#include "Views/Qt4/QtMoleculeList.hpp"
[b47bfc]36
[41815a3]37#include <QMetaMethod>
38
[b47bfc]39#include <iostream>
40
[ad011c]41#include "CodePatterns/MemDebug.hpp"
[bbbad5]42
[6f0841]43#include "Atom/atom.hpp"
[26cf178]44#include "Formula.hpp"
[b47bfc]45#include "molecule.hpp"
[42127c]46#include "MoleculeListClass.hpp"
[b14efe]47#include "Actions/SelectionAction/Molecules/MoleculeByIdAction.hpp"
48#include "Actions/SelectionAction/Molecules/NotMoleculeByIdAction.hpp"
[b47bfc]49
50using namespace std;
51
52// maybe this should go with the definition of molecules
53
54// some attributes need to be easier to find for molecules
[6cab535]55// these attributes are skipped so far
[0eb7bf3]56const int QtMoleculeList::COLUMNCOUNT = COLUMNTYPES_MAX;
57const char *QtMoleculeList::COLUMNNAMES[QtMoleculeList::COLUMNCOUNT]={"Name","Atoms","Formula","Occurrence"/*,"Size"*/};
[b47bfc]58
[0eb7bf3]59QtMoleculeList::QtMoleculeList(QWidget * _parent) :
[79b59b]60 QTreeWidget (_parent),
[0eb7bf3]61 Observer("QtMoleculeList")
[b47bfc]62{
63 setColumnCount(COLUMNCOUNT);
[79b59b]64 setSelectionMode(QAbstractItemView::MultiSelection);
[b47bfc]65
[79b59b]66 QStringList header;
67 for(int i=0; i<COLUMNCOUNT;++i)
68 header << COLUMNNAMES[i];
69 setHeaderLabels(header);
[b47bfc]70
[41815a3]71 World::getInstance().signOn(this);//, World::MoleculeInserted);
72 //World::getInstance().signOn(this, World::MoleculeRemoved);
73
74
[a39006]75 dirty = true;
[99e8ea]76 clearing = false;
[41815a3]77 selecting = false;
[a39006]78 refill();
[b47bfc]79
[25e18e7]80 qRegisterMetaType<QItemSelection>("QItemSelection");
[79b59b]81 //connect(this,SIGNAL(cellChanged(int,int)),this,SLOT(moleculeChanged(int,int)));
[41815a3]82 connect(selectionModel(),SIGNAL(selectionChanged(QItemSelection, QItemSelection)),this,SLOT(rowsSelected(QItemSelection, QItemSelection)));
[b47bfc]83
84}
85
[0eb7bf3]86QtMoleculeList::~QtMoleculeList()
[b47bfc]87{
[41815a3]88 World::getInstance().signOff(this);//, World::MoleculeInserted);
89 //World::getInstance().signOff(this, World::MoleculeRemoved);
[b47bfc]90}
91
[0eb7bf3]92void QtMoleculeList::update(Observable *publisher) {
[a39006]93
[41815a3]94 if (selecting)
95 return;
96
[a39006]97 dirty = true;
98
99 // force an update from Qt...
[99e8ea]100 clearing = true;
[a39006]101 clear();
[99e8ea]102 clearing = false;
[a39006]103}
104
[0eb7bf3]105void QtMoleculeList::refill() {
[6cab535]106 clearing = true;
[41815a3]107 const std::vector<molecule*> &molecules = World::getInstance().getAllMolecules();
108
[79b59b]109 clear();
110
111 // list of (unique) formulas in the world
112 std::vector<Formula> formula;
113
[41815a3]114 for (std::vector<molecule*>::const_iterator iter = molecules.begin();
115 iter != molecules.end();
116 iter++) {
[b47bfc]117
[79b59b]118 // find group if already in list
119 QTreeWidgetItem *groupItem = NULL;
120 for (unsigned int j=0;j<formula.size();j++)
121 if ((*iter)->getFormula() == formula[j]){
122 groupItem = topLevelItem(j);
123 break;
124 }
125
126 // new molecule type -> create new group
127 if (!groupItem){
128 formula.push_back((*iter)->getFormula());
129 groupItem = new QTreeWidgetItem(this);
130 groupItem->setText(0, QString((*iter)->getName().c_str()));
131 groupItem->setText(1, QString::number((*iter)->getAtomCount()));
132 groupItem->setText(2, QString((*iter)->getFormula().toString().c_str()));
133 groupItem->setText(3, "0");
[41815a3]134 groupItem->setData(0, Qt::UserRole, QVariant(-1));
[79b59b]135 }
136
137 // add molecule
138 QTreeWidgetItem *molItem = new QTreeWidgetItem(groupItem);
139 molItem->setText(0, QString((*iter)->getName().c_str()));
140 molItem->setText(1, QString::number((*iter)->getAtomCount()));
141 molItem->setText(2, QString((*iter)->getFormula().toString().c_str()));
[41815a3]142 const int index = (*iter)->getId();
[79b59b]143 molItem->setData(0, Qt::UserRole, QVariant(index));
[b14efe]144 molItem->setSelected(World::getInstance().isSelected(*iter));
[79b59b]145
146
147 // increase group occurrence
148 int count = groupItem->text(3).toInt() + 1;
149 groupItem->setText(3, QString::number(count));
[b47bfc]150 }
[a39006]151 dirty = false;
[6cab535]152 clearing = false;
[a39006]153}
154
[0eb7bf3]155void QtMoleculeList::paintEvent(QPaintEvent * event)
[a39006]156{
157 if (dirty)
158 refill();
159 QTreeWidget::paintEvent(event);
[b47bfc]160}
161
[0eb7bf3]162void QtMoleculeList::subjectKilled(Observable *publisher) {
[b47bfc]163}
164
[0eb7bf3]165void QtMoleculeList::moleculeChanged() {
[79b59b]166 /*int idx = verticalHeaderItem(row)->data(Qt::UserRole).toInt();
[b47bfc]167 molecule *mol = molecules->ReturnIndex(idx);
168 string cellValue = item(row,NAME)->text().toStdString();
169 if(mol->getName() != cellValue && cellValue !="") {
170 mol->setName(cellValue);
171 }
172 else if(cellValue==""){
173 item(row,NAME)->setText(QString(mol->getName().c_str()));
[79b59b]174 }*/
[b47bfc]175}
176
[0eb7bf3]177void QtMoleculeList::rowsSelected(const QItemSelection & selected, const QItemSelection & deselected){
[b14efe]178
[99e8ea]179 if (clearing)
180 return;
[41815a3]181 if (selecting)
182 return;
183 selecting = true;
184
185 // Select all molecules which belong to newly selected rows.
186 QModelIndex index;
187 QModelIndexList items = selected.indexes();
188 foreach (index, items)
189 if (index.column() == 0){
190 int mol_id = model()->data(index, Qt::UserRole).toInt();
191 if (mol_id < 0)
192 continue;
193 //std::cout << "select molecule" << std::endl;
194 MoleCuilder::SelectionMoleculeById(mol_id);
195 }
[99e8ea]196
[41815a3]197 // Unselect all molecules which belong to newly unselected rows.
198 items = deselected.indexes();
199 foreach (index, items)
200 if (index.column() == 0){
201 int mol_id = model()->data(index, Qt::UserRole).toInt();
202 if (mol_id < 0)
203 continue;
204 //std::cout << "unselect molecule" << std::endl;
205 MoleCuilder::SelectionNotMoleculeById(mol_id);
[b47bfc]206 }
[41815a3]207
208 selecting = false;
[b47bfc]209}
Note: See TracBrowser for help on using the repository browser.