| [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); | 
|---|
| [d238e7] | 54 |  | 
|---|
| [7188b1] | 55 | signals: | 
|---|
|  | 56 | void changed(); | 
|---|
|  | 57 | void atomInserted(const atom *_atom); | 
|---|
|  | 58 | void atomRemoved(const atom *_atom); | 
|---|
| [53059e] | 59 | void moleculeInserted(const molecule *_molecule); | 
|---|
| [c67518] | 60 | void moleculeRemoved(const molecule *_molecule); | 
|---|
| [3927ef] | 61 | void worldSelectionChanged(); | 
|---|
| [407638e] | 62 | void hoverChanged(const atom *_atom); | 
|---|
| [7188b1] | 63 |  | 
|---|
| [d238e7] | 64 | protected: | 
|---|
| [06ebf5] | 65 | void initializeGL(QGLPainter *painter); | 
|---|
|  | 66 | void paintGL(QGLPainter *painter); | 
|---|
| [e8c636] | 67 | void drawDomainBox(QGLPainter *painter) const; | 
|---|
|  | 68 | void drawDreiBein(QGLPainter *painter); | 
|---|
| [8880c9] | 69 |  | 
|---|
|  | 70 | // input functions | 
|---|
|  | 71 | void mousePressEvent(QMouseEvent *event); | 
|---|
|  | 72 | void mouseMoveEvent(QMouseEvent *event); | 
|---|
|  | 73 | void keyPressEvent(QKeyEvent *event); | 
|---|
|  | 74 | void wheelEvent(QWheelEvent *event); | 
|---|
| [d238e7] | 75 |  | 
|---|
| [e13b34] | 76 | // camera functions | 
|---|
|  | 77 | enum CameraControlModeType{ | 
|---|
|  | 78 | Rotate, | 
|---|
|  | 79 | Translate | 
|---|
|  | 80 | }; | 
|---|
|  | 81 |  | 
|---|
|  | 82 | void setCameraControlMode(CameraControlModeType mode); | 
|---|
|  | 83 | CameraControlModeType getCameraControlMode(bool inverted = false); | 
|---|
|  | 84 | public slots: | 
|---|
|  | 85 | void fitCameraToDomain(); | 
|---|
|  | 86 | void setCameraControlModeRotation(); | 
|---|
|  | 87 | void setCameraControlModeTranslation(); | 
|---|
|  | 88 |  | 
|---|
|  | 89 | protected: | 
|---|
|  | 90 | CameraControlModeType cameraControlMode; | 
|---|
|  | 91 |  | 
|---|
| [d238e7] | 92 | private: | 
|---|
| [06ebf5] | 93 | GLWorldScene *worldscene; | 
|---|
| [65487f] | 94 |  | 
|---|
|  | 95 | bool changesPresent; | 
|---|
| [3927ef] | 96 | bool processingSelectionChanged; // workaround to prevent a loop in (atom_iterator <-> observer) | 
|---|
| [8880c9] | 97 |  | 
|---|
|  | 98 | QPointF lastMousePos; | 
|---|
| [e8c636] | 99 |  | 
|---|
| [26ed25] | 100 | QGLSceneNode *meshDomainBox; | 
|---|
|  | 101 | QGLSceneNode *meshDreiBein; | 
|---|
|  | 102 |  | 
|---|
| [e8c636] | 103 | QGLMaterial *domainBoxMaterial; | 
|---|
|  | 104 | QGLMaterial *dreiBeinMaterial[3]; | 
|---|
| [585f78] | 105 |  | 
|---|
|  | 106 | QTimer *redrawTimer; | 
|---|
|  | 107 | bool needsRedraw; | 
|---|
| [d238e7] | 108 | }; | 
|---|
|  | 109 |  | 
|---|
|  | 110 |  | 
|---|
|  | 111 |  | 
|---|
| [02ce36] | 112 | //#include "CodePatterns/Observer/Observer.hpp" | 
|---|
| [d238e7] | 113 | //#include "LinearAlgebra/Vector.hpp" | 
|---|
|  | 114 | //#include "changetypes.hpp" | 
|---|
|  | 115 | // | 
|---|
|  | 116 | //class atom; | 
|---|
|  | 117 | //class element; | 
|---|
|  | 118 | //class molecule; | 
|---|
|  | 119 | // | 
|---|
|  | 120 | //class GLMoleculeView : public QGLWidget, public Observer | 
|---|
|  | 121 | //{ | 
|---|
|  | 122 | //    Q_OBJECT | 
|---|
|  | 123 | // | 
|---|
|  | 124 | //public: | 
|---|
|  | 125 | // | 
|---|
|  | 126 | //    GLMoleculeView( QWidget* parent); | 
|---|
|  | 127 | //    ~GLMoleculeView(); | 
|---|
|  | 128 | // | 
|---|
|  | 129 | //public slots: | 
|---|
|  | 130 | // | 
|---|
|  | 131 | //    void    setXRotation( int degrees ); | 
|---|
|  | 132 | //    void    setYRotation( int degrees ); | 
|---|
|  | 133 | //    void    setZRotation( int degrees ); | 
|---|
|  | 134 | //    void    setScale( int distance ); | 
|---|
|  | 135 | //    void    setLightPosition( int *light ); | 
|---|
|  | 136 | //    void    setLightDiffuse( int *light ); | 
|---|
|  | 137 | //    void    setLightAmbient( int *light ); | 
|---|
|  | 138 | //    void    createDialogLight(); | 
|---|
|  | 139 | //    void    toggleMultiViewEnabled(); | 
|---|
|  | 140 | // | 
|---|
|  | 141 | //    void    init( QLabel *ptr ); | 
|---|
|  | 142 | //    void    initCoordinates(QLabel *ptr); | 
|---|
|  | 143 | //    void    createView(); | 
|---|
|  | 144 | //    void    hearMoleculeSelected(molecule *mol); | 
|---|
|  | 145 | //    void    hearAtomSelected(molecule *mol, atom *Walker); | 
|---|
|  | 146 | //    void    hearMoleculeChanged(molecule *mol, enum ChangesinMolecule type); | 
|---|
|  | 147 | //    void    hearAtomChanged(molecule *mol, atom *Walker, enum ChangesinAtom type); | 
|---|
|  | 148 | //    void    hearElementChanged(element *Runner, enum ChangesinElement type); | 
|---|
|  | 149 | //    void    hearMoleculeAdded(molecule *mol); | 
|---|
|  | 150 | //    void    hearAtomAdded(molecule *mol, atom *Walker); | 
|---|
|  | 151 | //    void    hearMoleculeRemoved(molecule *mol); | 
|---|
|  | 152 | //    void    hearAtomRemoved(molecule *mol, atom *Walker); | 
|---|
|  | 153 | // | 
|---|
|  | 154 | //signals: | 
|---|
|  | 155 | //    void    notifyMoleculeSelected( molecule *mol ); | 
|---|
|  | 156 | //    void    notifyAtomSelected( molecule *mol, atom *Walker ); | 
|---|
|  | 157 | //    void    notifyMoleculeChanged( molecule *mol, enum ChangesinMolecule type ); | 
|---|
|  | 158 | //    void    notifyAtomChanged( molecule *mol, atom *Walker, enum ChangesinAtom type ); | 
|---|
|  | 159 | //    void    notifyElementChanged( element *Runner, enum ChangesinElement type ); | 
|---|
|  | 160 | //    void    notifyMoleculeAdded( molecule *mol); | 
|---|
|  | 161 | //    void    notifyElementAdded( element *Runner); | 
|---|
|  | 162 | //    void    notifyAtomAdded( molecule *mol, atom *Walker ); | 
|---|
|  | 163 | //    void    notifyMoleculeRemoved( molecule *mol ); | 
|---|
|  | 164 | //    void    notifyAtomRemoved( molecule *mol, atom *Walker ); | 
|---|
|  | 165 | // | 
|---|
|  | 166 | //protected: | 
|---|
|  | 167 | // | 
|---|
|  | 168 | //    void    initializeGL(); | 
|---|
|  | 169 | //    void    paintGL(); | 
|---|
|  | 170 | //    void    resizeGL( int w, int h ); | 
|---|
|  | 171 | //    void    makeSphere(const Vector &x, double radius, const unsigned char color[3]); | 
|---|
|  | 172 | //    void    makeCylinder(const Vector &x, const Vector &y, double radius, double height, const unsigned char color[3]); | 
|---|
|  | 173 | //    void mousePressEvent(QMouseEvent* event); | 
|---|
|  | 174 | //    void mouseReleaseEvent(QMouseEvent* event); | 
|---|
|  | 175 | // | 
|---|
|  | 176 | //public: | 
|---|
|  | 177 | // | 
|---|
|  | 178 | //    /** Update function as we are an Observer. | 
|---|
|  | 179 | //     * | 
|---|
|  | 180 | //     * @param publisher ref to Observable | 
|---|
|  | 181 | //     */ | 
|---|
|  | 182 | //    void update(Observable *publisher); | 
|---|
|  | 183 | // | 
|---|
|  | 184 | //    /** | 
|---|
|  | 185 | //     * This method is called when a special named change | 
|---|
|  | 186 | //     * of the Observable occured | 
|---|
|  | 187 | //     */ | 
|---|
|  | 188 | //    void recieveNotification(Observable *publisher, Notification_ptr notification); | 
|---|
|  | 189 | // | 
|---|
|  | 190 | //    /** | 
|---|
|  | 191 | //     * This method is called when the observed object is destroyed. | 
|---|
|  | 192 | //     */ | 
|---|
|  | 193 | //    void subjectKilled(Observable *publisher); | 
|---|
|  | 194 | // | 
|---|
|  | 195 | // | 
|---|
|  | 196 | //private: | 
|---|
|  | 197 | // | 
|---|
|  | 198 | //    typedef std::map< size_t, node > AtomNodeMap; | 
|---|
|  | 199 | //    typedef std::map< std::pair< size_t, size_t> , node > BondNodeMap; | 
|---|
|  | 200 | //    typedef std::map< size_t, QGLMaterial *> ElementMaterialMap; | 
|---|
|  | 201 | // | 
|---|
|  | 202 | //    ElementMaterialMap ElementNoMaterialMap; | 
|---|
|  | 203 | //    AtomNodeMap AtomsinSceneMap; | 
|---|
|  | 204 | //    BondNodeMap BondsinSceneMap; | 
|---|
|  | 205 | // | 
|---|
|  | 206 | //    QGLMaterial* getMaterial(size_t); | 
|---|
|  | 207 | //    QGLSceneNode* getAtom(size_t); | 
|---|
|  | 208 | //    QGLSceneNode* getBond(size_t, size_t); | 
|---|
|  | 209 | // | 
|---|
|  | 210 | //    // old stuff | 
|---|
|  | 211 | // | 
|---|
|  | 212 | //    GLuint object;  // call list for the scene to be rendered | 
|---|
|  | 213 | //    GLfloat xRot, yRot, zRot, scale;  // rotation angles and scaling (zoom) | 
|---|
|  | 214 | //    Vector position;  //!< position of observer | 
|---|
|  | 215 | //    Vector view;      //!< point along line of view | 
|---|
|  | 216 | //    Vector top;       //!< giving upwards direction | 
|---|
|  | 217 | //    Vector X,Y,Z;     //!< vectors defining the coordinate system | 
|---|
|  | 218 | //    int width;        //!< width of window | 
|---|
|  | 219 | //    int height;       //!< height of window | 
|---|
|  | 220 | // | 
|---|
|  | 221 | //  QLabel *StatusBar;  //!< pointer to status bar for messages | 
|---|
|  | 222 | //  QLabel *CoordinatesBar; //!< pointer to coordinates bar for view port | 
|---|
|  | 223 | // | 
|---|
|  | 224 | //  GLfloat LightPosition[4];        //!< Light Position | 
|---|
|  | 225 | //  GLfloat LightDiffuse[4];         //!< Diffuse Light Values | 
|---|
|  | 226 | //  GLfloat LightAmbient[4];        //!< Ambient Light Values | 
|---|
|  | 227 | // | 
|---|
|  | 228 | //  QPoint LeftButtonPos;     //!< mouse position on mousePressEvent for LeftButton | 
|---|
|  | 229 | //  QPoint MiddleButtonPos;   //!< mouse position on mousePressEvent for MidButton | 
|---|
|  | 230 | //  QPoint RightButtonPos;    //!< mouse position on mousePressEvent for RightButton | 
|---|
|  | 231 | // | 
|---|
|  | 232 | //  unsigned char SelectionColor[3] ; //!< highlight color | 
|---|
|  | 233 | // | 
|---|
|  | 234 | //  bool isSignaller; | 
|---|
|  | 235 | // | 
|---|
|  | 236 | //  bool MultiViewEnabled;    //!< if true, split screen into four parts with additional xy,xz,yz views | 
|---|
|  | 237 | //}; | 
|---|
|  | 238 |  | 
|---|
|  | 239 | #endif /* GLWORLDVIEW_HPP_ */ | 
|---|