- Timestamp:
- Apr 25, 2016, 7:05:31 AM (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:
- 1eba7c
- Parents:
- 649f59
- git-author:
- Frederik Heber <heber@…> (04/17/16 21:26:58)
- git-committer:
- Frederik Heber <heber@…> (04/25/16 07:05:31)
- Location:
- src/UIElements/Views/Qt4/Qt3D
- Files:
-
- 2 edited
Legend:
- Unmodified
- Added
- Removed
-
src/UIElements/Views/Qt4/Qt3D/GLWorldScene.cpp
r649f59 refeeb7 73 73 74 74 using namespace MoleCuilder; 75 76 // static functions 77 78 static void eraseBondNodeParents( 79 std::vector<GLWorldScene::BondNodeParentMap_t> &_BondNodeParentMaps, 80 const ObservedValue_Index_t &_bondid) 81 { 82 const size_t left_erased = _BondNodeParentMaps[0].left.erase(_bondid); 83 const size_t right_erased = _BondNodeParentMaps[1].left.erase(_bondid); 84 ASSERT( (left_erased == 1) && (right_erased == 1), 85 "eraseBondNodeParents() - could not erase both parents of "+toString(_bondid)+"?"); 86 } 87 88 /** Checks whether both parents of the bond are set to GLWorldScene and the 89 * bondRemoved() signals was received for this bond. 90 * 91 * \param _BondNodeParent_Maps - map containing parents 92 * \param _ToBeRemovedNodes - set with all bonds that are to be removed 93 * \param _bondid id of bond 94 * \return true - both parents are assigned to GLWorldScene, false - else 95 */ 96 static bool checkBondRemoval( 97 const std::vector<GLWorldScene::BondNodeParentMap_t> &_BondNodeParentMaps, 98 const GLWorldScene::ToBeRemovedNodes_t &_ToBeRemovedNodes, 99 const ObservedValue_Index_t &_bondid) 100 { 101 GLWorldScene::BondNodeParentMap_t::left_const_iterator leftiter = 102 _BondNodeParentMaps[0].left.find(_bondid); 103 GLWorldScene::BondNodeParentMap_t::left_const_iterator rightiter = 104 _BondNodeParentMaps[1].left.find(_bondid); 105 ASSERT( leftiter != _BondNodeParentMaps[0].left.end(), 106 "checkBondRemoval() - left parent to index "+toString(_bondid)+" missing?"); 107 ASSERT( rightiter != _BondNodeParentMaps[1].left.end(), 108 "checkBondRemoval() - right parent to index "+toString(_bondid)+" missing?"); 109 return ((leftiter->second == (ObservedValue_Index_t)NULL) 110 && (rightiter->second == (ObservedValue_Index_t)NULL) 111 && (_ToBeRemovedNodes.count(_bondid))); 112 } 113 114 void removeBondFromScene( 115 GLWorldScene::BondNodeMap &_BondsinSceneMap, 116 const ObservedValue_Index_t &_bondid) 117 { 118 std::pair<GLWorldScene::BondNodeMap::iterator, GLWorldScene::BondNodeMap::iterator> iters = 119 _BondsinSceneMap.equal_range(_bondid); 120 ASSERT( iters.first != iters.second, 121 "removeBondFromScene() - could not find bond to id "+toString(_bondid)); 122 for (GLWorldScene::BondNodeMap::iterator iter = iters.first; iter != iters.second; ++iter) { 123 GLMoleculeObject_bond *bondObject = iter->second; 124 delete bondObject; // is done by signal from bond itself 125 //LOG(4, "INFO: Still present bonds " << BondsinSceneMap << "."); 126 } 127 _BondsinSceneMap.erase(_bondid); 128 } 129 130 static bool checkAtomRemoval( 131 const GLWorldScene::AtomNodeParentMap_t &_AtomNodeParentMap, 132 const GLWorldScene::ToBeRemovedNodes_t &_ToBeRemovedNodes, 133 const ObservedValue_Index_t &_atomid) 134 { 135 GLWorldScene::AtomNodeParentMap_t::left_const_iterator iter = _AtomNodeParentMap.left.find(_atomid); 136 ASSERT( iter != _AtomNodeParentMap.left.end(), 137 "checkAtomRemoval() - missing parent entry for "+toString(_atomid)); 138 return ((iter->second == (ObservedValue_Index_t)NULL) && (_ToBeRemovedNodes.count(_atomid))); 139 } 140 141 // class definitions 75 142 76 143 GLWorldScene::GLWorldScene( … … 238 305 GLWorldScene::ObservedValueIndexLookup_t &_ObservedValueIndexLookup, 239 306 T &_ObservedValues, 240 ObservedValue_Index_t_id)307 const ObservedValue_Index_t &_id) 241 308 { 242 309 // get QObject* from lookup … … 244 311 _ObservedValueIndexLookup.find(_id); 245 312 ASSERT( iter != _ObservedValueIndexLookup.end(), 246 " GLWorldScene::removeAtom() - could not find index "+toString(_id)313 "removeStoredObservedValue() - could not find index "+toString(_id) 247 314 +" to stored observed value."); 248 315 QObject * sender = iter->second; 249 316 const size_t erased = _ObservedValues.erase(sender); 250 317 ASSERT( erased == 1, 251 " GLWorldScene::removeStoredObservedValue() - could not erase stored observed value "318 "removeStoredObservedValue() - could not erase stored observed value " 252 319 +toString(_id)); 253 320 _ObservedValueIndexLookup.erase(iter); 254 321 } 255 322 323 void removeAtomFromScene( 324 GLWorldScene::AtomNodeMap &_AtomsinSceneMap, 325 const ObservedValue_Index_t &_atomid) 326 { 327 GLWorldScene::AtomNodeMap::iterator iter = _AtomsinSceneMap.find(_atomid); 328 ASSERT(iter != _AtomsinSceneMap.end(), 329 "removeAtomFromScene() - atom "+toString(_atomid)+" not on display."); 330 GLMoleculeObject_atom *atomObject = iter->second; 331 _AtomsinSceneMap.erase(iter); 332 delete atomObject; 333 } 334 335 void GLWorldScene::checkAndRemoveAtom(const ObservedValue_Index_t &_atomid) 336 { 337 boost::recursive_mutex::scoped_lock lock(AtomNodeParentMap_mutex); 338 339 if (checkAtomRemoval(AtomNodeParentMap, ToBeRemovedNodes, _atomid)) { 340 LOG(4, "DEBUG: Found parent of to be removed atom as GLWorldScene, removing."); 341 removeAtomFromScene(AtomsinSceneMap, _atomid); 342 AtomNodeParentMap.left.erase(_atomid); 343 ToBeRemovedNodes.erase(_atomid); 344 removeStoredObservedValue(ObservedValueIndexLookup, ObservedAtoms, _atomid); 345 } 346 } 347 256 348 /** Removes an atom. 257 349 * … … 263 355 // bonds are removed by signal coming from ~bond 264 356 357 ASSERT( ToBeRemovedNodes.count(_atomid) == 0, 358 "GLWorldScene::removeAtom() - removedAtom signal for id "+toString(_atomid) 359 +" came in twice?"); 360 ToBeRemovedNodes.insert( _atomid ); 361 265 362 // remove atoms 266 { 267 AtomNodeMap::iterator iter = AtomsinSceneMap.find(_atomid); 268 ASSERT(iter != AtomsinSceneMap.end(), 269 "GLWorldScene::removeAtom() - atom "+toString(_atomid)+" not on display."); 270 GLMoleculeObject_atom *atomObject = iter->second; 271 AtomsinSceneMap.erase(iter); 272 delete atomObject; 273 } 274 { 275 boost::recursive_mutex::scoped_lock lock(AtomNodeParentMap_mutex); 276 AtomNodeParentMap_t::left_iterator iter = AtomNodeParentMap.left.find(_atomid); 277 ASSERT( iter != AtomNodeParentMap.left.end(), 278 "GLWorldScene::removeAtom() - missing parent entry for "+toString(_atomid)); 279 if (iter->second == (ObservedValue_Index_t)NULL) { 280 LOG(4, "DEBUG: Found parent of atom as GLWorldScene, removing."); 281 removeStoredObservedValue(ObservedValueIndexLookup, ObservedAtoms, _atomid); 282 } 283 AtomNodeParentMap.left.erase(iter); 284 } 363 checkAndRemoveAtom( _atomid ); 285 364 286 365 emit changed(); … … 297 376 void GLWorldScene::connectBond(QtObservedBond::ptr _bond) 298 377 { 299 connect(_bond.get(), SIGNAL(leftmoleculeChanged()), this, SLOT(reparentBondLeft())); 300 connect(_bond.get(), SIGNAL(rightmoleculeChanged()), this, SLOT(reparentBondRight())); 378 LOG(3, "INFO: GLWorldScene::connectBond() - connecting to bonds " << _bond->getBondIndex()); 379 380 connect(_bond.get(), SIGNAL(leftmoleculeChanged()), this, SLOT(reparentBondLeft()), Qt::QueuedConnection); 381 connect(_bond.get(), SIGNAL(rightmoleculeChanged()), this, SLOT(reparentBondRight()), Qt::QueuedConnection); 301 382 302 383 // store the object, as we need it on reparenting … … 381 462 } 382 463 464 void GLWorldScene::checkAndRemoveBond(const ObservedValue_Index_t &_bondid) 465 { 466 if (checkBondRemoval(BondNodeParentMaps, ToBeRemovedNodes, _bondid)) { 467 LOG(3, "DEBUG: Found both parents of to be removed bond " << _bondid << " as GLWorldScene, removing."); 468 removeBondFromScene(BondsinSceneMap, _bondid); 469 removeStoredObservedValue(ObservedValueIndexLookup, ObservedBonds, _bondid); 470 eraseBondNodeParents(BondNodeParentMaps, _bondid); 471 ToBeRemovedNodes.erase(_bondid); 472 } 473 } 474 383 475 /** Removes a bond. 384 476 * … … 387 479 void GLWorldScene::removeBond(ObservedValue_Index_t _bondid) 388 480 { 389 LOG(3, "INFO: GLWorldScene::removedBond() - Removing bond to id " << _bondid); 390 391 // left bond 392 { 393 std::pair<BondNodeMap::iterator, BondNodeMap::iterator> iters = 394 BondsinSceneMap.equal_range(_bondid); 395 ASSERT( iters.first != iters.second, 396 "GLWorldScene::removedBond() - could not find bond to id "+toString(_bondid)); 397 for (BondNodeMap::iterator iter = iters.first; iter != iters.second; ++iter) { 398 GLMoleculeObject_bond *bondObject = iter->second; 399 delete bondObject; // is done by signal from bond itself 400 //LOG(4, "INFO: Still present bonds " << BondsinSceneMap << "."); 401 } 402 BondsinSceneMap.erase(_bondid); 403 } 404 { 405 boost::recursive_mutex::scoped_lock lock(BondNodeParentMap_mutex); 406 for (size_t i=0;i<2;++i) { 407 BondNodeParentMap_t::left_iterator iter = BondNodeParentMaps[i].left.find(_bondid); 408 ASSERT( iter != BondNodeParentMaps[i].left.end(), 409 "GLWorldScene::removeBond() - missing parent entry for "+toString(_bondid)); 410 if (iter->second == (ObservedValue_Index_t)NULL) { 411 LOG(4, "DEBUG: Found parent of bond as GLWorldScene, removing."); 412 removeStoredObservedValue(ObservedValueIndexLookup, ObservedBonds, _bondid); 413 } 414 BondNodeParentMaps[i].left.erase(iter); 415 } 416 } 481 boost::recursive_mutex::scoped_lock lock(BondNodeParentMap_mutex); 482 LOG(3, "INFO: GLWorldScene::removedBond() - got bondRemoved signal from board for id " << _bondid); 483 484 ASSERT( ToBeRemovedNodes.find(_bondid) == ToBeRemovedNodes.end(), 485 "GLWorldScene::removeBond() - bondRemoved for "+toString(_bondid)+" obtained twice?"); 486 ToBeRemovedNodes.insert( _bondid ); 487 488 // check whether node has still non-NULL parents, otherwise remove completely 489 checkAndRemoveBond( _bondid ); 417 490 418 491 emit changed(); … … 600 673 boost::recursive_mutex::scoped_lock lock(AtomNodeParentMap_mutex); 601 674 QObject * origin = sender(); 675 if (origin == NULL) { 676 ELOG(1, "Got reparentAtom() with sender being NULL."); 677 return; 678 } 602 679 ObservedAtoms_t::const_iterator iter = ObservedAtoms.find(origin); 603 680 ASSERT( iter != ObservedAtoms.end(), … … 623 700 // else atom does not yet exist 624 701 625 // check whether node is still shown, otherwise remove from lists completely 626 { 627 AtomNodeMap::iterator iter = AtomsinSceneMap.find(walkerid); 628 if (iter == AtomsinSceneMap.end()) { 629 LOG(3, "DEBUG: Reparented atom that is no longer on display, removing."); 630 removeStoredObservedValue(ObservedValueIndexLookup, ObservedAtoms, walkerid); 631 } 632 } 702 // check whether node is still shown, otherwise remove completely 703 checkAndRemoveAtom( walkerid ); 633 704 } 634 705 … … 640 711 boost::recursive_mutex::scoped_lock lock(BondNodeParentMap_mutex); 641 712 QObject * origin = sender(); 713 if (origin == NULL) { 714 ELOG(1, "Got reparentBondLeft() with sender being NULL."); 715 return; 716 } 642 717 ObservedBonds_t::const_iterator iter = ObservedBonds.find(origin); 643 718 ASSERT( iter != ObservedBonds.end(), 644 719 "GLWorldScene::reparentBondLeft() - bond "+toString(origin)+" is no longer stored?"); 645 720 QtObservedBond::ptr bond = iter->second; 721 LOG(3, "INFO: GLWorldScene::reparentBondLeft() - Reparenting left side of bond " 722 << bond->getBondIndex() << "."); 646 723 reparentBond(bond, bond->getLeftAtom(), GLMoleculeObject_bond::left); 647 724 648 // check whether node is still shown, otherwise remove from lists completely 649 { 650 const ObservedValue_Index_t bondid = bond->getIndex(); 651 BondNodeMap::iterator iter = BondsinSceneMap.find(bondid); 652 if (iter == BondsinSceneMap.end()) { 653 // check whether both parents are now NULL 654 BondNodeParentMap_t::left_iterator leftiter = BondNodeParentMaps[0].left.find(bondid); 655 BondNodeParentMap_t::left_iterator rightiter = BondNodeParentMaps[1].left.find(bondid); 656 ASSERT( leftiter != BondNodeParentMaps[0].left.end(), 657 "GLWorldScene::reparentBondRight() - left parent to index "+toString(bondid)+" missing?"); 658 ASSERT( rightiter != BondNodeParentMaps[1].left.end(), 659 "GLWorldScene::reparentBondRight() - right parent to index "+toString(bondid)+" missing?"); 660 if ((leftiter->second == (ObservedValue_Index_t)NULL) 661 && (rightiter->second == (ObservedValue_Index_t)NULL)) { 662 LOG(3, "DEBUG: Reparented both left and right bond that is also no longer on display, removing."); 663 removeStoredObservedValue(ObservedValueIndexLookup, ObservedBonds, bondid); 664 } 665 } 666 } 725 // check whether node is still shown, otherwise remove completely 726 checkAndRemoveBond( bond->getIndex() ); 667 727 } 668 728 … … 674 734 boost::recursive_mutex::scoped_lock lock(BondNodeParentMap_mutex); 675 735 QObject * origin = sender(); 736 if (origin == NULL) { 737 ELOG(1, "Got reparentBondRight() with sender being NULL."); 738 return; 739 } 676 740 ObservedBonds_t::const_iterator iter = ObservedBonds.find(origin); 677 741 ASSERT( iter != ObservedBonds.end(), 678 742 "GLWorldScene::reparentBondRight() - bond "+toString(origin)+" is no longer stored?"); 679 743 QtObservedBond::ptr bond = iter->second; 744 LOG(3, "INFO: GLWorldScene::reparentBondRight() - Reparenting right side of bond " 745 << bond->getBondIndex() << "."); 680 746 reparentBond(bond, bond->getRightAtom(), GLMoleculeObject_bond::right); 681 747 682 // check whether node is still shown, otherwise remove from lists completely 683 { 684 const ObservedValue_Index_t bondid = bond->getIndex(); 685 BondNodeMap::iterator iter = BondsinSceneMap.find(bondid); 686 if (iter == BondsinSceneMap.end()) { 687 // check whether both parents are now NULL 688 BondNodeParentMap_t::left_iterator leftiter = BondNodeParentMaps[0].left.find(bondid); 689 BondNodeParentMap_t::left_iterator rightiter = BondNodeParentMaps[1].left.find(bondid); 690 ASSERT( leftiter != BondNodeParentMaps[0].left.end(), 691 "GLWorldScene::reparentBondRight() - left parent to index "+toString(bondid)+" missing?"); 692 ASSERT( rightiter != BondNodeParentMaps[1].left.end(), 693 "GLWorldScene::reparentBondRight() - right parent to index "+toString(bondid)+" missing?"); 694 if ((leftiter->second == (ObservedValue_Index_t)NULL) 695 && (rightiter->second == (ObservedValue_Index_t)NULL)) { 696 LOG(3, "DEBUG: Reparented both left and right bond that is also no longer on display, removing."); 697 removeStoredObservedValue(ObservedValueIndexLookup, ObservedBonds, bondid); 698 } 699 } 700 } 748 // check whether node is still shown, otherwise remove completely 749 checkAndRemoveBond( bond->getIndex() ); 701 750 } 702 751 … … 707 756 std::pair<GLWorldScene::BondNodeMap::const_iterator, GLWorldScene::BondNodeMap::const_iterator> iters = 708 757 BondsinSceneMap.equal_range(_bondid); 709 ASSERT( std::distance(iters.first, iters.second) == 2,710 "GLWorldScene::getBondInScene() - not exactly two bonds of sameid "758 ASSERT( std::distance(iters.first, iters.second) >= 1, 759 "GLWorldScene::getBondInScene() - not at least one bond of id " 711 760 +toString(_bondid)+" present in scene."); 712 761 for (GLWorldScene::BondNodeMap::const_iterator bonditer = iters.first; … … 731 780 const size_t dim = (_side == GLMoleculeObject_bond::left) ? 0 : 1; 732 781 const ObservedValue_Index_t bondid = _bond->getIndex(); 733 LOG(4, "DEBUG: GLWorldScene: Received signal moleculeChanged for bond "+toString(bondid)+".");734 782 BondNodeParentMap_t::left_iterator parentiter = BondNodeParentMaps[dim].left.find(bondid); 735 783 ASSERT( parentiter != BondNodeParentMaps[dim].left.end(), … … 743 791 BondNodeParentMaps[dim].left.insert( std::make_pair( bondid, (ObservedValue_Index_t)NULL) ); 744 792 parentiter = BondNodeParentMaps[dim].left.find(bondid); 793 LOG(3, "INFO: GLWorldScene::reparentBond() - Reparented bond " 794 << _bond->getBondIndex() << " to " << parentiter->second); 745 795 746 796 // reset parent -
src/UIElements/Views/Qt4/Qt3D/GLWorldScene.hpp
r649f59 refeeb7 135 135 GLMoleculeObject_bond::SideOfBond _side) const; 136 136 137 void checkAndRemoveBond(const ObservedValue_Index_t &_bondid); 138 139 void checkAndRemoveAtom(const ObservedValue_Index_t &_atomid); 140 137 141 public: 138 142 void updateSelectedShapes(); … … 142 146 143 147 typedef std::map< ObservedValue_Index_t, QObject* > ObservedValueIndexLookup_t; 144 145 private:146 147 //!> id of atom hovered over148 atomId_t hoverAtomId;149 148 150 149 typedef std::map< ObservedValue_Index_t, GLMoleculeObject_molecule* > MoleculeNodeMap; … … 163 162 boost::bimaps::multiset_of< ObservedValue_Index_t > 164 163 > BondNodeParentMap_t; 164 165 typedef std::set< ObservedValue_Index_t > ToBeRemovedNodes_t; 166 167 private: 168 169 //!> id of atom hovered over 170 atomId_t hoverAtomId; 165 171 166 172 //!> mutex to ascertain atomic access to NodeParentMaps … … 182 188 ObservedValueIndexLookup_t ObservedValueIndexLookup; 183 189 190 //!> all atoms and bond id where we got the ...Removed signals for 191 ToBeRemovedNodes_t ToBeRemovedNodes; 192 184 193 SelectionModeType selectionMode; 185 194
Note:
See TracChangeset
for help on using the changeset viewer.