Geant4 11.3.0
Toolkit for the simulation of the passage of particles through matter
Loading...
Searching...
No Matches
G4ToolsSGViewer< SG_SESSION, SG_VIEWER > Class Template Reference

#include <G4ToolsSGViewer.hh>

+ Inheritance diagram for G4ToolsSGViewer< SG_SESSION, SG_VIEWER >:

Classes

class  Messenger
 

Public Member Functions

virtual void key_press (const tools::sg::key_down_event &a_event)
 
virtual void key_release (const tools::sg::key_up_event &)
 
virtual void mouse_press (const tools::sg::mouse_down_event &a_event)
 
virtual void mouse_release (const tools::sg::mouse_up_event &)
 
virtual void mouse_move (const tools::sg::mouse_move_event &a_event)
 
virtual void wheel_rotate (const tools::sg::wheel_rotate_event &a_event)
 
 G4ToolsSGViewer (SG_SESSION &a_session, G4ToolsSGSceneHandler &a_scene_handler, const G4String &a_name)
 
virtual ~G4ToolsSGViewer ()
 
virtual void Initialise ()
 
virtual void SetView ()
 
virtual void ClearView ()
 
virtual void DrawView ()
 
virtual void ShowView ()
 
virtual void FinishView ()
 
virtual void SwitchToVisSubThread ()
 
virtual void SwitchToMasterThread ()
 
- Public Member Functions inherited from G4VViewer
 G4VViewer (G4VSceneHandler &, G4int id, const G4String &name="")
 
virtual ~G4VViewer ()
 
virtual void ResetView ()
 
void RefreshView ()
 
virtual G4bool ReadyToDraw ()
 
std::vector< G4ThreeVectorComputeFlyThrough (G4Vector3D *)
 
virtual void DoneWithMasterThread ()
 
virtual void MovingToVisSubThread ()
 
virtual void DoneWithVisSubThread ()
 
virtual void MovingToMasterThread ()
 
void InsertModelInSceneTree (G4VModel *)
 
const G4SceneTreeItemGetSceneTree ()
 
G4SceneTreeItemAccessSceneTree ()
 
void UpdateGUISceneTree ()
 
const G4StringGetName () const
 
const G4StringGetShortName () const
 
void SetName (const G4String &)
 
G4int GetViewId () const
 
G4VSceneHandlerGetSceneHandler () const
 
const G4ViewParametersGetViewParameters () const
 
const G4ViewParametersGetDefaultViewParameters () const
 
G4double GetKernelVisitElapsedTimeSeconds () const
 
virtual const std::vector< G4ModelingParameters::VisAttributesModifier > * GetPrivateVisAttributesModifiers () const
 
void SetViewParameters (const G4ViewParameters &vp)
 
void SetDefaultViewParameters (const G4ViewParameters &vp)
 
const G4VisAttributesGetApplicableVisAttributes (const G4VisAttributes *) const
 
void SetNeedKernelVisit (G4bool need)
 
void NeedKernelVisit ()
 
void ProcessView ()
 

Protected Member Functions

 G4ToolsSGViewer (const G4ToolsSGViewer &a_from)
 
G4ToolsSGVieweroperator= (const G4ToolsSGViewer &)
 
void KernelVisitDecision ()
 
G4bool CompareForKernelVisit (G4ViewParameters &vp)
 
void CreateSG (tools::sg::base_camera *a_camera, const G4Vector3D &a_light_dir)
 
void Export (const G4String &a_format, const G4String &a_file, G4bool a_do_transparency)
 
- Protected Member Functions inherited from G4VViewer
void SetTouchable (const std::vector< G4PhysicalVolumeModel::G4PhysicalVolumeNodeID > &fullPath)
 
void TouchableSetVisibility (const std::vector< G4PhysicalVolumeModel::G4PhysicalVolumeNodeID > &fullPath, G4bool visibility)
 
void TouchableSetColour (const std::vector< G4PhysicalVolumeModel::G4PhysicalVolumeNodeID > &fullPath, const G4Colour &)
 

Protected Attributes

SG_SESSION & fSGSession
 
G4ToolsSGSceneHandlerfSGSceneHandler
 
SG_VIEWER * fSGViewer
 
G4ViewParameters fLastVP
 
G4bool fKeyPressed
 
G4bool fKeyShift
 
G4bool fMousePressed
 
G4double fMousePressedX
 
G4double fMousePressedY
 
tools::sg::zb_manager f_zb_mgr
 
tools::sg::gl2ps_manager f_gl2ps_mgr
 
