source: trunk/geant4/visualization/OpenGL/src/G4OpenGLStoredQtViewer.cc @ 803

Last change on this file since 803 was 800, checked in by garnier, 16 years ago

r838@wl-72126: garnier | 2008-05-15 18:52:11 +0200
en test avec les glRotation

  • Property svn:mime-type set to text/cpp
File size: 10.6 KB
RevLine 
[531]1//
2// ********************************************************************
3// * License and Disclaimer                                           *
4// *                                                                  *
5// * The  Geant4 software  is  copyright of the Copyright Holders  of *
6// * the Geant4 Collaboration.  It is provided  under  the terms  and *
7// * conditions of the Geant4 Software License,  included in the file *
8// * LICENSE and available at  http://cern.ch/geant4/license .  These *
9// * include a list of copyright holders.                             *
10// *                                                                  *
11// * Neither the authors of this software system, nor their employing *
12// * institutes,nor the agencies providing financial support for this *
13// * work  make  any representation or  warranty, express or implied, *
14// * regarding  this  software system or assume any liability for its *
15// * use.  Please see the license in the file  LICENSE  and URL above *
16// * for the full disclaimer and the limitation of liability.         *
17// *                                                                  *
18// * This  code  implementation is the result of  the  scientific and *
19// * technical work of the GEANT4 collaboration.                      *
20// * By using,  copying,  modifying or  distributing the software (or *
21// * any work based  on the software)  you  agree  to acknowledge its *
22// * use  in  resulting  scientific  publications,  and indicate your *
23// * acceptance of all terms of the Geant4 Software license.          *
24// ********************************************************************
25//
26//
[790]27// $Id: G4OpenGLStoredQtViewer.cc,v 1.14 2008/04/29 16:58:04 lgarnier Exp $
[593]28// GEANT4 tag $Name:  $
[531]29//
[564]30//
[533]31// Class G4OpenGLStoredQtViewer : a class derived from G4OpenGLQtViewer and
[564]32//                                G4OpenGLStoredViewer.
[531]33
[533]34#ifdef G4VIS_BUILD_OPENGLQT_DRIVER
[531]35
[799]36//#define GEANT4_QT_DEBUG
[610]37
[533]38#include "G4OpenGLStoredQtViewer.hh"
[531]39
40#include "G4ios.hh"
41
[595]42//#include <qmouseevent.h>
43#include <qevent.h> // include <qcontextmenuevent.h>
[593]44
[533]45G4OpenGLStoredQtViewer::G4OpenGLStoredQtViewer
[531]46(G4OpenGLStoredSceneHandler& sceneHandler,
47 const G4String&  name):
[682]48  G4VViewer (sceneHandler, sceneHandler.IncrementViewCount (), name),
49  G4OpenGLViewer (sceneHandler),
50  G4OpenGLQtViewer (sceneHandler),
[709]51  G4OpenGLStoredViewer (sceneHandler)             // FIXME : gerer le pb du parent !
[682]52{
[709]53#if QT_VERSION < 0x040000
54  setFocusPolicy(QWidget::StrongFocus); // enable keybord events
55#else
[696]56  setFocusPolicy(Qt::StrongFocus); // enable keybord events
[709]57#endif
[682]58  nbPaint =0;
59  hasToRepaint =false;
[531]60  if (fViewId < 0) return;  // In case error in base class instantiation.
61}
62
[564]63G4OpenGLStoredQtViewer::~G4OpenGLStoredQtViewer() {
[608]64#ifdef GEANT4_QT_DEBUG
[682]65  printf("GLWidget::~GLWidget \n");
[608]66#endif
[682]67  makeCurrent();
68  // this is connect to the Dialog for deleting it properly
69  // when close event.
70  //   ((QDialog*)window())->reject();
[608]71#ifdef GEANT4_QT_DEBUG
[682]72  printf("GLWidget::~GLWidget END\n");
[608]73#endif
[564]74}
[531]75
[564]76void G4OpenGLStoredQtViewer::Initialise() {
[608]77#ifdef GEANT4_QT_DEBUG
[682]78  printf("GLWidget::Initialise \n");
[608]79#endif
[682]80  readyToPaint = false;
81  CreateGLQtContext ();
[608]82#ifdef GEANT4_QT_DEBUG
[682]83  printf("G4OpenGLStoredQtViewer::Initialise () 2\n");
[608]84#endif
[564]85  CreateMainWindow (this);
[608]86#ifdef GEANT4_QT_DEBUG
[564]87  printf("G4OpenGLStoredQtViewer::Initialise () 3\n");
[608]88#endif
[682]89  CreateFontLists ();  // FIXME Does nothing!
[564]90 
[608]91#ifdef GEANT4_QT_DEBUG
[564]92  printf("readyToPaint = true \n");
[608]93#endif
[564]94  readyToPaint = true;
95}
[531]96
[564]97void G4OpenGLStoredQtViewer::initializeGL () {
98
[682]99  InitializeGLView ();
[564]100
[608]101#ifdef GEANT4_QT_DEBUG
[682]102  printf("G4OpenGLStoredQtViewer::InitialiseGL () 1\n");
[608]103#endif
[564]104
[682]105  // clear the buffers and window.
106  ClearView ();
107  //   printf("G4OpenGLStoredQtViewer::InitialiseGL () 2\n");
108  FinishView ();
[564]109   
[682]110  glDepthFunc (GL_LEQUAL);
111  glDepthMask (GL_TRUE);
[564]112
[682]113  hasToRepaint =true;
[564]114
[608]115#ifdef GEANT4_QT_DEBUG
[682]116  printf("G4OpenGLStoredQtViewer::InitialiseGL  -------------------------------------------------------------------------------------\n");
[608]117#endif
[531]118}
119
[564]120
[533]121void G4OpenGLStoredQtViewer::DrawView () {
[682]122
[608]123#ifdef GEANT4_QT_DEBUG
[800]124  printf("G4OpenGLQtViewer::setupViewport\n");
125#endif
126#ifdef GEANT4_QT_DEBUG
[564]127  printf("G4OpenGLStoredQtViewer::DrawView %d %d   VVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVV\n",WinSize_x, WinSize_y);
[608]128#endif
[682]129  G4ViewParameters::DrawingStyle style = GetViewParameters().GetDrawingStyle();
[531]130
[682]131  //Make sure current viewer is attached and clean...
132  //Qt version needed
133  //   glViewport (0, 0, WinSize_x, WinSize_y);
[531]134
[682]135  //See if things have changed from last time and remake if necessary...
136  // The fNeedKernelVisit flag might have been set by the user in
137  // /vis/viewer/rebuild, but if not, make decision and set flag only
138  // if necessary...
139  if (!fNeedKernelVisit)
[565]140
[682]141    if (!fNeedKernelVisit) KernelVisitDecision ();
[565]142   
[682]143  G4bool kernelVisitWasNeeded = fNeedKernelVisit; // Keep (ProcessView resets).
144  ProcessView ();
[564]145   
[531]146
[682]147  if(style!=G4ViewParameters::hlr &&
148     haloing_enabled) {
[608]149#ifdef GEANT4_QT_DEBUG
[682]150    printf("G4OpenGLStoredQtViewer::DrawView DANS LE IF\n");
[608]151#endif
[531]152
[682]153    HaloingFirstPass ();
154    DrawDisplayLists ();
155    glFlush ();
[531]156
[682]157    HaloingSecondPass ();
[531]158
[682]159    DrawDisplayLists ();
160    FinishView ();
[531]161
[682]162  } else {
[564]163     
[682]164    // If kernel visit was needed, drawing and FinishView will already
165    // have been done, so...
166    if (!kernelVisitWasNeeded) {
[608]167#ifdef GEANT4_QT_DEBUG
[797]168      printf("**************************  G4OpenGLStoredQtViewer::DrawView Don't need kernel Visit \n");
[608]169#endif
[682]170      DrawDisplayLists ();
171      FinishView ();
172    } else {
[608]173#ifdef GEANT4_QT_DEBUG
[797]174      printf("**************************  G4OpenGLStoredQtViewer::DrawView need kernel Visit \n");
[608]175#endif
[682]176      // However, union cutaways are implemented in DrawDisplayLists, so make
177      // an extra pass...
178      if (fVP.IsCutaway() &&
179          fVP.GetCutawayMode() == G4ViewParameters::cutawayUnion) {
180        ClearView();
181        DrawDisplayLists ();
182        FinishView ();
[608]183#ifdef GEANT4_QT_DEBUG
[682]184        printf("***************************  CASE 4 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ \n");
[608]185#endif
[682]186      } else { // ADD TO AVOID KernelVisit=1 and nothing to display
187        DrawDisplayLists ();
188        FinishView ();
189      }
190    }
191  }
[564]192
[745]193  if (isRecording()) {
[739]194    savePPMToTemp();
[724]195  }
196
197#ifdef GEANT4_QT_DEBUG
[682]198  printf("G4OpenGLStoredQtViewer::DrawView %d %d ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ \n",WinSize_x, WinSize_y);
[608]199#endif
[682]200  hasToRepaint =true;
[531]201}
202
[564]203
[531]204//////////////////////////////////////////////////////////////////////////////
[533]205void G4OpenGLStoredQtViewer::FinishView (
[531]206)
207//////////////////////////////////////////////////////////////////////////////
208//!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!//
209{
210  glFlush ();
[564]211  swapBuffers ();
[531]212}
213
[564]214
215/**
[682]216   - Lors du resize de la fenetre, on doit non pas redessiner le detecteur, mais aussi les evenements
217*/
[564]218void G4OpenGLStoredQtViewer::resizeGL(
[682]219                                      int aWidth
220                                      ,int aHeight)
[564]221
[673]222  setupViewport(aWidth,aHeight);
[564]223
[682]224  if (((WinSize_x != (G4int)aWidth)) || (WinSize_y != (G4int) aHeight)) {
225    hasToRepaint =true;
226  }
227  WinSize_x = (G4int) aWidth;
228  WinSize_y = (G4int) aHeight;
229 
[608]230#ifdef GEANT4_QT_DEBUG
[564]231  printf("G4OpenGLStoredQtViewer::resizeGL ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ %d %d=%d %d=%d\n",hasToRepaint,width(),aWidth,height(),aHeight);
[608]232#endif
[564]233}
234
235
[673]236/**
[682]237    @see :
[673]238*/
[564]239
240void G4OpenGLStoredQtViewer::paintGL()
[682]241{
242  if (!readyToPaint) {
[608]243#ifdef GEANT4_QT_DEBUG
[682]244    printf("G4OpenGLStoredQtViewer::paintGL ============  Not ready %d\n",readyToPaint);
[608]245#endif
[682]246    readyToPaint= true;
247    return;
248  }
249  // DO NOT RESIZE IF SIZE HAS NOT CHANGE :
250  //    WHEN CLICK ON THE FRAME FOR EXAMPLE
251  //    EXECEPT WHEN MOUSE MOVE EVENT
252  if ( !hasToRepaint) {
253    if (((WinSize_x == (G4int)width())) &&(WinSize_y == (G4int) height())) {
[608]254#ifdef GEANT4_QT_DEBUG
[682]255      printf("G4OpenGLStoredQtViewer::paintGL ============  Dont repaint\n");
[608]256#endif
[682]257      return;
258    }
259  }
260  nbPaint++;
[608]261#ifdef GEANT4_QT_DEBUG
[682]262  printf("G4OpenGLStoredQtViewer::paintGL VVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVV %d ready %d\n",nbPaint,readyToPaint);
[608]263#endif
[682]264  WinSize_x = (G4int) width();
265  WinSize_y = (G4int) height();
[673]266     
[682]267  setupViewport(width(),height());
268  //     glViewport (0, 0, width(), height());
269  //   glLoadIdentity();
[673]270     
271     
[682]272  SetView();
[673]273     
[682]274  //   //  printf("before ClearView\n");
[608]275#ifdef GEANT4_QT_DEBUG
[682]276  printf("    ClearView\n");
[608]277#endif
[673]278     
[682]279  ClearView (); //ok, put the background correct
280  DrawView();
[673]281     
[682]282  hasToRepaint =false;
[673]283     
[608]284#ifdef GEANT4_QT_DEBUG
[682]285  printf("G4OpenGLStoredQtViewer::paintGL ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ %d ready %d\n",nbPaint,readyToPaint);
[608]286#endif
[682]287}
[564]288
289void G4OpenGLStoredQtViewer::mousePressEvent(QMouseEvent *event)
290{
[709]291#if QT_VERSION < 0x040000
292  if ((event->button() & Qt::LeftButton)
293      && !((event->state() & Qt::ShiftButton)
294           || (event->state() & Qt::ControlButton)
295           || (event->state() & Qt::AltButton)
296           || (event->state() & Qt::MetaButton))) {
297#else
[690]298  if ((event->buttons() & Qt::LeftButton)
299      && !((event->modifiers() & Qt::ShiftModifier)
300           || (event->modifiers() & Qt::ControlModifier)
301           || (event->modifiers() & Qt::AltModifier)
302           || (event->modifiers() & Qt::MetaModifier))) {
[709]303#endif
[608]304#ifdef GEANT4_QT_DEBUG
[682]305    printf("G4OpenGLStoredQtViewer::mousePressEvent\n");
[608]306#endif
[682]307    setMouseTracking(true);
[797]308    G4MousePressEvent(event->pos());
[682]309  }
[564]310}
311
[696]312void G4OpenGLStoredQtViewer::keyPressEvent (QKeyEvent * event)
313{
314  G4keyPressEvent(event);
315}
316
[678]317/**
318 * This function was build in order to make a zoom on double clic event.
319 * It was think to build a rubberband on the zoom area, but never work fine
320 */
[673]321void G4OpenGLStoredQtViewer::mouseDoubleClickEvent(QMouseEvent *event)
322{
323#ifdef GEANT4_QT_DEBUG
324  printf("G4OpenGLStoredQtViewer::mouseDoubleClickEvent\n");
325#endif
[720]326  setMouseTracking(true);
[682]327  //   glBufferImage = grabFrameBuffer().convertToFormat(QImage::Format_ARGB32);//_Premultiplied); 
[673]328}
329
330void G4OpenGLStoredQtViewer::mouseReleaseEvent(QMouseEvent *event)
331{
[797]332  G4MouseReleaseEvent();
[673]333#ifdef GEANT4_QT_DEBUG
[797]334  printf("G4OpenGLStoredQtViewer::mouseReleaseEvent ================\n");
[673]335#endif
[720]336  setMouseTracking(false);
[673]337}
338
[564]339void G4OpenGLStoredQtViewer::mouseMoveEvent(QMouseEvent *event)
340{
[720]341 
[606]342#if QT_VERSION < 0x040000
[720]343  G4MouseMoveEvent(event->x(),event->y(),event->state());
[606]344#else
[720]345  G4MouseMoveEvent(event->x(),event->y(),event->buttons());
[606]346#endif
[564]347}
348
349
350void G4OpenGLStoredQtViewer::contextMenuEvent(QContextMenuEvent *e)
351{
[635]352#ifdef GEANT4_QT_DEBUG
353  printf("G4OpenGLStoredQtViewer::contextMenuEvent\n");
354#endif
[564]355  manageContextMenuEvent(e);
356}
357
358void G4OpenGLStoredQtViewer::updateQWidget() {
359  hasToRepaint= true;
360  updateGL();
361  hasToRepaint= false;
362}
363
[673]364
[531]365#endif
Note: See TracBrowser for help on using the repository browser.