Ignore:
Timestamp:
Feb 14, 2016, 12:34:29 PM (9 years ago)
Author:
Frederik Heber <heber@…>
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:
03e69e
Parents:
1c0961
git-author:
Frederik Heber <heber@…> (01/07/16 12:00:38)
git-committer:
Frederik Heber <heber@…> (02/14/16 12:34:29)
Message:

FIX: Making sure that atomInserted is received from same source in GLWorldScene and GLMoleculeObject_molecule.

  • otherwise we cannot guarantee that the events are processed in order.
Location:
src/UIElements/Views/Qt4/Qt3D
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • src/UIElements/Views/Qt4/Qt3D/GLWorldScene.cpp

    r1c0961 r8281cc  
    9494  }
    9595  connect(board, SIGNAL(moleculeInserted(QtObservedMolecule::ptr)),
    96       this, SLOT(moleculeInserted(QtObservedMolecule::ptr)));
     96      this, SLOT(moleculeSignOn(QtObservedMolecule::ptr)));
    9797  connect(board, SIGNAL(moleculeRemoved(const moleculeId_t)),
    98       this, SLOT(moleculeRemoved(const moleculeId_t)));
     98      this, SLOT(moleculeSignOff(const moleculeId_t)));
    9999  connect(board, SIGNAL(moleculeIndexChanged(const moleculeId_t, const moleculeId_t)),
    100100      this, SLOT(moleculeIndexChanged(const moleculeId_t, const moleculeId_t)));
    101   connect(board, SIGNAL(atomInserted(QtObservedAtom::ptr)),
    102       this, SLOT(atomInserted(QtObservedAtom::ptr)));
    103   connect(board, SIGNAL(atomRemoved(const moleculeId_t, const atomId_t)),
    104       this, SLOT(atomRemoved(const moleculeId_t, const atomId_t)));
     101  connect(this, SIGNAL(insertMolecule(QtObservedMolecule::ptr)),
     102      this, SLOT(moleculeInserted(QtObservedMolecule::ptr)) );
     103  connect(this, SIGNAL(removeMolecule(const moleculeId_t)),
     104      this, SLOT(moleculeRemoved(const moleculeId_t)) );
    105105
    106106//  connect(this, SIGNAL(updated()), this, SLOT(update()));
     
    174174    MoleculeMissedStateMap[molid].insert( std::make_pair(atomid, atomInsertedState) );
    175175    QtObservedAtomMap[atomid] = _atom;
     176    connect(_atom.get(), SIGNAL(indexChanged(const atomId_t,const atomId_t)),
     177        this, SLOT(atomIndexChanged(const atomId_t,const atomId_t)) );
    176178    LOG(3, "INFO: GLWorldScene: Placing atomInserted for atom " << atomid
    177179         << " and molecule " << molid << " into missed state map.");
     
    184186 * @param _atomid atom to insert
    185187 */
    186 void GLWorldScene::atomRemoved(const moleculeId_t _molid, const atomId_t _atomid)
    187 {
     188void GLWorldScene::atomRemoved(const atomId_t _atomid)
     189{
     190  boost::recursive_mutex::scoped_lock lock(MoleculeMissedStateMap_mutex);
     191
    188192  LOG(3, "INFO: GLWorldScene: Received signal atomRemoved for atom "+toString(_atomid)+".");
    189193
    190   boost::recursive_mutex::scoped_lock lock(MoleculeMissedStateMap_mutex);
    191 
    192   // check of molecule is already present
    193   MoleculeNodeMap::iterator moliter = MoleculesinSceneMap.find(_molid);
    194   if (moliter != MoleculesinSceneMap.end()) {
    195     // no action, is also caught via QtObservedMolecule by GLMoleculeObject_molecule
    196   } else {
    197     // store signal for when it is instantiated
    198     if (MoleculeMissedStateMap.count(_molid) == 0)
    199       MoleculeMissedStateMap.insert( std::make_pair(_molid ,StateChangeMap_t()) );
    200     MoleculeMissedStateMap[_molid].insert( std::make_pair(_atomid, atomRemovedState) );
    201     LOG(3, "INFO: GLWorldScene: Placing atomRemoved for atom " << _atomid
    202          << " and molecule " << _molid << " into missed state map.");
    203   }
     194  // if atom is not in map, then GLMoleculeObject_molecule is already present anyway.
     195  if (QtObservedAtomMap.count(_atomid)) {
     196    const QtObservedAtom::ptr atom = QtObservedAtomMap[_atomid];
     197    const moleculeId_t molid = atom->getAtomMoleculeIndex();
     198    // check of molecule is already present
     199    MoleculeNodeMap::iterator moliter = MoleculesinSceneMap.find(molid);
     200    if (moliter != MoleculesinSceneMap.end()) {
     201      // no action, is also caught via QtObservedMolecule by GLMoleculeObject_molecule
     202    } else {
     203      // store signal for when it is instantiated
     204      if (MoleculeMissedStateMap.count(molid) == 0)
     205        MoleculeMissedStateMap.insert( std::make_pair(molid ,StateChangeMap_t()) );
     206      MoleculeMissedStateMap[molid].insert( std::make_pair(_atomid, atomRemovedState) );
     207      LOG(3, "INFO: GLWorldScene: Placing atomRemoved for atom " << _atomid
     208           << " and molecule " << molid << " into missed state map.");
     209    }
     210  }
     211}
     212
     213void GLWorldScene::moleculeSignOn(QtObservedMolecule::ptr _mol)
     214{
     215  // sign on to QtObservedMolecule to get atomInserted/..Removed signals from same
     216  // source as GLMoleculeObject_molecule would
     217  connect(_mol.get(), SIGNAL(atomInserted(QtObservedAtom::ptr)),
     218      this, SLOT(atomInserted(QtObservedAtom::ptr)) );
     219  connect(_mol.get(), SIGNAL(atomRemoved(const atomId_t)),
     220      this, SLOT(atomRemoved(const atomId_t)) );
     221  const moleculeId_t molid = _mol->getMolIndex();
     222  QtObservedMoleculeMap.insert( std::make_pair(molid, _mol) );
     223
     224  LOG(3, "INFO: GLWorldScene: Received signal moleculeSignOn for molecule "+toString(molid)+".");
     225
     226  emit insertMolecule(_mol);
     227}
     228
     229void GLWorldScene::moleculeSignOff(const moleculeId_t _id)
     230{
     231  ASSERT( QtObservedMoleculeMap.count(_id),
     232      "GLWorldScene::moleculeSignOff() - cannot find id "+toString(_id)+" in map.");
     233  const QtObservedMolecule::ptr mol = QtObservedMoleculeMap[_id];
     234  mol->disconnect(this);
     235  QtObservedMoleculeMap.erase(_id);
     236
     237  LOG(3, "INFO: GLWorldScene: Received signal moleculeSignOff for molecule "+toString(_id)+".");
     238
     239  emit removeMolecule(_id);
    204240}
    205241
     
    289325          {
    290326            LOG(1, "INFO: invoking atomInserted for atom " << iter->first);
     327            const QtObservedAtom::ptr walker = QtObservedAtomMap[iter->first];
    291328            QMetaObject::invokeMethod(molObject,        // pointer to a QObject
    292329                                      "atomInserted",       // member name (no parameters here)
     
    357394}
    358395
     396void GLWorldScene::atomIndexChanged(const atomId_t _oldid, const atomId_t _newid)
     397{
     398  if (QtObservedAtomMap.count(_oldid)) {
     399    const QtObservedAtom::ptr atom = QtObservedAtomMap[_oldid];
     400    QtObservedAtomMap.erase(_oldid);
     401    QtObservedAtomMap.insert( std::make_pair(_newid, atom) );
     402  }
     403}
     404
    359405void GLWorldScene::moleculeIndexChanged(const moleculeId_t _oldid, const moleculeId_t _newid)
    360406{
     
    367413    RemovalMolecules.erase(removeiter);
    368414    RemovalMolecules.insert(_newid);
     415    if (QtObservedMoleculeMap.count(_oldid)) {
     416      const QtObservedMolecule::ptr mol = QtObservedMoleculeMap[_oldid];
     417      QtObservedMoleculeMap.erase(_oldid);
     418      QtObservedMoleculeMap.insert( std::make_pair(_newid, mol) );
     419    }
    369420  } else {
    370421    LOG(1, "DEBUG: Changing GLMoleculeObject_molecule from " << _oldid << " to id " << _newid);
     
    467518}
    468519
    469 void GLWorldScene::changeMoleculeId(
    470     GLMoleculeObject_molecule *ob,
    471     const moleculeId_t oldId,
    472     const moleculeId_t newId)
    473 {
    474   LOG(3, "INFO: GLWorldScene - change molecule id " << oldId << " to " << newId << ".");
    475 
    476   {
    477     boost::recursive_mutex::scoped_lock lock(MoleculeinSceneMap_mutex);
    478     // Remove from map.
    479     MoleculeNodeMap::iterator iter = MoleculesinSceneMap.find(oldId);
    480     ASSERT(iter != MoleculesinSceneMap.end(),
    481         "GLWorldScene::changeMoleculeId() - molecule with old id "+toString(oldId)+" not on display.");
    482     ASSERT(iter->second == ob,
    483         "GLWorldScene::changeMoleculeId() - molecule with id "
    484         +toString(oldId)+" does not match with object in MoleculesinSceneMap.");
    485     MoleculesinSceneMap.erase(iter);
    486 
    487     // Reinsert with new id.
    488     {
    489       MoleculeNodeMap::iterator iter = MoleculesinSceneMap.find(newId);
    490       ASSERT(iter == MoleculesinSceneMap.end(),
    491             "GLWorldScene::changeMoleculeId() -  moleculewith new id "+toString(newId)+" already known.");
    492     }
    493     MoleculesinSceneMap.insert( make_pair(newId, ob) );
    494   }
    495 
    496   {
    497     boost::recursive_mutex::scoped_lock lock(MoleculeMissedStateMap_mutex);
    498     // Remove and re-insert from map if present.
    499     MoleculeMissedStateMap_t::iterator iter = MoleculeMissedStateMap.find(oldId);
    500     if (iter != MoleculeMissedStateMap.end()) {
    501       StateChangeMap_t changemap = iter->second;
    502       MoleculeMissedStateMap.erase(iter);
    503       MoleculeMissedStateMap.insert( std::make_pair(newId, changemap) );
    504     }
    505   }
    506 }
    507 
  • src/UIElements/Views/Qt4/Qt3D/GLWorldScene.hpp

    r1c0961 r8281cc  
    8484  void hoverChanged(const atomId_t);
    8585  void hoverChanged(const moleculeId_t, int);
     86  void insertMolecule(QtObservedMolecule::ptr);
     87  void removeMolecule(const moleculeId_t);
    8688
    8789private slots:
     
    8991  void moleculeClicked(moleculeId_t no);
    9092  void moleculeRemoved(const moleculeId_t _id);
     93  void moleculeSignOff(const moleculeId_t _id);
    9194  void moleculeInserted(QtObservedMolecule::ptr);
     95  void moleculeSignOn(QtObservedMolecule::ptr);
    9296  void moleculeIndexChanged(const moleculeId_t _oldid, const moleculeId_t _newid);
    93   void atomRemoved(const moleculeId_t _molid, const atomId_t _atomid);
     97  void atomRemoved(const atomId_t _atomid);
    9498  void atomInserted(QtObservedAtom::ptr);
     99  void atomIndexChanged(const atomId_t _oldid, const atomId_t _newid);
    95100  void setSelectionModeAtom();
    96101  void setSelectionModeMolecule();
     
    99104//  void update();
    100105  void moleculesVisibilityChanged(const moleculeId_t _id, bool _visible);
    101   void changeMoleculeId(GLMoleculeObject_molecule *, const moleculeId_t, const moleculeId_t);
    102106
    103107public:
     
    124128  };
    125129  typedef std::map< atomId_t, QtObservedAtom::ptr> QtObservedAtomMap_t;
     130  typedef std::map< moleculeId_t, QtObservedMolecule::ptr> QtObservedMoleculeMap_t;
    126131  typedef std::multimap< atomId_t, StateChangeType> StateChangeMap_t;
    127132  typedef std::map< moleculeId_t, StateChangeMap_t> MoleculeMissedStateMap_t;
     
    130135  //!> map to contain all QtObservedAtom that have not been instantiated so far
    131136  QtObservedAtomMap_t QtObservedAtomMap;
     137  //!> map to contain all QtObservedMolecule that have not been instantiated so far
     138  QtObservedMoleculeMap_t QtObservedMoleculeMap;
    132139  //!> flag to indicate whether state map is currently worked on
    133140  boost::recursive_mutex MoleculeMissedStateMap_mutex;
Note: See TracChangeset for help on using the changeset viewer.