source: src/UIElements/Views/Qt4/Qt3D/GLMoleculeObject_atom.hpp@ 099f67

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 099f67 was 16bd37, checked in by Frederik Heber <heber@…>, 10 years ago

GLMoleculeObject_atom's ObservedValues is now all static.

  • this is equivalent to the changes to GLMoleculeObject_molecule.
  • Property mode set to 100644
File size: 5.3 KB
Line 
1/*
2 * GLMoleculeObject_atom.hpp
3 *
4 * Created on: Aug 17, 2011
5 * Author: heber
6 */
7
8#ifndef GLMOLECULEOBJECT_ATOM_HPP_
9#define GLMOLECULEOBJECT_ATOM_HPP_
10
11// include config.h
12#ifdef HAVE_CONFIG_H
13#include <config.h>
14#endif
15
16#include "GLMoleculeObject.hpp"
17
18#include <vector>
19#include <boost/any.hpp>
20
21#include "CodePatterns/ObservedValue.hpp"
22#include "CodePatterns/Observer/Observer.hpp"
23
24#include "LinearAlgebra/Vector.hpp"
25
26#include "Bond/bond.hpp"
27#include "UIElements/Views/Qt4/Qt3D/GLMoleculeObject_bond.hpp"
28#include "types.hpp"
29
30class GLWorldScene;
31
32class GLMoleculeObject_atom : public GLMoleculeObject, Observer
33{
34 Q_OBJECT
35public:
36 GLMoleculeObject_atom(QGLSceneNode *mesh[], QObject *parent, const atomId_t id);
37 virtual ~GLMoleculeObject_atom();
38
39 void draw(QGLPainter *painter, const QVector4D &cameraPlane);
40
41 // Observer functions
42 void update(Observable *publisher);
43 void subjectKilled(Observable *publisher);
44 void recieveNotification(Observable *publisher, Notification_ptr notification);
45
46public slots:
47 void Selected();
48 void Unselected();
49
50private slots:
51 void wasClicked();
52 void resetIndex();
53 void resetElement();
54 void resetPosition();
55 void resetBonds();
56
57signals:
58 void clicked(atomId_t);
59 void BondsAdded(const atomId_t _left, const atomId_t _right, const GLMoleculeObject_bond::SideOfBond side);
60 void BondsRemoved(const atomId_t _left, const atomId_t _right);
61 void indexChanged(GLMoleculeObject_atom *ob, const atomId_t oldId, const atomId_t newId);
62 void idChanged();
63 void positionChanged();
64 void elementChanged();
65 void bondsChanged();
66 void InstanceRemoved(const atomId_t);
67
68private:
69 //!> grant GLMoleculeObject_molecule acess to reset functions
70 friend class GLMoleculeObject_molecule;
71
72 //!> typedef for list of bonds, defined by pairs of atom ids
73 typedef std::vector< std::pair<atomId_t, atomId_t> > ListOfBonds_t;
74
75 static const atom * const getAtomConst(const atomId_t _id);
76 static atom * const getAtom(const atomId_t _id);
77
78 static atomId_t updateIndex();
79 static Vector updatePosition(
80 const boost::function<const atomId_t ()> &_getAtomIndex);
81 static atomicNumber_t updateElement(
82 const boost::function<const atomId_t ()> &_getAtomIndex);
83 static ListOfBonds_t updateBonds(
84 const boost::function<const atomId_t ()> &_getAtomIndex);
85
86 void activateObserver();
87 void deactivateObserver();
88
89private:
90
91 //!> current list of bonds to compare new onw against for changes
92 ListOfBonds_t ListOfBonds;
93
94 //!> temporary variable used in cstor
95 atom * const atomref;
96
97private:
98 /** Observed Values **/
99
100 //!> enumeration of observed values to match with entries in ObservedValues
101 enum ObservedTypes {
102 //!> contains the current atom index
103 AtomIndex,
104 //!> contains the current atom position
105 AtomPosition,
106 //!> contains the current atom element
107 AtomElement,
108 //!> contains the current set of bonds atoms fort the atom
109 AtomBonds,
110 //!> gives the size of the enumeration
111 MAX_ObservedTypes
112 };
113
114 //!> vector with all observed values
115 std::vector<boost::any> ObservedValues;
116
117 /** Initializes all \a ObservedValues entries.
118 *
119 * \param _ObservedValues vector of ObservedValue to be filled
120 * \param _id atom id
121 * \param _atomref reference to atom
122 * \param _subjectKilled ref to function to call on subjectKilled()
123 */
124 static void initObservedValues(
125 std::vector<boost::any> &_ObservedValues,
126 const atomId_t _id,
127 const atom * const _atomref,
128 const boost::function<void()> &_subjectKilled);
129
130 /** Destroys all \a ObservedValues entries.
131 *
132 * \param _ObservedValues vector of ObservedValue to be destroyed
133 */
134 static void destroyObservedValues(
135 std::vector<boost::any> &_ObservedValues);
136
137 /** Getter to atom index contained in \a ObservedValues.
138 *
139 * \return atom's index
140 */
141 atomId_t getAtomIndex() const;
142
143 /** Getter to atom position contained in \a ObservedValues.
144 *
145 * \return atom's position
146 */
147 Vector getAtomPosition() const;
148
149 /** Getter to atom element contained in \a ObservedValues.
150 *
151 * \return atom's elemnt
152 */
153 atomicNumber_t getAtomElement() const;
154
155 /** Getter to atom bonds contained in \a ObservedValues.
156 *
157 * \return atom's bonds
158 */
159 ListOfBonds_t getAtomBonds() const;
160
161 /** Counts how many ObservedValues got subjectKilled.
162 *
163 * This is used to give InstanceRemoved() signal only when each and every
164 * ObservedValue (and the instance itself) has been subjectKilled by the
165 * monitored Observable. Only then can we safely remove the instance.
166 *
167 */
168 void countsubjectKilled();
169
170 //!> counts how many ObservedValues have already been subjectKilled()
171 mutable size_t subjectKilledCount;
172
173private:
174
175 //!> list of channels when index needs to update
176 static const Observable::channels_t AtomIndexChannels;
177 //!> list of channels when position needs to update
178 static const Observable::channels_t AtomPositionChannels;
179 //!> list of channels when element needs to update
180 static const Observable::channels_t AtomElementChannels;
181 //!> list of channels when bonds needs to update
182 static const Observable::channels_t AtomBondsChannels;
183
184 //!> the Observable we are signed on, also indicates whether we are sign on (not NULL)
185 const Observable *owner;
186};
187
188
189
190#endif /* GLMOLECULEOBJECT_ATOM_HPP_ */
Note: See TracBrowser for help on using the repository browser.