| [d238e7] | 1 | /* | 
|---|
|  | 2 | * GLWorldView.hpp | 
|---|
|  | 3 | * | 
|---|
|  | 4 | *  Created on: Auf 11, 2010 | 
|---|
|  | 5 | *      Author: heber | 
|---|
|  | 6 | */ | 
|---|
|  | 7 |  | 
|---|
|  | 8 | #ifndef GLWORLDVIEW_HPP_ | 
|---|
|  | 9 | #define GLWORLDVIEW_HPP_ | 
|---|
|  | 10 |  | 
|---|
|  | 11 | // include config.h | 
|---|
|  | 12 | #ifdef HAVE_CONFIG_H | 
|---|
|  | 13 | #include <config.h> | 
|---|
|  | 14 | #endif | 
|---|
|  | 15 |  | 
|---|
| [4269ca] | 16 | #include <Qt3D/qglview.h> | 
|---|
| [d238e7] | 17 |  | 
|---|
| [02ce36] | 18 | #include "CodePatterns/Observer/Observer.hpp" | 
|---|
| [7188b1] | 19 |  | 
|---|
|  | 20 | #include "World.hpp" | 
|---|
|  | 21 |  | 
|---|
| [3e93332] | 22 | class molecule; | 
|---|
| [907636] | 23 | class QKeyEvent; | 
|---|
|  | 24 | class GLWorldScene; | 
|---|
| [d238e7] | 25 | class QGLPainter; | 
|---|
| [0e5d14] | 26 | class QToolBar; | 
|---|
| [585f78] | 27 | class QTimer; | 
|---|
| [d238e7] | 28 |  | 
|---|
|  | 29 | /** This class is the view on the 3D representation of the World, i.e. the whole | 
|---|
|  | 30 | * of all molecules (consisting of atoms). | 
|---|
|  | 31 | * | 
|---|
|  | 32 | */ | 
|---|
| [7188b1] | 33 | class GLWorldView : public QGLView, public Observer | 
|---|
| [d238e7] | 34 | { | 
|---|
| [06ebf5] | 35 | Q_OBJECT | 
|---|
| [d238e7] | 36 | public: | 
|---|
| [06ebf5] | 37 | GLWorldView(QWidget *parent=0); | 
|---|
|  | 38 | virtual ~GLWorldView(); | 
|---|
| [d238e7] | 39 |  | 
|---|
| [0e5d14] | 40 | void addToolBarActions(QToolBar *toolbar); | 
|---|
| [26ed25] | 41 | void createDomainBox(); | 
|---|
|  | 42 | void createDreiBein(); | 
|---|
| [0e5d14] | 43 |  | 
|---|
| [7188b1] | 44 | // Observer functions | 
|---|
|  | 45 | void update(Observable *publisher); | 
|---|
|  | 46 | void subjectKilled(Observable *publisher); | 
|---|
|  | 47 | void recieveNotification(Observable *publisher, Notification_ptr notification); | 
|---|
|  | 48 |  | 
|---|
| [d238e7] | 49 | public slots: | 
|---|
| [65487f] | 50 | void changeSignalled(); | 
|---|
| [585f78] | 51 | void checkChanges(); | 
|---|
|  | 52 | void sceneChangeSignalled(); | 
|---|
| [407638e] | 53 | void sceneHoverSignalled(const atom *_atom); | 
|---|
| [592d42] | 54 | void changeDreiBein(); | 
|---|
|  | 55 | void changeDomain(); | 
|---|
| [d238e7] | 56 |  | 
|---|
| [7188b1] | 57 | signals: | 
|---|
|  | 58 | void changed(); | 
|---|
| [ce4126] | 59 | void TimeChanged(); | 
|---|
| [beadd0] | 60 | void atomInserted(const atomicNumber_t _id); | 
|---|
| [c48ac12] | 61 | void atomRemoved(const atomicNumber_t _id); | 
|---|
| [53059e] | 62 | void moleculeInserted(const molecule *_molecule); | 
|---|
| [c67518] | 63 | void moleculeRemoved(const molecule *_molecule); | 
|---|
| [3927ef] | 64 | void worldSelectionChanged(); | 
|---|
| [407638e] | 65 | void hoverChanged(const atom *_atom); | 
|---|
| [4d6662] | 66 | void ShapeAdded(); | 
|---|
|  | 67 | void ShapeRemoved(); | 
|---|
| [7188b1] | 68 |  | 
|---|
| [d238e7] | 69 | protected: | 
|---|
| [06ebf5] | 70 | void initializeGL(QGLPainter *painter); | 
|---|
|  | 71 | void paintGL(QGLPainter *painter); | 
|---|
| [e8c636] | 72 | void drawDomainBox(QGLPainter *painter) const; | 
|---|
|  | 73 | void drawDreiBein(QGLPainter *painter); | 
|---|
| [8880c9] | 74 |  | 
|---|
|  | 75 | // input functions | 
|---|
|  | 76 | void mousePressEvent(QMouseEvent *event); | 
|---|
|  | 77 | void mouseMoveEvent(QMouseEvent *event); | 
|---|
|  | 78 | void keyPressEvent(QKeyEvent *event); | 
|---|
|  | 79 | void wheelEvent(QWheelEvent *event); | 
|---|
| [d238e7] | 80 |  | 
|---|
| [e13b34] | 81 | // camera functions | 
|---|
|  | 82 | enum CameraControlModeType{ | 
|---|
|  | 83 | Rotate, | 
|---|
|  | 84 | Translate | 
|---|
|  | 85 | }; | 
|---|
|  | 86 |  | 
|---|
|  | 87 | void setCameraControlMode(CameraControlModeType mode); | 
|---|
|  | 88 | CameraControlModeType getCameraControlMode(bool inverted = false); | 
|---|
|  | 89 | public slots: | 
|---|
|  | 90 | void fitCameraToDomain(); | 
|---|
|  | 91 | void setCameraControlModeRotation(); | 
|---|
|  | 92 | void setCameraControlModeTranslation(); | 
|---|
| [8e7dd9] | 93 | void setCameraStereoModeDisable(); | 
|---|
|  | 94 | void setCameraStereoModeHardware(); | 
|---|
|  | 95 | void setCameraStereoModeLeftRight(); | 
|---|
|  | 96 | void setCameraStereoModeRightLeft(); | 
|---|
|  | 97 | void setCameraStereoModeTopBottom(); | 
|---|
|  | 98 | void setCameraStereoModeBottomTop(); | 
|---|
|  | 99 | void setCameraStereoModeAnaglyph(); | 
|---|
| [e13b34] | 100 |  | 
|---|
|  | 101 | protected: | 
|---|
|  | 102 | CameraControlModeType cameraControlMode; | 
|---|
|  | 103 |  | 
|---|
| [592d42] | 104 | private: | 
|---|
|  | 105 | void setdreiBeinStatus(const bool status); | 
|---|
|  | 106 | void setDomainStatus(const bool status); | 
|---|
|  | 107 |  | 
|---|
| [d238e7] | 108 | private: | 
|---|
| [284551] | 109 |  | 
|---|
| [06ebf5] | 110 | GLWorldScene *worldscene; | 
|---|
| [65487f] | 111 |  | 
|---|
|  | 112 | bool changesPresent; | 
|---|
| [3927ef] | 113 | bool processingSelectionChanged; // workaround to prevent a loop in (atom_iterator <-> observer) | 
|---|
| [8880c9] | 114 |  | 
|---|
|  | 115 | QPointF lastMousePos; | 
|---|
| [e8c636] | 116 |  | 
|---|
| [26ed25] | 117 | QGLSceneNode *meshDomainBox; | 
|---|
|  | 118 | QGLSceneNode *meshDreiBein; | 
|---|
|  | 119 |  | 
|---|
| [e8c636] | 120 | QGLMaterial *domainBoxMaterial; | 
|---|
|  | 121 | QGLMaterial *dreiBeinMaterial[3]; | 
|---|
| [585f78] | 122 |  | 
|---|
|  | 123 | QTimer *redrawTimer; | 
|---|
|  | 124 | bool needsRedraw; | 
|---|
| [8e7dd9] | 125 |  | 
|---|
|  | 126 | double defaultEyeSeparation; | 
|---|
| [d238e7] | 127 | }; | 
|---|
|  | 128 |  | 
|---|
|  | 129 |  | 
|---|
|  | 130 |  | 
|---|
| [02ce36] | 131 | //#include "CodePatterns/Observer/Observer.hpp" | 
|---|
| [d238e7] | 132 | //#include "LinearAlgebra/Vector.hpp" | 
|---|
|  | 133 | //#include "changetypes.hpp" | 
|---|
|  | 134 | // | 
|---|
|  | 135 | //class atom; | 
|---|
|  | 136 | //class element; | 
|---|
|  | 137 | //class molecule; | 
|---|
|  | 138 | // | 
|---|
|  | 139 | //class GLMoleculeView : public QGLWidget, public Observer | 
|---|
|  | 140 | //{ | 
|---|
|  | 141 | //    Q_OBJECT | 
|---|
|  | 142 | // | 
|---|
|  | 143 | //public: | 
|---|
|  | 144 | // | 
|---|
|  | 145 | //    GLMoleculeView( QWidget* parent); | 
|---|
|  | 146 | //    ~GLMoleculeView(); | 
|---|
|  | 147 | // | 
|---|
|  | 148 | //public slots: | 
|---|
|  | 149 | // | 
|---|
|  | 150 | //    void    setXRotation( int degrees ); | 
|---|
|  | 151 | //    void    setYRotation( int degrees ); | 
|---|
|  | 152 | //    void    setZRotation( int degrees ); | 
|---|
|  | 153 | //    void    setScale( int distance ); | 
|---|
|  | 154 | //    void    setLightPosition( int *light ); | 
|---|
|  | 155 | //    void    setLightDiffuse( int *light ); | 
|---|
|  | 156 | //    void    setLightAmbient( int *light ); | 
|---|
|  | 157 | //    void    createDialogLight(); | 
|---|
|  | 158 | //    void    toggleMultiViewEnabled(); | 
|---|
|  | 159 | // | 
|---|
|  | 160 | //    void    init( QLabel *ptr ); | 
|---|
|  | 161 | //    void    initCoordinates(QLabel *ptr); | 
|---|
|  | 162 | //    void    createView(); | 
|---|
|  | 163 | //    void    hearMoleculeSelected(molecule *mol); | 
|---|
|  | 164 | //    void    hearAtomSelected(molecule *mol, atom *Walker); | 
|---|
|  | 165 | //    void    hearMoleculeChanged(molecule *mol, enum ChangesinMolecule type); | 
|---|
|  | 166 | //    void    hearAtomChanged(molecule *mol, atom *Walker, enum ChangesinAtom type); | 
|---|
|  | 167 | //    void    hearElementChanged(element *Runner, enum ChangesinElement type); | 
|---|
|  | 168 | //    void    hearMoleculeAdded(molecule *mol); | 
|---|
|  | 169 | //    void    hearAtomAdded(molecule *mol, atom *Walker); | 
|---|
|  | 170 | //    void    hearMoleculeRemoved(molecule *mol); | 
|---|
|  | 171 | //    void    hearAtomRemoved(molecule *mol, atom *Walker); | 
|---|
|  | 172 | // | 
|---|
|  | 173 | //signals: | 
|---|
|  | 174 | //    void    notifyMoleculeSelected( molecule *mol ); | 
|---|
|  | 175 | //    void    notifyAtomSelected( molecule *mol, atom *Walker ); | 
|---|
|  | 176 | //    void    notifyMoleculeChanged( molecule *mol, enum ChangesinMolecule type ); | 
|---|
|  | 177 | //    void    notifyAtomChanged( molecule *mol, atom *Walker, enum ChangesinAtom type ); | 
|---|
|  | 178 | //    void    notifyElementChanged( element *Runner, enum ChangesinElement type ); | 
|---|
|  | 179 | //    void    notifyMoleculeAdded( molecule *mol); | 
|---|
|  | 180 | //    void    notifyElementAdded( element *Runner); | 
|---|
|  | 181 | //    void    notifyAtomAdded( molecule *mol, atom *Walker ); | 
|---|
|  | 182 | //    void    notifyMoleculeRemoved( molecule *mol ); | 
|---|
|  | 183 | //    void    notifyAtomRemoved( molecule *mol, atom *Walker ); | 
|---|
|  | 184 | // | 
|---|
|  | 185 | //protected: | 
|---|
|  | 186 | // | 
|---|
|  | 187 | //    void    initializeGL(); | 
|---|
|  | 188 | //    void    paintGL(); | 
|---|
|  | 189 | //    void    resizeGL( int w, int h ); | 
|---|
|  | 190 | //    void    makeSphere(const Vector &x, double radius, const unsigned char color[3]); | 
|---|
|  | 191 | //    void    makeCylinder(const Vector &x, const Vector &y, double radius, double height, const unsigned char color[3]); | 
|---|
|  | 192 | //    void mousePressEvent(QMouseEvent* event); | 
|---|
|  | 193 | //    void mouseReleaseEvent(QMouseEvent* event); | 
|---|
|  | 194 | // | 
|---|
|  | 195 | //public: | 
|---|
|  | 196 | // | 
|---|
|  | 197 | //    /** Update function as we are an Observer. | 
|---|
|  | 198 | //     * | 
|---|
|  | 199 | //     * @param publisher ref to Observable | 
|---|
|  | 200 | //     */ | 
|---|
|  | 201 | //    void update(Observable *publisher); | 
|---|
|  | 202 | // | 
|---|
|  | 203 | //    /** | 
|---|
|  | 204 | //     * This method is called when a special named change | 
|---|
|  | 205 | //     * of the Observable occured | 
|---|
|  | 206 | //     */ | 
|---|
|  | 207 | //    void recieveNotification(Observable *publisher, Notification_ptr notification); | 
|---|
|  | 208 | // | 
|---|
|  | 209 | //    /** | 
|---|
|  | 210 | //     * This method is called when the observed object is destroyed. | 
|---|
|  | 211 | //     */ | 
|---|
|  | 212 | //    void subjectKilled(Observable *publisher); | 
|---|
|  | 213 | // | 
|---|
|  | 214 | // | 
|---|
|  | 215 | //private: | 
|---|
|  | 216 | // | 
|---|
|  | 217 | //    typedef std::map< size_t, node > AtomNodeMap; | 
|---|
|  | 218 | //    typedef std::map< std::pair< size_t, size_t> , node > BondNodeMap; | 
|---|
|  | 219 | //    typedef std::map< size_t, QGLMaterial *> ElementMaterialMap; | 
|---|
|  | 220 | // | 
|---|
|  | 221 | //    ElementMaterialMap ElementNoMaterialMap; | 
|---|
|  | 222 | //    AtomNodeMap AtomsinSceneMap; | 
|---|
|  | 223 | //    BondNodeMap BondsinSceneMap; | 
|---|
|  | 224 | // | 
|---|
|  | 225 | //    QGLMaterial* getMaterial(size_t); | 
|---|
|  | 226 | //    QGLSceneNode* getAtom(size_t); | 
|---|
|  | 227 | //    QGLSceneNode* getBond(size_t, size_t); | 
|---|
|  | 228 | // | 
|---|
|  | 229 | //    // old stuff | 
|---|
|  | 230 | // | 
|---|
|  | 231 | //    GLuint object;  // call list for the scene to be rendered | 
|---|
|  | 232 | //    GLfloat xRot, yRot, zRot, scale;  // rotation angles and scaling (zoom) | 
|---|
|  | 233 | //    Vector position;  //!< position of observer | 
|---|
|  | 234 | //    Vector view;      //!< point along line of view | 
|---|
|  | 235 | //    Vector top;       //!< giving upwards direction | 
|---|
|  | 236 | //    Vector X,Y,Z;     //!< vectors defining the coordinate system | 
|---|
|  | 237 | //    int width;        //!< width of window | 
|---|
|  | 238 | //    int height;       //!< height of window | 
|---|
|  | 239 | // | 
|---|
|  | 240 | //  QLabel *StatusBar;  //!< pointer to status bar for messages | 
|---|
|  | 241 | //  QLabel *CoordinatesBar; //!< pointer to coordinates bar for view port | 
|---|
|  | 242 | // | 
|---|
|  | 243 | //  GLfloat LightPosition[4];        //!< Light Position | 
|---|
|  | 244 | //  GLfloat LightDiffuse[4];         //!< Diffuse Light Values | 
|---|
|  | 245 | //  GLfloat LightAmbient[4];        //!< Ambient Light Values | 
|---|
|  | 246 | // | 
|---|
|  | 247 | //  QPoint LeftButtonPos;     //!< mouse position on mousePressEvent for LeftButton | 
|---|
|  | 248 | //  QPoint MiddleButtonPos;   //!< mouse position on mousePressEvent for MidButton | 
|---|
|  | 249 | //  QPoint RightButtonPos;    //!< mouse position on mousePressEvent for RightButton | 
|---|
|  | 250 | // | 
|---|
|  | 251 | //  unsigned char SelectionColor[3] ; //!< highlight color | 
|---|
|  | 252 | // | 
|---|
|  | 253 | //  bool isSignaller; | 
|---|
|  | 254 | // | 
|---|
|  | 255 | //  bool MultiViewEnabled;    //!< if true, split screen into four parts with additional xy,xz,yz views | 
|---|
|  | 256 | //}; | 
|---|
|  | 257 |  | 
|---|
|  | 258 | #endif /* GLWORLDVIEW_HPP_ */ | 
|---|