- Protected Attributes inherited from G4VViewer
G4VSceneHandlerfSceneHandler
 
G4int fViewId
 
G4String fName
 
G4String fShortName
 
G4ViewParameters fVP
 
G4ViewParameters fDefaultVP
 
G4double fKernelVisitElapsedTimeSeconds = 999.
 
G4SceneTreeItem fSceneTree
 
G4bool fNeedKernelVisit
 

Additional Inherited Members

- Public Attributes inherited from G4VViewer
const G4int fMaxNTouchables = 10000
 
G4bool fCurtailDescent = false
 

Detailed Description

template<class SG_SESSION, class SG_VIEWER>
class G4ToolsSGViewer< SG_SESSION, SG_VIEWER >

Definition at line 53 of file G4ToolsSGViewer.hh.

Constructor & Destructor Documentation

◆ G4ToolsSGViewer() [1/2]

template<class SG_SESSION, class SG_VIEWER>
G4ToolsSGViewer< SG_SESSION, SG_VIEWER >::G4ToolsSGViewer ( SG_SESSION & a_session,
G4ToolsSGSceneHandler & a_scene_handler,
const G4String & a_name )
inline

Definition at line 122 of file G4ToolsSGViewer.hh.

123 :parent(a_scene_handler,a_scene_handler.IncrementViewCount(),a_name)
126 ,fSGViewer(nullptr)
127 ,fKeyPressed(false)
128 ,fKeyShift(false)
129 ,fMousePressed(false)
132 {
133 //::printf("debug : G4ToolsSGViewer::G4ToolsSGViewer: %lu, %s\n",this,a_name.c_str());
135 }
SG_SESSION & fSGSession
G4ToolsSGSceneHandler & fSGSceneHandler
SG_VIEWER * fSGViewer

Referenced by G4ToolsSGViewer< SG_SESSION, SG_VIEWER >::Messenger::SetNewValue().

◆ ~G4ToolsSGViewer()

template<class SG_SESSION, class SG_VIEWER>
virtual G4ToolsSGViewer< SG_SESSION, SG_VIEWER >::~G4ToolsSGViewer ( )
inlinevirtual

Definition at line 137 of file G4ToolsSGViewer.hh.

137 {
138 //::printf("debug : G4ToolsSGViewer::~G4ToolsSGViewer: %lu\n",this);
139 //WARNING : nodes may refer f_gl2ps_mgr, f_zb_mgr (to handle gstos (for GPU) or textures), then
140 // we have to delete them first.
141 fSGViewer->sg().clear();
142 delete fSGViewer;
143 }

◆ G4ToolsSGViewer() [2/2]

template<class SG_SESSION, class SG_VIEWER>
G4ToolsSGViewer< SG_SESSION, SG_VIEWER >::G4ToolsSGViewer ( const G4ToolsSGViewer< SG_SESSION, SG_VIEWER > & a_from)
inlineprotected

Definition at line 145 of file G4ToolsSGViewer.hh.

146 :parent(a_from)
147 ,parent_interactor(a_from)
150 ,fSGViewer(nullptr)
151 ,fKeyPressed(false)
152 ,fKeyShift(false)
153 ,fMousePressed(false)
156 {}

Member Function Documentation

◆ ClearView()

template<class SG_SESSION, class SG_VIEWER>
virtual void G4ToolsSGViewer< SG_SESSION, SG_VIEWER >::ClearView ( void )
inlinevirtual

Implements G4VViewer.

Reimplemented in G4ToolsSGOffscreenViewer.

Definition at line 274 of file G4ToolsSGViewer.hh.

274{}

◆ CompareForKernelVisit()

template<class SG_SESSION, class SG_VIEWER>
G4bool G4ToolsSGViewer< SG_SESSION, SG_VIEWER >::CompareForKernelVisit ( G4ViewParameters & vp)
inlineprotected

Definition at line 332 of file G4ToolsSGViewer.hh.

