- Timestamp:
- Jan 28, 2015, 7:07:03 PM (11 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, 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
- Children:
- 2696b1
- Parents:
- 53c1ff
- git-author:
- Frederik Heber <heber@…> (01/18/15 20:01:55)
- git-committer:
- Frederik Heber <heber@…> (01/28/15 19:07:03)
- Location:
- src/UIElements/Views/Qt4/MoleculeList
- Files:
-
- 4 edited
Legend:
- Unmodified
- Added
- Removed
-
src/UIElements/Views/Qt4/MoleculeList/QtMoleculeList.cpp
r53c1ff rd2dbb5d 49 49 50 50 #include "Atom/atom.hpp" 51 #include "Descriptors/MoleculeIdDescriptor.hpp" 51 52 #include "Formula.hpp" 52 53 #include "molecule.hpp" 53 54 #include "MoleculeListClass.hpp" 54 #include "Actions/SelectionAction/Molecules/MoleculeByIdAction.hpp"55 #include "Actions/SelectionAction/Molecules/NotMoleculeByIdAction.hpp"56 55 57 56 using namespace std; … … 61 60 QtMoleculeList::QtMoleculeList() : 62 61 Observer("QtMoleculeList"), 63 selecting(false),64 62 changing(false), 65 63 ChangingChildrensVisibility(false), … … 107 105 MoleculeItemBiMap_t::left_const_iterator iter = 108 106 MoleculeItemBiMap.left.find(_mol); 109 ASSERT( iter != MoleculeItemBiMap.left.end(), 110 "QtMoleculeList - could not find molecule "+_mol->getName()+" in my list."); 111 return iter->second; 107 if( iter != MoleculeItemBiMap.left.end()) 108 return iter->second; 109 else 110 return NULL; 112 111 } 113 112 … … 116 115 const MoleculeItemBiMap_t::right_const_iterator iter = 117 116 MoleculeItemBiMap.right.find(const_cast<QtMoleculeItem * const>(_item)); 118 ASSERT( iter != MoleculeItemBiMap.right.end(), 119 "QtMoleculeList::IndexToMolecule() - index to unknown molecule given."); 120 return iter->second; 117 if (iter != MoleculeItemBiMap.right.end()) 118 return iter->second; 119 else 120 return NULL; 121 121 } 122 122 -
src/UIElements/Views/Qt4/MoleculeList/QtMoleculeList.hpp
r53c1ff rd2dbb5d 59 59 friend class QtMoleculeItem; 60 60 61 // void rowsSelected(const QItemSelection & selected, const QItemSelection & deselected);62 61 void readdItem(QtMoleculeItem *_molitem); 63 62 … … 69 68 private: 70 69 71 bool selecting;72 70 bool changing; 73 71 bool ChangingChildrensVisibility; -
src/UIElements/Views/Qt4/MoleculeList/QtMoleculeListView.cpp
r53c1ff rd2dbb5d 36 36 37 37 #include "UIElements/Views/Qt4/MoleculeList/QtMoleculeList.hpp" 38 #include "UIElements/Views/Qt4/MoleculeList/QtMoleculeItemFactory.hpp" 38 39 39 40 #include "CodePatterns/MemDebug.hpp" … … 41 42 #include "CodePatterns/Observer/Notification.hpp" 42 43 44 #include "Actions/SelectionAction/Molecules/MoleculeByIdAction.hpp" 45 #include "Actions/SelectionAction/Molecules/NotMoleculeByIdAction.hpp" 46 43 47 #include "World.hpp" 44 48 45 49 QtMoleculeListView::QtMoleculeListView(QWidget * _parent) : 46 QTreeView(_parent), 47 Observer("QtMoleculeListView") 50 QTreeView(_parent), 51 Observer("QtMoleculeListView"), 52 selecting(false) 48 53 { 49 54 setSelectionMode(QAbstractItemView::MultiSelection); … … 60 65 { 61 66 QTreeView::setModel(_moleculelist); 67 // clicking a molecule means calling SelectionAction 62 68 connect( 63 69 selectionModel(), SIGNAL(selectionChanged(const QItemSelection &, const QItemSelection &)), 64 _moleculelist, SLOT(rowsSelected(const QItemSelection &, const QItemSelection &)));70 this, SLOT(rowsSelected(const QItemSelection &, const QItemSelection &))); 65 71 } 66 72 67 73 void QtMoleculeListView::update(Observable *publisher) 68 74 {} 75 76 QModelIndex QtMoleculeListView::setIndexToLastColumn(const QModelIndex &_index) const 77 { 78 QModelIndex return_index; 79 QModelIndex parent_index = _index.parent(); 80 ASSERT (parent_index.isValid(), 81 "QtMoleculeListView::setIndexToLastColumn() - _index has no valid parent."); 82 return_index = parent_index.child(_index.row(), QtMoleculeItemFactory::OCCURRENCE); 83 // return_index = 84 // model()->invisibleRootItem()->child( 85 // _index.row(), 86 // QtMoleculeItemFactory::OCCURRENCE)->index(); 87 return return_index; 88 } 89 90 void QtMoleculeListView::rowsSelected( 91 const QItemSelection& selected, const QItemSelection& deselected) 92 { 93 if (selecting) 94 return; 95 96 selecting = true; 97 98 // Select all molecules which belong to newly selected rows. 99 QtMoleculeList *moleculelist = dynamic_cast<QtMoleculeList *>(model()); 100 QModelIndex index; 101 { 102 QModelIndexList items = selected.indexes(); 103 molids_t ids; 104 ids.reserve(items.size()); 105 foreach (index, items) 106 if ((index.column() == 0) && (selectionModel()->isSelected(index))) { 107 const molecule *mol = moleculelist->IndexToMolecule(index); 108 if (mol == NULL) // means we are looking at deselection because of removal 109 continue; 110 int mol_id = mol->getId(); 111 // check for invalid molecule 112 if (mol_id < 0) 113 continue; 114 // means we are looking at deselection because of removal (in World) 115 if (World::getInstance().getMolecule(MoleculeById(mol_id)) != mol) 116 continue; 117 if (!World::getInstance().isSelected(mol)) 118 ids.push_back(mol_id); 119 //std::cout << "select molecule" << std::endl; 120 } 121 if (!ids.empty()) 122 MoleCuilder::SelectionMoleculeById(ids); 123 } 124 125 // Unselect all molecules which belong to newly unselected rows. 126 { 127 QModelIndexList items = deselected.indexes(); 128 molids_t ids; 129 ids.reserve(items.size()); 130 foreach (index, items) 131 if ((index.column() == 0) && (!selectionModel()->isSelected(index))) { 132 const molecule *mol = moleculelist->IndexToMolecule(index); 133 if (mol == NULL) // means we are looking at deselection because of removal 134 continue; 135 int mol_id = mol->getId(); 136 // check for invalid molecule 137 if (mol_id < 0) 138 continue; 139 // means we are looking at deselection because of removal (in World) 140 if (World::getInstance().getMolecule(MoleculeById(mol_id)) != mol) 141 continue; 142 if (World::getInstance().isSelected(mol)) 143 ids.push_back(mol_id); 144 //std::cout << "unselect molecule" << std::endl; 145 } 146 if (!ids.empty()) 147 MoleCuilder::SelectionNotMoleculeById(ids); 148 } 149 150 selecting = false; 151 } 69 152 70 153 void QtMoleculeListView::recieveNotification(Observable *publisher, Notification_ptr notification) … … 83 166 std::set<QModelIndex> already_selected_indices; 84 167 for (std::vector<molecule *>::const_iterator iter = selectedMolecules.begin(); 85 iter != selectedMolecules. begin(); ++iter) {168 iter != selectedMolecules.end(); ++iter) { 86 169 QModelIndex mol_index = moleculelist->MoleculeToItem(*iter)->index(); 87 170 if (!currently_selected.contains(mol_index)) 88 selected.select(mol_index, mol_index);171 selected.select(mol_index, setIndexToLastColumn(mol_index)); 89 172 else 90 173 already_selected_indices.insert(mol_index); … … 96 179 already_selected_indices.find(mol_index); 97 180 if (iter == already_selected_indices.end()) 98 deselected.select(mol_index, mol_index);181 deselected.select(mol_index, setIndexToLastColumn(mol_index)); 99 182 } 100 183 } 101 selectionChanged(selected, deselected); 184 selecting = true; 185 if (!selected.indexes().empty()) 186 selectionModel()->select(selected, QItemSelectionModel::Select); 187 if (!deselected.indexes().empty()) 188 selectionModel()->select(deselected, QItemSelectionModel::Deselect); 189 selecting = false; 102 190 break; 103 191 } -
src/UIElements/Views/Qt4/MoleculeList/QtMoleculeListView.hpp
r53c1ff rd2dbb5d 14 14 #endif 15 15 16 #include <QModelIndex> 16 17 #include <QTreeView> 17 18 … … 30 31 void setModel(QtMoleculeList *_moleculelist); 31 32 33 public slots: 34 void rowsSelected(const QItemSelection&, const QItemSelection&); 35 32 36 protected: 33 37 virtual void update(Observable *publisher); 34 38 virtual void recieveNotification(Observable *publisher, Notification_ptr notification); 35 39 virtual void subjectKilled(Observable *publisher); 40 41 private: 42 QModelIndex setIndexToLastColumn(const QModelIndex &_index) const; 43 44 bool selecting; 36 45 }; 37 46
Note:
See TracChangeset
for help on using the changeset viewer.