source: trunk/source/visualization/OpenGL/src/G4OpenGLImmediateQtViewer.cc@ 1044

Last change on this file since 1044 was 1041, checked in by garnier, 17 years ago

en test

  • Property svn:mime-type set to text/cpp
File size: 7.5 KB
Line 
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//
27// $Id: G4OpenGLImmediateQtViewer.cc,v 1.14 2009/05/13 10:28:00 lgarnier Exp $
28// GEANT4 tag $Name: $
29//
30//
31// Class G4OpenGLImmediateQtViewer : a class derived from G4OpenGLQtViewer and
32// G4OpenGLImmediateViewer.
33
34#ifdef G4VIS_BUILD_OPENGLQT_DRIVER
35
36#include "G4OpenGLImmediateQtViewer.hh"
37#include "G4OpenGLImmediateSceneHandler.hh"
38
39#include "G4ios.hh"
40
41G4OpenGLImmediateQtViewer::G4OpenGLImmediateQtViewer
42(G4OpenGLImmediateSceneHandler& sceneHandler,
43 const G4String& name):
44 G4VViewer (sceneHandler, sceneHandler.IncrementViewCount (), name),
45 G4OpenGLViewer (sceneHandler),
46 G4OpenGLQtViewer (sceneHandler),
47 G4OpenGLImmediateViewer (sceneHandler)
48{
49
50 //set true to picking
51 fVP.SetPicking(true);
52 fDefaultVP.SetPicking(true);
53#if QT_VERSION < 0x040000
54 setFocusPolicy(QWidget::StrongFocus); // enable keybord events
55#else
56 setFocusPolicy(Qt::StrongFocus); // enable keybord events
57#endif
58 fHasToRepaint =false;
59
60 if (fViewId < 0) return; // In case error in base class instantiation.
61}
62
63G4OpenGLImmediateQtViewer::~G4OpenGLImmediateQtViewer() {
64 makeCurrent();
65}
66
67void G4OpenGLImmediateQtViewer::Initialise() {
68#ifdef G4DEBUG_VIS_OGL
69 printf("G4OpenGLImmediateQtViewer::Initialise \n");
70#endif
71 fReadyToPaint = false;
72 CreateMainWindow (this,QString(fName));
73 CreateFontLists ();
74
75 fReadyToPaint = true;
76}
77
78void G4OpenGLImmediateQtViewer::initializeGL () {
79
80 InitializeGLView ();
81
82
83 // If a double buffer context has been forced upon us, ignore the
84 // back buffer for this OpenGLImmediate view.
85 // glDrawBuffer (GL_FRONT); // FIXME : Ne marche pas avec cette ligne, mais affiche le run correctement...
86 // clear the buffers and window.
87 ClearView ();
88 FinishView ();
89
90 glDepthFunc (GL_LEQUAL);
91 glDepthMask (GL_TRUE);
92
93 if (fSceneHandler.GetScene() == 0) {
94 fHasToRepaint =false;
95 } else {
96 fHasToRepaint =true;
97 }
98
99}
100
101
102/** To ensure compatibility with DrawView method
103 */
104void G4OpenGLImmediateQtViewer::DrawView() {
105#ifdef G4DEBUG_VIS_OGL
106 printf("G4OpenGLImmediateQtViewer::DrawView VVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVV\n");
107#endif
108 // That's no the same logic as Stored Viewer, I don't know why...
109 // see G4OpenGLStoredQtViewer::DrawView for more informations
110
111 updateQWidget();
112#ifdef G4DEBUG_VIS_OGL
113 printf("G4OpenGLImmediateQtViewer::DrawView ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n");
114#endif
115}
116
117
118void G4OpenGLImmediateQtViewer::ComputeView () {
119
120#ifdef G4DEBUG_VIS_OGL
121 printf("G4OpenGLImmediateQtViewer::ComputeView %d %d VVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVV\n",getWinWidth(), getWinHeight());
122#endif
123 makeCurrent();
124 // If a double buffer context has been forced upon us, ignore the
125 // back buffer for this OpenGLImmediate view.
126 // glDrawBuffer (GL_FRONT);
127
128 G4ViewParameters::DrawingStyle style = GetViewParameters().GetDrawingStyle();
129
130 if(style!=G4ViewParameters::hlr &&
131 haloing_enabled) {
132
133 HaloingFirstPass ();
134 NeedKernelVisit ();
135 ProcessView ();
136 glFlush ();
137#ifdef G4DEBUG_VIS_OGL
138 printf("G4OpenGLImmediateQtViewer::ComputeView First ProcessView ok\n");
139#endif
140 HaloingSecondPass ();
141
142 }
143
144 NeedKernelVisit (); // Always need to visit G4 kernel.
145 ProcessView ();
146
147 if (isRecording()) {
148 savePPMToTemp();
149 }
150
151#ifdef G4DEBUG_VIS_OGL
152 printf("G4OpenGLImmediateQtViewer::ComputeView %d %d ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ \n",getWinWidth(), getWinHeight());
153#endif
154 fHasToRepaint = true;
155}
156
157void G4OpenGLImmediateQtViewer::FinishView()
158{
159#ifdef G4DEBUG_VIS_OGL
160 printf("G4OpenGLImmediateQtViewer::FinishView() BEGIN\n");
161#endif
162 glFlush ();
163#ifdef G4DEBUG_VIS_OGL
164 printf("G4OpenGLImmediateQtViewer::FinishView() END\n");
165#endif
166
167}
168
169
170/**
171 - Lors du resize de la fenetre, on doit non pas redessiner le detecteur, mais aussi les evenements
172*/
173void G4OpenGLImmediateQtViewer::resizeGL(
174 int aWidth
175,int aHeight)
176{
177 ResizeWindow(aWidth,aHeight);
178 fHasToRepaint = sizeHasChanged();
179}
180
181
182void G4OpenGLImmediateQtViewer::paintGL()
183{
184#ifdef G4DEBUG_VIS_OGL
185 printf("\n\nG4OpenGLImmediateQtViewer::paintGL ??\n");
186#endif
187 if (!fReadyToPaint) {
188 fReadyToPaint= true;
189 return;
190 }
191 // DO NOT RESIZE IF SIZE HAS NOT CHANGE
192 if ( !fHasToRepaint) {
193 if (((getWinWidth() == (unsigned int)width())) &&(getWinHeight() == (unsigned int) height())) {
194 return;
195 }
196 }
197#ifdef G4DEBUG_VIS_OGL
198 printf("G4OpenGLImmediateQtViewer::paintGL VVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVVV ready %d\n",fReadyToPaint);
199#endif
200
201 SetView();
202
203 ClearView (); //ok, put the background correct
204 ComputeView();
205
206 fHasToRepaint = false; // could be set to false by ComputeView
207
208#ifdef G4DEBUG_VIS_OGL
209 printf("G4OpenGLImmediateQtViewer::paintGL ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ ready %d\n\n\n",fReadyToPaint);
210#endif
211}
212
213void G4OpenGLImmediateQtViewer::mousePressEvent(QMouseEvent *event)
214{
215 G4MousePressEvent(event);
216}
217
218void G4OpenGLImmediateQtViewer::keyPressEvent (QKeyEvent * event)
219{
220 G4keyPressEvent(event);
221}
222
223void G4OpenGLImmediateQtViewer::wheelEvent (QWheelEvent * event)
224{
225 G4wheelEvent(event);
226}
227
228/**
229 * This function was build in order to make a zoom on double clic event.
230 * It was think to build a rubberband on the zoom area, but never work fine
231 */
232void G4OpenGLImmediateQtViewer::mouseDoubleClickEvent(QMouseEvent *)
233{
234 G4MouseDoubleClickEvent();
235}
236
237void G4OpenGLImmediateQtViewer::mouseReleaseEvent(QMouseEvent *)
238{
239 G4MouseReleaseEvent();
240}
241
242void G4OpenGLImmediateQtViewer::mouseMoveEvent(QMouseEvent *event)
243{
244 G4MouseMoveEvent(event);
245}
246
247
248void G4OpenGLImmediateQtViewer::contextMenuEvent(QContextMenuEvent *e)
249{
250 G4manageContextMenuEvent(e);
251}
252
253void G4OpenGLImmediateQtViewer::updateQWidget() {
254 fHasToRepaint= true;
255 updateGL();
256 fHasToRepaint= false;
257}
258
259
260void G4OpenGLImmediateQtViewer::ShowView (
261)
262//////////////////////////////////////////////////////////////////////////////
263//!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!//
264{
265#if QT_VERSION < 0x040000
266 setActiveWindow();
267#else
268 activateWindow();
269#endif
270}
271#endif
Note: See TracBrowser for help on using the repository browser.