332 {
333 // Typical comparison. Taken from OpenInventor.
334 if (
335 (vp.GetDrawingStyle () != fVP.GetDrawingStyle ()) ||
336 (vp.GetNumberOfCloudPoints() != fVP.GetNumberOfCloudPoints()) ||
337 (vp.IsAuxEdgeVisible () != fVP.IsAuxEdgeVisible ()) ||
338 (vp.IsCulling () != fVP.IsCulling ()) ||
339 (vp.IsCullingInvisible () != fVP.IsCullingInvisible ()) ||
340 (vp.IsDensityCulling () != fVP.IsDensityCulling ()) ||
341 (vp.IsCullingCovered () != fVP.IsCullingCovered ()) ||
342 (vp.GetCBDAlgorithmNumber() !=
343 fVP.GetCBDAlgorithmNumber()) ||
344 (vp.IsSection () != fVP.IsSection ()) ||
345 (vp.IsCutaway () != fVP.IsCutaway ()) ||
346 // This assumes use of generic clipping (sectioning, slicing,
347 // DCUT, cutaway). If a decision is made to implement locally,
348 // this will need changing. See G4OpenGLViewer::SetView,
349 // G4OpenGLStoredViewer.cc::CompareForKernelVisit and
350 // G4OpenGLStoredSceneHander::CreateSection/CutawayPolyhedron.
351 (vp.IsExplode () != fVP.IsExplode ()) ||
352 (vp.GetNoOfSides () != fVP.GetNoOfSides ()) ||
353 (vp.GetGlobalMarkerScale() != fVP.GetGlobalMarkerScale()) ||
354 (vp.GetGlobalLineWidthScale() != fVP.GetGlobalLineWidthScale()) ||
355 (vp.IsMarkerNotHidden () != fVP.IsMarkerNotHidden ()) ||
356 (vp.GetDefaultVisAttributes()->GetColour() !=
357 fVP.GetDefaultVisAttributes()->GetColour()) ||
358 (vp.GetDefaultTextVisAttributes()->GetColour() !=
359 fVP.GetDefaultTextVisAttributes()->GetColour()) ||
360 (vp.GetBackgroundColour ()!= fVP.GetBackgroundColour ())||
361 (vp.IsPicking () != fVP.IsPicking ()) ||
362 // Scaling for Open Inventor is done by the scene handler so it
363 // needs a kernel visit. (In this respect, it differs from the
364 // OpenGL drivers, where it's done in SetView.)
365 (vp.GetScaleFactor () != fVP.GetScaleFactor ()) ||
366 (vp.GetVisAttributesModifiers() !=
367 fVP.GetVisAttributesModifiers()) ||
368 (vp.IsSpecialMeshRendering() !=
369 fVP.IsSpecialMeshRendering()) ||
370 (vp.GetSpecialMeshRenderingOption() !=
371 fVP.GetSpecialMeshRenderingOption())
372 )
373 return true;
374
375 if (vp.IsDensityCulling () &&
376 (vp.GetVisibleDensity () != fVP.GetVisibleDensity ()))
377 return true;
378
379 if (vp.GetCBDAlgorithmNumber() > 0) {
380 if (vp.GetCBDParameters().size() != fVP.GetCBDParameters().size()) return true;
381 else if (vp.GetCBDParameters() != fVP.GetCBDParameters()) return true;
382 }
383
384 if (vp.IsSection () &&
385 (vp.GetSectionPlane () != fVP.GetSectionPlane ()))
386 return true;
387
388 if (vp.IsCutaway ()) {
389 if (vp.GetCutawayMode() != fVP.GetCutawayMode()) return true;
390 if (vp.GetCutawayPlanes ().size () !=
391 fVP.GetCutawayPlanes ().size ()) return true;
392 for (size_t i = 0; i < vp.GetCutawayPlanes().size(); ++i)
393 if (vp.GetCutawayPlanes()[i] != fVP.GetCutawayPlanes()[i])
394 return true;
395 }
396
397 if (vp.IsExplode () &&
398 (vp.GetExplodeFactor () != fVP.GetExplodeFactor ()))
399 return true;
400
401 if (vp.IsSpecialMeshRendering() &&
402 (vp.GetSpecialMeshVolumes() != fVP.GetSpecialMeshVolumes()))
403 return true;
404
405 return false;
406 }
G4ViewParameters fVP
Definition G4VViewer.hh:257

Referenced by G4ToolsSGViewer< tools::offscreen::session, tools::offscreen::sg_viewer >::KernelVisitDecision().

◆ CreateSG()

template<class SG_SESSION, class SG_VIEWER>
void G4ToolsSGViewer< SG_SESSION, SG_VIEWER >::CreateSG ( tools::sg::base_camera * a_camera,
const G4Vector3D & a_light_dir )
inlineprotected

2D scene graph: ///////////////////////////////

3D scene graph: ///////////////////////////////

Definition at line 416 of file G4ToolsSGViewer.hh.

