Geant4 11.1.1
Toolkit for the simulation of the passage of particles through matter
Loading...
Searching...
No Matches
G4RayTracerSceneHandler.cc
Go to the documentation of this file.
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
29
30#include "G4VisManager.hh"
31
32#define G4warn G4cout
33
34G4int G4RayTracerSceneHandler::fSceneIdCount = 0;
35
37 const G4String& name)
38: G4VSceneHandler(system, fSceneIdCount++, name)
39{
40 // Keep vis manager happy when someone opens a ray tracer with "/vis/open
41 // RayTracer" but uses the ray tracer with "/vis/rayTracer" commands
42 // before creating any scenes, for example, instead of using
43 // "/vis/drawVolume"...
45 if(visManager) {
46 G4Scene* pScene = visManager->GetCurrentScene();
47 if (!pScene) {
48 // Create new scene like /vis/scene/create...
49 fpScene = new G4Scene("dummy-ray-tracer-scene");
50 // Add dummy run-duration model to avoid world being added and
51 // notifyHandler being invoked...
53 // Add to vis manager list; ownership thereby passes to vis manager...
54 visManager->SetSceneList().push_back(fpScene);
55 // ...and make current...
56 visManager->SetCurrentScene(fpScene);
57 }
58 }
59}
60
62{}
63
65{
66 fSceneVisAttsMap.clear();
67}
68
69G4bool G4RayTracerSceneHandler::PathLessThan::operator()
72{
73 if (a.size() != b.size()) return a.size() < b.size();
74 auto ia = a.begin();
75 auto ib = b.begin();
76 for (; ia != a.end(); ++ia, ++ib) {
77 if (ia->GetPVPointer() < ib->GetPVPointer()) return true;
78 if (ia->GetPVPointer() > ib->GetPVPointer()) return false;
79 // Pointers equal
80 if (ia->GetCopyNo() < ib->GetCopyNo()) return true;
81 if (ia->GetCopyNo() > ib->GetCopyNo()) return false;
82 // Both pointers and copy no are equal - continue
83 }
84 // Equality
85 return false;
86}
87
89{
90 // Build map of vis attributes
91
92 G4PhysicalVolumeModel* fpPVModel = dynamic_cast<G4PhysicalVolumeModel*>(fpModel);
93 if (fpPVModel) {
95 for (const auto& nodeID: fpPVModel->GetFullPVPath()) {
96 // Build an element from the nodeid.
97 temp.push_back(G4ModelingParameters::PVPointerCopyNo(nodeID.GetPhysicalVolume(),nodeID.GetCopyNo()));
98 }
99 const G4VisAttributes* pVisAtts = fpVisAttribs;
100 if (!pVisAtts) {
101 // Shouldn't happen.
103 G4warn <<
104 "WARNING: G4RayTracerSceneHandler::BuildVisAttsMap: null vis atts pointer."
105 "\n Using a default vis atts."
106 << G4endl;
107 }
108 static const G4VisAttributes defaultVisAtts;
109 pVisAtts = &defaultVisAtts;
110 }
111 // Copy vis atts into the vis atts map
112 fSceneVisAttsMap[temp] = *pVisAtts;
113 }
114}
115
#define G4warn
Definition: G4Scene.cc:41
bool G4bool
Definition: G4Types.hh:86
int G4int
Definition: G4Types.hh:85
#define G4endl
Definition: G4ios.hh:57
std::vector< PVPointerCopyNo > PVPointerCopyNoPath
const std::vector< G4PhysicalVolumeNodeID > & GetFullPVPath() const
void BuildVisAttsMap(const G4VSolid &solid)
G4RayTracerSceneHandler(G4VGraphicsSystem &system, const G4String &name="")
G4bool AddWorldIfEmpty(G4bool warn=false)
Definition: G4Scene.cc:124
const G4VisAttributes * fpVisAttribs
G4Scene * GetCurrentScene() const
void SetCurrentScene(G4Scene *)
G4SceneList & SetSceneList()
static Verbosity GetVerbosity()
static G4VisManager * GetInstance()