source: snovis/trunk/source/G4Lab/cxx/SoG4RunManager.cxx @ 233

Last change on this file since 233 was 233, checked in by barrand, 17 years ago
  • Property svn:eol-style set to native
File size: 2.3 KB
Line 
1
2// this :
3#include <G4Lab/SoG4RunManager.h>
4
5// Inventor :
6#include <Inventor/errors/SoDebugError.h>
7#include <Inventor/actions/SoGLRenderAction.h>
8#include <Inventor/bundles/SoMaterialBundle.h>
9
10// Geant4 :
11#include <G4RunManager.hh>
12#include <G4UserSteppingAction.hh>
13
14// GLab :
15#include <G4Lab/SteppingAction.h>
16
17SO_NODE_SOURCE(SoG4RunManager)
18//////////////////////////////////////////////////////////////////////////////
19void SoG4RunManager::initClass(
20)
21//////////////////////////////////////////////////////////////////////////////
22//!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!//
23{
24  SO_NODE_INIT_CLASS(SoG4RunManager,SoNode,"Node");
25}
26//////////////////////////////////////////////////////////////////////////////
27SoG4RunManager::SoG4RunManager(
28)
29//////////////////////////////////////////////////////////////////////////////
30//!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!//
31{
32  SO_NODE_CONSTRUCTOR(SoG4RunManager);
33  SO_NODE_ADD_FIELD(numberOfEvents,(1));
34}
35//////////////////////////////////////////////////////////////////////////////
36SoG4RunManager::~SoG4RunManager(
37)
38//////////////////////////////////////////////////////////////////////////////
39//!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!//
40{
41}
42//////////////////////////////////////////////////////////////////////////////
43void SoG4RunManager::GLRender (
44 SoGLRenderAction* aAction
45)
46//////////////////////////////////////////////////////////////////////////////
47//!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!//
48{
49  G4RunManager* runManager = G4RunManager::GetRunManager();
50  if(!runManager) return;
51
52  G4Lab::SteppingAction* g4LabSteppingAction = 0;
53
54  G4UserSteppingAction* steppingAction = 
55    (G4UserSteppingAction*)runManager->GetUserSteppingAction();
56  if(steppingAction) {
57    g4LabSteppingAction = dynamic_cast<G4Lab::SteppingAction*>(steppingAction);
58  }
59
60  if(g4LabSteppingAction) g4LabSteppingAction->enable();
61
62  // The G4Lab::SteppingAction::UserSteppingAction, that draw directly
63  // with OpenGL will be perform here.
64
65  //SoDebugError::postInfo("SoG4RunManager::GLRender","beamOn.");
66
67  SoMaterialBundle mb(aAction);
68  mb.sendFirst();
69
70  runManager->BeamOn(numberOfEvents.getValue());
71
72  if(g4LabSteppingAction) g4LabSteppingAction->disable();
73
74}
Note: See TracBrowser for help on using the repository browser.