416 {
418 _parent.clear();
419
420 ///////////////////////////////////////////////////
421 /// 2D scene graph: ///////////////////////////////
422 ///////////////////////////////////////////////////
424 _parent.add(scene_2D);
425 scene_2D->add(new tools::sg::noderef(fSGSceneHandler.GetTransient2DObjects()));
426 scene_2D->add(new tools::sg::noderef(fSGSceneHandler.GetPersistent2DObjects()));
427
428 ///////////////////////////////////////////////////
429 /// 3D scene graph: ///////////////////////////////
430 ///////////////////////////////////////////////////
432 _parent.add(scene_3D);
433
434 scene_3D->add(a_camera);
435
437 light->on = true;
438 light->direction = tools::vec3f(-a_light_dir.x(),-a_light_dir.y(),-a_light_dir.z());
439 light->ambient = tools::colorf(0.2f,0.2f,0.2f,1.0f); //same as in G4OpenGLViewer.cc glLight(GL_LIGHT0,GL_AMBIENT and GL_DIFFUSE).
440 light->color = tools::colorf(0.8f,0.8f,0.8f,1.0f); //idem.
441 scene_3D->add(light);}
442
444 blend->on = true; //to handle transparency.
445 scene_3D->add(blend);}
446
447 scene_3D->add(new tools::sg::noderef(fSGSceneHandler.GetTransient3DObjects()));
448 scene_3D->add(new tools::sg::noderef(fSGSceneHandler.GetPersistent3DObjects()));
449 }

Referenced by G4ToolsSGViewer< tools::offscreen::session, tools::offscreen::sg_viewer >::SetView().

◆ DrawView()

template<class SG_SESSION, class SG_VIEWER>
virtual void G4ToolsSGViewer< SG_SESSION, SG_VIEWER >::DrawView ( )
inlinevirtual

Implements G4VViewer.

Reimplemented in G4ToolsSGOffscreenViewer.

Definition at line 276 of file G4ToolsSGViewer.hh.

276 {
278 G4bool kernelVisitWasNeeded = fNeedKernelVisit; // Keep (ProcessView resets).
279 fLastVP = fVP;
280 ProcessView(); // Clears store and processes scene only if necessary.
282 // We might need to do something if the kernel was visited.
283 } else {
284 }
285 FinishView (); // Flush streams and/or swap buffers.
286 }
virtual void FinishView()
G4ViewParameters fLastVP
G4bool fNeedKernelVisit
Definition G4VViewer.hh:265
void ProcessView()
Definition G4VViewer.cc:109

Referenced by G4ToolsSGViewer< tools::offscreen::session, tools::offscreen::sg_viewer >::mouse_move(), G4ToolsSGViewer< tools::offscreen::session, tools::offscreen::sg_viewer >::SwitchToMasterThread(), and G4ToolsSGViewer< tools::offscreen::session, tools::offscreen::sg_viewer >::wheel_rotate().

◆ Export()

template<class SG_SESSION, class SG_VIEWER>
void G4ToolsSGViewer< SG_SESSION, SG_VIEWER >::Export ( const G4String & a_format,
const G4String & a_file,
G4bool a_do_transparency )
inlineprotected

Definition at line 451 of file G4ToolsSGViewer.hh.

451 {
452 if(!fSGViewer) return;
453 const G4Colour& back_color = fVP.GetBackgroundColour();
454 bool top_to_bottom = false; //if using tools::fpng, tools::toojpeg.
457 float(back_color.GetRed()),float(back_color.GetGreen()),float(back_color.GetBlue()),float(back_color.GetAlpha()),
458 fSGViewer->sg(),fSGViewer->width(),fSGViewer->height(),
460 G4cout << "G4ToolsSGViewer::Export: write_paper() failed." << G4endl;
461 return;
462 }
463 }
tools::sg::gl2ps_manager f_gl2ps_mgr
tools::sg::zb_manager f_zb_mgr

Referenced by G4ToolsSGViewer< SG_SESSION, SG_VIEWER >::Messenger::SetNewValue().

◆ FinishView()

template<class SG_SESSION, class SG_VIEWER>
virtual void G4ToolsSGViewer< SG_SESSION, SG_VIEWER >::FinishView ( void )
inlinevirtual

Reimplemented from G4VViewer.

Reimplemented in G4ToolsSGOffscreenViewer.

Definition at line 290 of file G4ToolsSGViewer.hh.

290 {
291 if(fSGViewer) {
292 fSGSceneHandler.TouchPlotters(fSGViewer->sg());
293 fSGViewer->show();
294 fSGViewer->win_render();
295 fSGSession.sync();
296 }
297 }

