Changeset bfd520c
- Timestamp:
- Mar 24, 2016, 2:23:20 PM (9 years ago)
- Branches:
- 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, 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
- Children:
- d316ad
- Parents:
- 6a7353
- git-author:
- Frederik Heber <heber@…> (03/17/16 09:52:26)
- git-committer:
- Frederik Heber <heber@…> (03/24/16 14:23:20)
- Location:
- src/UIElements/Views/Qt4/ElementList
- Files:
-
- 2 edited
Legend:
- Unmodified
- Added
- Removed
-
src/UIElements/Views/Qt4/ElementList/QtElementList.cpp
r6a7353 rbfd520c 32 32 #include <config.h> 33 33 #endif 34 35 #include <QtCore/QMetaType> 34 36 35 37 #include "Views/Qt4/ElementList/QtElementList.hpp" … … 57 59 QtElementList::QtElementList(QtObservedInstanceBoard *_board, QWidget * _parent) : 58 60 QTreeWidget (_parent), 59 Observer("QtElementList"), 60 board(_board) 61 { 61 atomobserver(_board) 62 { 63 qRegisterMetaType<QtObservedAtom::ptr>("QtObservedAtom::ptr"); 64 62 65 setColumnCount(COLUMNCOUNT); 63 66 setSelectionMode(QAbstractItemView::MultiSelection); … … 97 100 dirty = true; 98 101 99 AtomObserver::getInstance().signOn(this, atom::ElementChanged); 100 102 connect(&atomobserver, SIGNAL(ElementChanged(const QtObservedAtom::ptr)), 103 this, SLOT(changeElement(const QtObservedAtom::ptr))); 104 connect(&atomobserver, SIGNAL(AtomInserted(const QtObservedAtom::ptr)), 105 this, SLOT(addAtomElement(const QtObservedAtom::ptr))); 106 connect(&atomobserver, SIGNAL(AtomRemoved(const atomId_t)), 107 this, SLOT(removeAtomElement(const atomId_t))); 101 108 connect(this,SIGNAL(itemSelectionChanged()),this,SLOT(rowSelected())); 102 connect(this,SIGNAL(needsRefill(const atomId_t)),this,SLOT(refill(const atomId_t)), Qt::QueuedConnection);103 109 // connect(this,SIGNAL(changed()),this,SLOT(update())); 104 110 … … 107 113 QtElementList::~QtElementList() 108 114 { 109 AtomObserver::getInstance().signOff(this, atom::ElementChanged); 110 } 111 112 void QtElementList::update(Observable *publisher) 113 { 114 ASSERT(0, "QtElementList::update() - is not enlisted to any general update."); 115 } 116 117 118 void QtElementList::recieveNotification(Observable *publisher, Notification_ptr notification) 119 { 120 if (notification->getChannelNo() == atom::ElementChanged) { 121 dirty = true; 122 123 emit needsRefill(dynamic_cast<atom *>(publisher)->getId()); 124 } else 125 ASSERT(0, "QtElementList::recieveNotification() - we are not enlisted to any other instance's channel."); 126 } 127 128 void QtElementList::updateElement(const QtObservedAtom::ptr &_atom) 129 { 115 } 116 void QtElementList::changeElement(const QtObservedAtom::ptr _atom) 117 { 118 boost::recursive_mutex::scoped_lock lock(refill_mutex); 119 130 120 const atomicNumber_t newelement = _atom->getAtomElement(); 131 121 atomicNumber_t oldelement = -1; … … 134 124 ASSERT( newtreeItem != NULL, 135 125 "QtElementList::updateElement() - new element item not present."); 136 // if (newtreeItem == NULL) {137 // // add new item138 // const element& e = _atom.getElement();139 // newtreeItem = new QTreeWidgetItem();140 // newtreeItem->setText(NUMBER, QString::number(e.getAtomicNumber()));141 // newtreeItem->setText(NAME, QString(e.getName().c_str()));142 // newtreeItem->setText(SYMBOL, QString(e.getSymbol().c_str()));143 // newtreeItem->setText(MASS, QString::number(e.getMass()));144 // setOccurrence(*newtreeItem, 0);145 // elementSelection.push_back(newtreeItem->isSelected());146 // insertTopLevelItem(newelement-1, newtreeItem);147 // }148 126 AtomElementMap_t::iterator iter = AtomElementMap.find(atomid); 149 127 if (iter == AtomElementMap.end()) { … … 182 160 } 183 161 184 void QtElementList::refill(const atomId_t _atomid) 185 { 186 refill_mutex.lock(); 187 188 const QtObservedAtom::ptr walker = board->getObservedAtom(_atomid); 189 if (walker) 190 updateElement(walker); 191 else { 192 AtomElementMap_t::iterator iter = AtomElementMap.find(_atomid); 193 if (iter != AtomElementMap.end()) { 194 QTreeWidgetItem *oldtreeItem = topLevelItem(iter->second-1); 195 const int count_old = oldtreeItem->text(OCCURRENCE).toInt(); 196 setOccurrence(*oldtreeItem, count_old-1); 197 198 AtomElementMap.erase(iter); 199 } 200 } 201 202 refill_mutex.unlock(); 162 void QtElementList::addAtomElement(const QtObservedAtom::ptr _atom) 163 { 164 boost::recursive_mutex::scoped_lock lock(refill_mutex); 165 166 changeElement(_atom); 167 168 } 169 170 void QtElementList::removeAtomElement(const atomId_t _atomid) 171 { 172 boost::recursive_mutex::scoped_lock lock(refill_mutex); 173 174 const AtomElementMap_t::iterator iter = AtomElementMap.find(_atomid); 175 ASSERT (iter != AtomElementMap.end(), 176 "QtElementList::addAtomElement() - atom #"+toString(_atomid) 177 +" is not present in elementlookup map."); 178 if (iter != AtomElementMap.end()) { 179 QTreeWidgetItem *oldtreeItem = topLevelItem(iter->second-1); 180 const int count_old = oldtreeItem->text(OCCURRENCE).toInt(); 181 setOccurrence(*oldtreeItem, count_old-1); 182 183 AtomElementMap.erase(iter); 184 } 203 185 } 204 186 … … 208 190 // refill(); 209 191 QTreeWidget::paintEvent(event); 210 }211 212 void QtElementList::subjectKilled(Observable *publisher) {213 192 } 214 193 -
src/UIElements/Views/Qt4/ElementList/QtElementList.hpp
r6a7353 rbfd520c 14 14 #endif 15 15 16 #include <QtGui/QTreeWidget> 16 17 17 #include <QtGui/QTreeWidget> 18 #include <QMutex> 19 20 #include "CodePatterns/Observer/Observer.hpp" 21 #include "CodePatterns/Observer/Notification.hpp" 18 #include <boost/thread/recursive_mutex.hpp> 22 19 23 20 #include "types.hpp" 24 21 25 22 #include "UIElements/Qt4/InstanceBoard/QtObservedAtom.hpp" 23 #include "UIElements/Views/Qt4/ElementList/QtObservedAtomObserver.hpp" 26 24 27 25 class QtObservedInstanceBoard; 28 26 29 class QtElementList: public QTreeWidget , public Observer27 class QtElementList: public QTreeWidget 30 28 { 31 29 Q_OBJECT … … 36 34 37 35 protected: 38 virtual void update(Observable *publisher);39 virtual void recieveNotification(Observable *publisher, Notification_ptr notification);40 virtual void subjectKilled(Observable *publisher);41 36 virtual void paintEvent(QPaintEvent * event); 42 37 43 38 void setOccurrence(QTreeWidgetItem &_item, const int count); 44 void updateElement(const QtObservedAtom::ptr &_atom);45 39 46 40 static const int COLUMNCOUNT; … … 48 42 static const char *COLUMNNAMES[]; 49 43 50 signals:51 void needsRefill(const atomId_t);52 53 44 private slots: 54 45 void rowSelected(); 55 void refill(const atomId_t); 46 void changeElement(const QtObservedAtom::ptr _atom); 47 void addAtomElement(const QtObservedAtom::ptr _atom); 48 void removeAtomElement(const atomId_t _atom); 56 49 57 50 private: 58 51 std::vector<bool> elementSelection; //!< needed to determine when a selection changes 59 typedef std::map< atomId_t, atomicNumber_t> AtomElementMap_t;52 typedef std::map<const atomId_t, atomicNumber_t> AtomElementMap_t; 60 53 AtomElementMap_t AtomElementMap; 61 54 bool dirty; 62 55 63 //!> ptr to instance board to obtain observed atoms64 QtObserved InstanceBoard * const board;56 //!> observed all QtObservedAtoms for ElementChanged signals 57 QtObservedAtomObserver atomobserver; 65 58 66 QMutex refill_mutex;59 mutable boost::recursive_mutex refill_mutex; 67 60 }; 68 61
Note:
See TracChangeset
for help on using the changeset viewer.