Referenced by G4ToolsSGViewer< tools::offscreen::session, tools::offscreen::sg_viewer >::DrawView(), and G4ToolsSGViewer< tools::offscreen::session, tools::offscreen::sg_viewer >::ShowView().

◆ Initialise()

template<class SG_SESSION, class SG_VIEWER>
virtual void G4ToolsSGViewer< SG_SESSION, SG_VIEWER >::Initialise ( )
inlinevirtual

create the viewer, set the scene graph ///////////////

Reimplemented from G4VViewer.

Reimplemented in G4ToolsSGOffscreenViewer, G4ToolsSGQtGLESViewer, and G4ToolsSGQtZBViewer.

Definition at line 159 of file G4ToolsSGViewer.hh.

159 {
160 if(fSGViewer) return; //done.
161 fVP.SetAutoRefresh(true);
162 fDefaultVP.SetAutoRefresh(true);
163 //::printf("debug : G4ToolsSGViewer::Initialise\n");
164 //////////////////////////////////////////////////////////
165 /// create the viewer, set the scene graph ///////////////
166 //////////////////////////////////////////////////////////
168 ,fVP.GetWindowAbsoluteLocationHintX(1440)
169 ,fVP.GetWindowAbsoluteLocationHintY(900)
170 ,fVP.GetWindowSizeHintX()
171 ,fVP.GetWindowSizeHintY()
172 ,fName);
173 if(!fSGViewer->has_window()) {
174 fViewId = -1; // This flags an error.
175 G4cerr << "G4ToolsSGViewer::Initialise : SG_VIEWER::has_window() failed." << G4endl;
176 return;
177 }
178 fSGViewer->set_device_interactor(this);
179 }
G4String fName
Definition G4VViewer.hh:255
G4ViewParameters fDefaultVP
Definition G4VViewer.hh:258
G4int fViewId
Definition G4VViewer.hh:254

◆ KernelVisitDecision()

template<class SG_SESSION, class SG_VIEWER>
void G4ToolsSGViewer< SG_SESSION, SG_VIEWER >::KernelVisitDecision ( )
inlineprotected

Definition at line 326 of file G4ToolsSGViewer.hh.

326 {
328 NeedKernelVisit (); // Sets fNeedKernelVisit.
329 }
330 }
G4bool CompareForKernelVisit(G4ViewParameters &vp)
void NeedKernelVisit()
Definition G4VViewer.cc:82

Referenced by G4ToolsSGViewer< tools::offscreen::session, tools::offscreen::sg_viewer >::DrawView().

◆ key_press()

template<class SG_SESSION, class SG_VIEWER>
virtual void G4ToolsSGViewer< SG_SESSION, SG_VIEWER >::key_press ( const tools::sg::key_down_event & a_event)
inlinevirtual

Definition at line 57 of file G4ToolsSGViewer.hh.

57 {
58 fKeyPressed = true;
59 fKeyShift = a_event.key() == tools::sg::key_shift()?true:false;
60 }

◆ key_release()

template<class SG_SESSION, class SG_VIEWER>
virtual void G4ToolsSGViewer< SG_SESSION, SG_VIEWER >::key_release ( const tools::sg::key_up_event & )
inlinevirtual

Definition at line 61 of file G4ToolsSGViewer.hh.

61{fKeyPressed = false;}

◆ mouse_move()

template<class SG_SESSION, class SG_VIEWER>
virtual void G4ToolsSGViewer< SG_SESSION, SG_VIEWER >::mouse_move ( const tools::sg::mouse_move_event & a_event)
inlinevirtual

Definition at line 68 of file G4ToolsSGViewer.hh.

68 {
69 G4double x = a_event.x();
70 G4double y = a_event.y();
75
76 if (fMousePressed) {
77
78 if (fKeyPressed && fKeyShift) { // Translation (pan)
79
80 const G4double sceneRadius = fSGSceneHandler.GetScene()->GetExtent().GetExtentRadius();
81 const G4double scale = 300; // Roughly pixels per window, empirically chosen
84 fVP.IncrementPan(-dxScene,dyScene);
85
86 } else { // Rotation
87
88 // Simple ad-hoc algorithms
89 const G4Vector3D& x_prime = fVP.GetViewpointDirection().cross(fVP.GetUpVector());
90 const G4Vector3D& y_prime = x_prime.cross(fVP.GetViewpointDirection());
91 const G4double scale = 200; // Roughly pixels per window, empirically chosen
92 G4Vector3D newViewpointDirection = fVP.GetViewpointDirection();
95 fVP.SetViewpointDirection(newViewpointDirection.unit());
96
97 if (fVP.GetRotationStyle() == G4ViewParameters::freeRotation) {
98 G4Vector3D newUpVector = fVP.GetUpVector();
101 fVP.SetUpVector(newUpVector.unit());
102 }
103 }
104 }
105
106 SetView();
107 DrawView();
108 }
virtual void SetView()
virtual void DrawView()

◆ mouse_press()

template<class SG_SESSION, class SG_VIEWER>
virtual void G4ToolsSGViewer< SG_SESSION, SG_VIEWER >::mouse_press ( const tools::sg::mouse_down_event & a_event)
inlinevirtual

Definition at line 62 of file G4ToolsSGViewer.hh.

62 {
63 fMousePressed = true;
66 }

◆ mouse_release()

template<class SG_SESSION, class SG_VIEWER>
virtual void G4ToolsSGViewer< SG_SESSION, SG_VIEWER >::mouse_release ( const tools::sg::mouse_up_event & )
inlinevirtual

Definition at line 67 of file G4ToolsSGViewer.hh.

67{fMousePressed = false;}

◆ operator=()

template<class SG_SESSION, class SG_VIEWER>
G4ToolsSGViewer & G4ToolsSGViewer< SG_SESSION, SG_VIEWER >::operator= ( const G4ToolsSGViewer< SG_SESSION, SG_VIEWER > & )
inlineprotected

Definition at line 157 of file G4ToolsSGViewer.hh.

157{return *this;}

◆ SetView()

template<class SG_SESSION, class SG_VIEWER>
virtual void G4ToolsSGViewer< SG_SESSION, SG_VIEWER >::SetView ( )
inlinevirtual

create scene graph ///////////////////////////////////

Implements G4VViewer.

Reimplemented in G4ToolsSGOffscreenViewer, G4ToolsSGQtGLESViewer, and G4ToolsSGQtZBViewer.

Definition at line 181 of file G4ToolsSGViewer.hh.

181 {
182 //::printf("debug : G4ToolsSGViewer::SetView\n");
183 if(!fSceneHandler.GetScene()) {
184 fSGViewer->set_clear_color(0.3,0.3,0.3,1); //some grey color to signal the user that something is wrong.
185 G4cerr << "G4ToolsSGViewer::SetView : no G4Scene.." << G4endl;
186 return;
187 }
188
189 //////////////////////////////////////////////////////////
190 //////////////////////////////////////////////////////////
191 //////////////////////////////////////////////////////////
192 // Get radius of scene, etc.
193 // Note that this procedure properly takes into account zoom, dolly and pan.
195 = fSceneHandler.GetScene()->GetStandardTargetPoint() + fVP.GetCurrentTargetPoint ();
196 G4double radius = fSceneHandler.GetScene()->GetExtent().GetExtentRadius();
197 if(radius<=0.) radius = 1.;
198 const G4double cameraDistance = fVP.GetCameraDistance (radius);
199 const G4Point3D cameraPosition = targetPoint + cameraDistance * fVP.GetViewpointDirection().unit();
200 const G4Normal3D& up = fVP.GetUpVector ();
201 const G4double pnear = fVP.GetNearDistance (cameraDistance, radius);
202 const G4double pfar = fVP.GetFarDistance (cameraDistance, pnear, radius);
203 //const G4double right = fVP.GetFrontHalfHeight (pnear, radius);
204 //const G4double left = -right;
205 const G4double top = fVP.GetFrontHalfHeight (pnear, radius);
206 const G4double bottom = -top;
207 // sanity check :
209 float(targetPoint.y()-cameraPosition.y()),
210 float(targetPoint.z()-cameraPosition.z()));
211 if(!dir.length()) {
212 fSGViewer->set_clear_color(0.3,0.3,0.3,1);
213 G4cerr << "G4ToolsSGViewer::SetView : null size viewer area." << G4endl;
214 return;
215 }
216
217 //////////////////////////////////////////////////////////
218 //////////////////////////////////////////////////////////
219 //////////////////////////////////////////////////////////
220 /*
221 G4cout << "debug : 0002 : radius " << radius << std::endl;
222 G4cout << "debug : cameraDistance : " << cameraDistance << std::endl;
223 G4cout << "debug : fieldHalfAngle : " << fVP.GetFieldHalfAngle() << std::endl;
224 G4cout << "debug : zoomFactor : " << fVP.GetZoomFactor() << std::endl;
225 G4cout << "debug : up : " << up.x() << " " << up.y() << " " << up.z() << std::endl;
226 G4cout << "debug : targetPoint : " << targetPoint.x() << " " << targetPoint.y() << " " << targetPoint.z() << std::endl;
227 G4cout << "debug : cameraPosition : " << cameraPosition.x() << " " << cameraPosition.y() << " " << cameraPosition.z() << std::endl;
228 G4cout << "debug : camera : znear " << pnear << ", zfar " << pfar << std::endl;
229 */
230 //////////////////////////////////////////////////////////
231 /// create scene graph ///////////////////////////////////
232 //////////////////////////////////////////////////////////
233 // Set projection, then create the tools::sg camera node :
235 if (fVP.GetFieldHalfAngle() <= 0.) {
236 //G4cout << "debug : camera : ortho : top " << top << " bottom " << bottom << " top-bottom " << top-bottom << std::endl;
237 if((top-bottom)<=0) {
238 fSGViewer->set_clear_color(0.3,0.3,0.3,1);
239 G4cerr << "G4ToolsSGViewer::SetView : for ortho camera, (top-bottom)<=0." << G4endl;
240 return;
241 }
243 ortho_camera->height.value(float(top-bottom));
245 } else {
246 //G4cout << "debug : camera : perspec : heightAngle " << float(2*fVP.GetFieldHalfAngle()) << std::endl;
248 perspective_camera->height_angle.value(float(2*fVP.GetFieldHalfAngle()));
250 }
251
252 _camera->position.value
253 (tools::vec3f(float(cameraPosition.x()),
254 float(cameraPosition.y()),
255 float(cameraPosition.z())));
256 _camera->znear.value(float(pnear));
257 _camera->zfar.value(float(pfar));
258
259 _camera->look_at(dir,tools::vec3f(up.x(),up.y(),up.z())); //same logic as in G4OpenInventorViewer.
260
261 /*
262 const G4Vector3D& lightDirection = fVP.GetLightpointDirection();
263 G4cout << "debug : lightDirection : " << lightDirection.x() << " " << lightDirection.y() << " " << lightDirection.z() << std::endl;
264 const G4Vector3D& actualLightDirection = fVP.GetActualLightpointDirection();
265 G4cout << "debug : actualLightDirection : " << actualLightDirection.x() << " " << actualLightDirection.y() << " " << actualLightDirection.z() << std::endl;
266 */
267
268 CreateSG(_camera,fVP.GetActualLightpointDirection());
269
270 {G4Color background = fVP.GetBackgroundColour ();
271 fSGViewer->set_clear_color(float(background.GetRed()),float(background.GetGreen()),float(background.GetBlue()),1);}
272 }
void CreateSG(tools::sg::base_camera *a_camera, const G4Vector3D &a_light_dir)
G4VSceneHandler & fSceneHandler
Definition G4VViewer.hh:253

Referenced by G4ToolsSGViewer< tools::offscreen::session, tools::offscreen::sg_viewer >::mouse_move(), and G4ToolsSGViewer< tools::offscreen::session, tools::offscreen::sg_viewer >::wheel_rotate().

◆ ShowView()

template<class SG_SESSION, class SG_VIEWER>
virtual void G4ToolsSGViewer< SG_SESSION, SG_VIEWER >::ShowView ( void )
inlinevirtual

Reimplemented from G4VViewer.

Reimplemented in G4ToolsSGOffscreenViewer.

Definition at line 288 of file G4ToolsSGViewer.hh.

288{FinishView();}

◆ SwitchToMasterThread()

template<class SG_SESSION, class SG_VIEWER>
virtual void G4ToolsSGViewer< SG_SESSION, SG_VIEWER >::SwitchToMasterThread ( )
inlinevirtual

Reimplemented from G4VViewer.

Definition at line 301 of file G4ToolsSGViewer.hh.

301 {
303 // I have not figured out how to draw during a run.
304 //
305 // Setting fNeedKernelVisit=true causes scene deletion and a complete rebuild,
306 // including trajectories, hits, etc. from kept events.
307 //
308 // Clearly this is a limitation because even if you run 1000 events you only
309 // get those kept (default 100), and even worse, if end-if-event-action is
310 // "refresh", you only get one event (the last I think).
311 //
312 // Also, strictly, there is no need to rebuid run-duration models (detector),
313 // but a complete rebuild is the easiest way (already imeplemented).
314 //
315 // Only do this if there are end-of-event models (e.g., trajectories) that
316 // may require it.
317 if (fSceneHandler.GetScene() && fSceneHandler.GetScene()->GetEndOfEventModelList().size()) {
318 fNeedKernelVisit = true;
319 DrawView(); // Draw trajectories, etc., from kept events
320 }
321 }
322 }

◆ SwitchToVisSubThread()

template<class SG_SESSION, class SG_VIEWER>
virtual void G4ToolsSGViewer< SG_SESSION, SG_VIEWER >::SwitchToVisSubThread ( )
inlinevirtual

Reimplemented from G4VViewer.

Definition at line 299 of file G4ToolsSGViewer.hh.

299{}

◆ wheel_rotate()

template<class SG_SESSION, class SG_VIEWER>
virtual void G4ToolsSGViewer< SG_SESSION, SG_VIEWER >::wheel_rotate ( const tools::sg::wheel_rotate_event & a_event)
inlinevirtual

Definition at line 109 of file G4ToolsSGViewer.hh.

109 {
110 const G4double angleY = a_event.angle();
111 if (fVP.GetFieldHalfAngle() == 0.) { // Orthographic projection
112 const G4double scale = 500; // Empirically chosen
113 fVP.MultiplyZoomFactor(1.+angleY/scale);
114 } else { // Perspective projection
115 const G4double delta = fSceneHandler.GetExtent().GetExtentRadius()/200.; // Empirical
116 fVP.SetDolly(fVP.GetDolly()+angleY*delta);
117 }
118 SetView();
119 DrawView();
120 }

Member Data Documentation

◆ f_gl2ps_mgr

template<class SG_SESSION, class SG_VIEWER>
tools::sg::gl2ps_manager G4ToolsSGViewer< SG_SESSION, SG_VIEWER >::f_gl2ps_mgr
protected

Definition at line 542 of file G4ToolsSGViewer.hh.

◆ f_zb_mgr

template<class SG_SESSION, class SG_VIEWER>
tools::sg::zb_manager G4ToolsSGViewer< SG_SESSION, SG_VIEWER >::f_zb_mgr
protected

Definition at line 541 of file G4ToolsSGViewer.hh.

◆ fKeyPressed

template<class SG_SESSION, class SG_VIEWER>
G4bool G4ToolsSGViewer< SG_SESSION, SG_VIEWER >::fKeyPressed
protected

Definition at line 536 of file G4ToolsSGViewer.hh.

◆ fKeyShift

template<class SG_SESSION, class SG_VIEWER>
G4bool G4ToolsSGViewer< SG_SESSION, SG_VIEWER >::fKeyShift
protected

Definition at line 537 of file G4ToolsSGViewer.hh.

◆ fLastVP

template<class SG_SESSION, class SG_VIEWER>
G4ViewParameters G4ToolsSGViewer< SG_SESSION, SG_VIEWER >::fLastVP
protected

Definition at line 534 of file G4ToolsSGViewer.hh.

◆ fMousePressed

template<class SG_SESSION, class SG_VIEWER>
G4bool G4ToolsSGViewer< SG_SESSION, SG_VIEWER >::fMousePressed
protected

Definition at line 538 of file G4ToolsSGViewer.hh.

◆ fMousePressedX

template<class SG_SESSION, class SG_VIEWER>
G4double G4ToolsSGViewer< SG_SESSION, SG_VIEWER >::fMousePressedX
protected

Definition at line 539 of file G4ToolsSGViewer.hh.

◆ fMousePressedY

template<class SG_SESSION, class SG_VIEWER>
G4double G4ToolsSGViewer< SG_SESSION, SG_VIEWER >::fMousePressedY
protected

Definition at line 539 of file G4ToolsSGViewer.hh.

◆ fSGSceneHandler

template<class SG_SESSION, class SG_VIEWER>
G4ToolsSGSceneHandler& G4ToolsSGViewer< SG_SESSION, SG_VIEWER >::fSGSceneHandler
protected

Definition at line 532 of file G4ToolsSGViewer.hh.

◆ fSGSession

template<class SG_SESSION, class SG_VIEWER>
SG_SESSION& G4ToolsSGViewer< SG_SESSION, SG_VIEWER >::fSGSession
protected

Definition at line 531 of file G4ToolsSGViewer.hh.

◆ fSGViewer

template<class SG_SESSION, class SG_VIEWER>
SG_VIEWER* G4ToolsSGViewer< SG_SESSION, SG_VIEWER >::fSGViewer
protected

Definition at line 533 of file G4ToolsSGViewer.hh.


The documentation for this class was generated from the following file: