Geant4 11.3.0
Toolkit for the simulation of the passage of particles through matter
Loading...
Searching...
No Matches
G4ToolsSGSceneHandler Class Reference

#include <G4ToolsSGSceneHandler.hh>

+ Inheritance diagram for G4ToolsSGSceneHandler:

Classes

class  Messenger
 

Public Member Functions

virtual void AddPrimitive (const G4Polyline &)
 
virtual void AddPrimitive (const G4Text &)
 
virtual void AddPrimitive (const G4Circle &)
 
virtual void AddPrimitive (const G4Square &)
 
virtual void AddPrimitive (const G4Polymarker &)
 
virtual void AddPrimitive (const G4Polyhedron &)
 
virtual void AddPrimitive (const G4Plotter &)
 
virtual void AddCompound (const G4Mesh &)
 
virtual void ClearStore ()
 
virtual void ClearTransientStore ()
 
 G4ToolsSGSceneHandler (G4VGraphicsSystem &system, const G4String &name)
 
virtual ~G4ToolsSGSceneHandler ()
 
tools::sg::separator & GetTransient2DObjects ()
 
tools::sg::separator & GetPersistent2DObjects ()
 
tools::sg::separator & GetTransient3DObjects ()
 
tools::sg::separator & GetPersistent3DObjects ()
 
void TouchPlotters (tools::sg::node &)
 
virtual void AddCompound (const G4VTrajectory &)
 
virtual void AddCompound (const G4VHit &)
 
virtual void AddCompound (const G4VDigi &)
 
virtual void AddCompound (const G4THitsMap< G4double > &)
 
virtual void AddCompound (const G4THitsMap< G4StatDouble > &)
 
- Public Member Functions inherited from G4VSceneHandler
 G4VSceneHandler (G4VGraphicsSystem &system, G4int id, const G4String &name="")
 
virtual ~G4VSceneHandler ()
 
virtual void PreAddSolid (const G4Transform3D &objectTransformation, const G4VisAttributes &)
 
virtual void PostAddSolid ()
 
virtual void AddSolid (const G4Box &)
 
virtual void AddSolid (const G4Cons &)
 
virtual void AddSolid (const G4Orb &)
 
virtual void AddSolid (const G4Para &)
 
virtual void AddSolid (const G4Sphere &)
 
virtual void AddSolid (const G4Torus &)
 
virtual void AddSolid (const G4Trap &)
 
virtual void AddSolid (const G4Trd &)
 
virtual void AddSolid (const G4Tubs &)
 
virtual void AddSolid (const G4Ellipsoid &)
 
virtual void AddSolid (const G4Polycone &)
 
virtual void AddSolid (const G4Polyhedra &)
 
virtual void AddSolid (const G4TessellatedSolid &)
 
virtual void AddSolid (const G4VSolid &)
 
virtual void BeginModeling ()
 
virtual void EndModeling ()
 
virtual void BeginPrimitives (const G4Transform3D &objectTransformation=G4Transform3D())
 
virtual void EndPrimitives ()
 
virtual void BeginPrimitives2D (const G4Transform3D &objectTransformation=G4Transform3D())
 
virtual void EndPrimitives2D ()
 
virtual const G4VisExtentGetExtent () const
 
const G4StringGetName () const
 
G4int GetSceneHandlerId () const
 
G4int GetViewCount () const
 
G4VGraphicsSystemGetGraphicsSystem () const
 
G4SceneGetScene () const
 
const G4ViewerListGetViewerList () const
 
G4VModelGetModel () const
 
G4VViewerGetCurrentViewer () const
 
G4bool GetMarkForClearingTransientStore () const
 
G4bool IsReadyForTransients () const
 
G4bool GetTransientsDrawnThisEvent () const
 
G4bool GetTransientsDrawnThisRun () const
 
const G4Transform3DGetObjectTransformation () const
 
void SetName (const G4String &)
 
void SetCurrentViewer (G4VViewer *)
 
virtual void SetScene (G4Scene *)
 
G4ViewerListSetViewerList ()
 
void SetModel (G4VModel *)
 
void SetMarkForClearingTransientStore (G4bool)
 
void SetTransientsDrawnThisEvent (G4bool)
 
void SetTransientsDrawnThisRun (G4bool)
 
void SetObjectTransformation (const G4Transform3D &)
 
const G4ColourGetColour ()
 
const G4ColourGetColor ()
 
const G4ColourGetColour (const G4Visible &)
 
const G4ColourGetColor (const G4Visible &)
 
const G4ColourGetTextColour (const G4Text &)
 
const G4ColourGetTextColor (const G4Text &)
 
G4double GetLineWidth (const G4VisAttributes *)
 
G4ViewParameters::DrawingStyle GetDrawingStyle (const G4VisAttributes *)
 
G4int GetNumberOfCloudPoints (const G4VisAttributes *) const
 
G4bool GetAuxEdgeVisible (const G4VisAttributes *)
 
G4int GetNoOfSides (const G4VisAttributes *)
 
G4double GetMarkerSize (const G4VMarker &, MarkerSizeType &)
 
G4double GetMarkerDiameter (const G4VMarker &, MarkerSizeType &)
 
G4double GetMarkerRadius (const G4VMarker &, MarkerSizeType &)
 
G4ModelingParametersCreateModelingParameters ()
 
void DrawEvent (const G4Event *)
 
void DrawEndOfRunModels ()
 
template<class T>
void AddSolidT (const T &solid)
 
template<class T>
void AddSolidWithAuxiliaryEdges (const T &solid)
 
G4int IncrementViewCount ()
 
void AddViewerToList (G4VViewer *pView)
 
void RemoveViewerFromList (G4VViewer *pView)
 
- Public Member Functions inherited from G4VGraphicsScene
 G4VGraphicsScene ()
 
virtual ~G4VGraphicsScene ()
 

Protected Types

using Region_h1 = std::pair<unsigned int,int>
 
using Region_h2 = std::pair<unsigned int,int>
 

Protected Member Functions

 G4ToolsSGSceneHandler (const G4ToolsSGSceneHandler &)
 
G4ToolsSGSceneHandleroperator= (const G4ToolsSGSceneHandler &)
 
void CreateSG ()
 
void EstablishBaseNodes ()
 
tools::sg::separator * GetOrCreateNode ()
 
void SetPlotterHistograms (tools::sg::plots &)
 
- Protected Member Functions inherited from G4VSceneHandler
virtual void ProcessScene ()
 
virtual void RequestPrimitives (const G4VSolid &solid)
 
virtual G4DisplacedSolidCreateSectionSolid ()
 
virtual G4DisplacedSolidCreateCutawaySolid ()
 
void LoadAtts (const G4Visible &, G4AttHolder *)
 
void StandardSpecialMeshRendering (const G4Mesh &)
 
void Draw3DRectMeshAsDots (const G4Mesh &)
 
void Draw3DRectMeshAsSurfaces (const G4Mesh &)
 
void DrawTetMeshAsDots (const G4Mesh &)
 
void DrawTetMeshAsSurfaces (const G4Mesh &)
 
G4ThreeVector GetPointInBox (const G4ThreeVector &pos, G4double halfX, G4double halfY, G4double halfZ) const
 
G4ThreeVector GetPointInTet (const std::vector< G4ThreeVector > &vertices) const
 

Protected Attributes

tools::sg::separator fpTransient2DObjects
 
tools::sg::separator fpPersistent2DObjects
 
tools::sg::separator fpTransient3DObjects
 
tools::sg::separator fpPersistent3DObjects
 
std::vector< G4ToolsSGNode * > fpPhysicalVolumeObjects
 
tools::sg::base_freetype * fFreetypeNode
 
std::vector< Region_h1fRegionH1s
 
std::vector< Region_h2fRegionH2s
 
- Protected Attributes inherited from G4VSceneHandler
G4VGraphicsSystemfSystem
 
const G4int fSceneHandlerId
 
G4String fName
 
G4int fViewCount
 
G4ViewerList fViewerList
 
G4VViewerfpViewer
 
G4ScenefpScene
 
G4bool fMarkForClearingTransientStore
 
G4bool fReadyForTransients
 
G4bool fTransientsDrawnThisEvent
 
G4bool fTransientsDrawnThisRun
 
G4bool fProcessingSolid
 
G4bool fProcessing2D
 
G4VModelfpModel
 
G4Transform3D fObjectTransformation
 
G4int fNestingDepth
 
const G4VisAttributesfpVisAttribs
 
const G4Transform3D fIdentityTransformation
 
std::map< G4VPhysicalVolume *, G4StringfProblematicVolumes
 

Static Protected Attributes

static G4int fSceneIdCount = 0
 

Additional Inherited Members

- Public Types inherited from G4VSceneHandler
enum  MarkerSizeType { world , screen }
 

Detailed Description

Definition at line 44 of file G4ToolsSGSceneHandler.hh.

Member Typedef Documentation

◆ Region_h1

using G4ToolsSGSceneHandler::Region_h1 = std::pair<unsigned int,int>
protected

Definition at line 94 of file G4ToolsSGSceneHandler.hh.

◆ Region_h2

using G4ToolsSGSceneHandler::Region_h2 = std::pair<unsigned int,int>
protected

Definition at line 95 of file G4ToolsSGSceneHandler.hh.

Constructor & Destructor Documentation

◆ G4ToolsSGSceneHandler() [1/2]

G4ToolsSGSceneHandler::G4ToolsSGSceneHandler ( G4VGraphicsSystem & system,
const G4String & name )

Definition at line 76 of file G4ToolsSGSceneHandler.cc.

78:parent(system, fSceneIdCount++, name)
80{
81 //::printf("debug : G4ToolsSGSceneHandler : %lu, %s\n",this,name.c_str());
83#if defined(TOOLS_USE_FREETYPE)
84 fFreetypeNode = new toolx::sg::text_freetype();
85 fFreetypeNode->add_embedded_font(tools::sg::font_lato_regular_ttf(),tools::font::lato_regular_ttf);
86 fFreetypeNode->add_embedded_font(tools::sg::font_roboto_bold_ttf(),tools::font::roboto_bold_ttf);
87#else
88 fFreetypeNode = new tools::sg::dummy_freetype();
89#endif
91}
tools::sg::base_freetype * fFreetypeNode

Referenced by G4ToolsSGSceneHandler(), operator=(), and G4ToolsSGSceneHandler::Messenger::SetNewValue().

◆ ~G4ToolsSGSceneHandler()

G4ToolsSGSceneHandler::~G4ToolsSGSceneHandler ( )
virtual

Definition at line 93 of file G4ToolsSGSceneHandler.cc.

94{
95 //::printf("debug : ~G4ToolsSGSceneHandler : %lu\n",this);
96 //WARNING : nodes may refer graphics managers (as tools/sg/[GL_manager,gl2ps_manager,zb_manager]
97 // used by viewers) to handle gstos (for GPU) or textures, then we have to delete them first.
98 // It is assumed that we pass here BEFORE the attached/managed viewers are deleted.
100 fpPersistent2DObjects.clear();
101 fpTransient3DObjects.clear();
102 fpPersistent3DObjects.clear();
103 delete fFreetypeNode;
104}
tools::sg::separator fpPersistent2DObjects
tools::sg::separator fpTransient3DObjects
tools::sg::separator fpTransient2DObjects
tools::sg::separator fpPersistent3DObjects

◆ G4ToolsSGSceneHandler() [2/2]

G4ToolsSGSceneHandler::G4ToolsSGSceneHandler ( const G4ToolsSGSceneHandler & )
protected

Member Function Documentation

◆ AddCompound() [1/6]

void G4ToolsSGSceneHandler::AddCompound ( const G4Mesh & mesh)
virtual

Reimplemented from G4VSceneHandler.

Definition at line 584 of file G4ToolsSGSceneHandler.cc.

585{
587}
void StandardSpecialMeshRendering(const G4Mesh &)

◆ AddCompound() [2/6]

void G4VSceneHandler::AddCompound ( const G4THitsMap< G4double > & hits)
virtual

Reimplemented from G4VSceneHandler.

Definition at line 133 of file G4VSceneHandler.cc.

345 {
346 using MeshScoreMap = G4VScoringMesh::MeshScoreMap;
347 //G4cout << "AddCompound: hits: " << &hits << G4endl;
348 G4bool scoreMapHits = false;
349 G4ScoringManager* scoringManager = G4ScoringManager::GetScoringManagerIfExist();
350 if (scoringManager) {
351 std::size_t nMeshes = scoringManager->GetNumberOfMesh();
352 for (std::size_t iMesh = 0; iMesh < nMeshes; ++iMesh) {
353 G4VScoringMesh* mesh = scoringManager->GetMesh((G4int)iMesh);
354 if (mesh && mesh->IsActive()) {
355 MeshScoreMap scoreMap = mesh->GetScoreMap();
356 const G4String& mapNam = const_cast<G4THitsMap<G4double>&>(hits).GetName();
357 for(MeshScoreMap::const_iterator i = scoreMap.cbegin();
358 i != scoreMap.cend(); ++i) {
359 const G4String& scoreMapName = i->first;
360 if (scoreMapName == mapNam) {
361 G4DefaultLinearColorMap colorMap("G4VSceneHandlerColorMap");
362 scoreMapHits = true;
363 mesh->DrawMesh(scoreMapName, &colorMap);
364 }
365 }
366 }
367 }
368 }
369 if (scoreMapHits) {
370 static G4bool first = true;
371 if (first) {
372 first = false;
373 G4cout <<
374 "Scoring map drawn with default parameters."
375 "\n To get gMocren file for gMocren browser:"
376 "\n /vis/open gMocrenFile"
377 "\n /vis/viewer/flush"
378 "\n Many other options available with /score/draw... commands."
379 "\n You might want to \"/vis/viewer/set/autoRefresh false\"."
380 << G4endl;
381 }
382 } else { // Not score map hits. Just call DrawAllHits.
383 // Cast away const because DrawAllHits is non-const!!!!
384 const_cast<G4THitsMap<G4double>&>(hits).DrawAllHits();
385 }
386}
bool G4bool
Definition G4Types.hh:86
int G4int
Definition G4Types.hh:85
#define G4endl
Definition G4ios.hh:67
G4GLOB_DLL std::ostream G4cout
G4VScoringMesh * GetMesh(G4int i) const
std::size_t GetNumberOfMesh() const
static G4ScoringManager * GetScoringManagerIfExist()
const G4String & GetName() const
G4bool IsActive() const
std::map< G4String, RunScore * > MeshScoreMap
void DrawMesh(const G4String &psName, G4VScoreColorMap *colorMap, G4int axflg=111)
MeshScoreMap GetScoreMap() const

◆ AddCompound() [3/6]

void G4VSceneHandler::AddCompound ( const G4THitsMap< G4StatDouble > & hits)
virtual

Reimplemented from G4VSceneHandler.

Definition at line 134 of file G4VSceneHandler.cc.

388 {
389 using MeshScoreMap = G4VScoringMesh::MeshScoreMap;
390 //G4cout << "AddCompound: hits: " << &hits << G4endl;
391 G4bool scoreMapHits = false;
392 G4ScoringManager* scoringManager = G4ScoringManager::GetScoringManagerIfExist();
393 if (scoringManager) {
394 std::size_t nMeshes = scoringManager->GetNumberOfMesh();
395 for (std::size_t iMesh = 0; iMesh < nMeshes; ++iMesh) {
396 G4VScoringMesh* mesh = scoringManager->GetMesh((G4int)iMesh);
397 if (mesh && mesh->IsActive()) {
398 MeshScoreMap scoreMap = mesh->GetScoreMap();
399 for(MeshScoreMap::const_iterator i = scoreMap.cbegin();
400 i != scoreMap.cend(); ++i) {
401 const G4String& scoreMapName = i->first;
402 const G4THitsMap<G4StatDouble>* foundHits = i->second;
403 if (foundHits == &hits) {
404 G4DefaultLinearColorMap colorMap("G4VSceneHandlerColorMap");
405 scoreMapHits = true;
406 mesh->DrawMesh(scoreMapName, &colorMap);
407 }
408 }
409 }
410 }
411 }
412 if (scoreMapHits) {
413 static G4bool first = true;
414 if (first) {
415 first = false;
416 G4cout <<
417 "Scoring map drawn with default parameters."
418 "\n To get gMocren file for gMocren browser:"
419 "\n /vis/open gMocrenFile"
420 "\n /vis/viewer/flush"
421 "\n Many other options available with /score/draw... commands."
422 "\n You might want to \"/vis/viewer/set/autoRefresh false\"."
423 << G4endl;
424 }
425 } else { // Not score map hits. Just call DrawAllHits.
426 // Cast away const because DrawAllHits is non-const!!!!
427 const_cast<G4THitsMap<G4StatDouble>&>(hits).DrawAllHits();
428 }
429}

◆ AddCompound() [4/6]

void G4VSceneHandler::AddCompound ( const G4VDigi & digi)
virtual

Reimplemented from G4VSceneHandler.

Definition at line 132 of file G4VSceneHandler.cc.

340 {
341 // Cast away const because Draw is non-const!!!!
342 const_cast<G4VDigi&>(digi).Draw();
343}

◆ AddCompound() [5/6]

void G4VSceneHandler::AddCompound ( const G4VHit & hit)
virtual

Reimplemented from G4VSceneHandler.

Definition at line 131 of file G4VSceneHandler.cc.

335 {
336 // Cast away const because Draw is non-const!!!!
337 const_cast<G4VHit&>(hit).Draw();
338}

◆ AddCompound() [6/6]

void G4VSceneHandler::AddCompound ( const G4VTrajectory & traj)
virtual

Reimplemented from G4VSceneHandler.

Definition at line 130 of file G4VSceneHandler.cc.

323 {
324 G4TrajectoriesModel* trajectoriesModel =
325 dynamic_cast<G4TrajectoriesModel*>(fpModel);
326 if (trajectoriesModel)
327 traj.DrawTrajectory();
328 else {
330 ("G4VSceneHandler::AddCompound(const G4VTrajectory&)",
331 "visman0105", FatalException, "Not a G4TrajectoriesModel.");
332 }
333}
@ FatalException
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *description)
virtual void DrawTrajectory() const

◆ AddPrimitive() [1/7]

void G4ToolsSGSceneHandler::AddPrimitive ( const G4Circle & a_circle)
virtual

Implements G4VSceneHandler.

Definition at line 413 of file G4ToolsSGSceneHandler.cc.

414{
415 G4Polymarker oneCircle(a_circle);
416 oneCircle.push_back(a_circle.GetPosition());
417 oneCircle.SetMarkerType(G4Polymarker::circles);
418 // Call this AddPrimitive to avoid re-doing sub-class code.
420}
virtual void AddPrimitive(const G4Polyline &)
G4Point3D GetPosition() const

◆ AddPrimitive() [2/7]

void G4ToolsSGSceneHandler::AddPrimitive ( const G4Plotter & a_plotter)
virtual

Reimplemented from G4VSceneHandler.

Definition at line 813 of file G4ToolsSGSceneHandler.cc.

814{
815//G4cout << "debug : G4ToolsSGSceneHandler::AddPrimitive : 004" << std::endl;
816 if(!fpViewer) return;
817
818 auto currentNode = GetOrCreateNode();
819 if (!currentNode) return; // Node not available
820
821 currentNode->add(new tools::sg::light_off());
822
823 tools::sg::plots* _plots = new tools::sg::plots(*fFreetypeNode);
824 currentNode->add(_plots);
825
826 _plots->view_border = false;
827 _plots->set_regions(a_plotter.GetColumns(),a_plotter.GetRows());
828
829 {tools::sg::event_dispatcher* dpt = new tools::sg::event_dispatcher;
830 dpt->add_callback(new plots_cbk(*_plots));
831 currentNode->add(dpt);}
832
833 SetPlotterStyles(*_plots,a_plotter.GetStyles(),a_plotter.GetRegionStyles());
834
835 tools::sg::cmaps_t _cmaps;
836 _cmaps["default"] = tools::sg::style_default_colormap();
837 _cmaps["ROOT"] = tools::sg::style_ROOT_colormap();
838
839 SetPlotterParameters(_cmaps,*_plots,a_plotter.GetRegionParameters());
840
841 fRegionH1s = a_plotter.GetRegionH1s();
842 fRegionH2s = a_plotter.GetRegionH2s();
843
844 SetPlotterHistograms(*_plots);
845}
void SetPlotterParameters(tools::sg::cmaps_t &a_cmaps, tools::sg::plots &a_plots, const std::vector< G4Plotter::RegionParameter > &a_region_parameters)
void SetPlotterStyles(tools::sg::plots &a_plots, const std::vector< G4String > &a_plotter_styles, const std::vector< G4Plotter::RegionStyle > &a_region_styles)
unsigned int GetRows() const
Definition G4Plotter.hh:68
const std::vector< RegionParameter > & GetRegionParameters() const
Definition G4Plotter.hh:71
const std::vector< G4String > & GetStyles() const
Definition G4Plotter.hh:69
const std::vector< Region_h2 > & GetRegionH2s() const
Definition G4Plotter.hh:76
const std::vector< RegionStyle > & GetRegionStyles() const
Definition G4Plotter.hh:70
const std::vector< Region_h1 > & GetRegionH1s() const
Definition G4Plotter.hh:75
unsigned int GetColumns() const
Definition G4Plotter.hh:67
void SetPlotterHistograms(tools::sg::plots &)
std::vector< Region_h1 > fRegionH1s
tools::sg::separator * GetOrCreateNode()
std::vector< Region_h2 > fRegionH2s

◆ AddPrimitive() [3/7]

void G4ToolsSGSceneHandler::AddPrimitive ( const G4Polyhedron & a_polyhedron)
virtual

Implements G4VSceneHandler.

Definition at line 431 of file G4ToolsSGSceneHandler.cc.

432{
433 if (a_polyhedron.GetNoFacets() == 0) return;
434
435 //::printf("debug : G4ToolsSGSceneHandler::AddPrimitive(const G4Polyhedron&) : %d\n",a_polyhedron.GetNoFacets());
436
437 fpVisAttribs = fpViewer->GetApplicableVisAttributes(a_polyhedron.GetVisAttributes());
438
439 // Roll out vertices and normals for the faces. Note that this means vertices
440 // are duplicated. For example a box has 8 vertices, but to define 6 faces
441 // you need 12 triangles and 36 vertices. If it was just a matter of vertices
442 // we could restrict the number to 8 and use the indices to define the
443 // triangles, but we also have to consider the normals. A vertex can be have
444 // more than one normal, depending on which face it is being used to define.
445 // So we roll out all the vertices and normals for each triangle.
446 std::vector<G4Point3D> vertices;
447 std::vector<G4Normal3D> normals;
448
449 // Also roll out edges (as lines) for wireframe. Avoid duplicate lines,
450 // including those that differ only in the order of vertices.
451 typedef std::pair<G4Point3D,G4Point3D> Line;
452 std::vector<Line> lines;
453 auto insertIfNew = [&lines](const Line& newLine) {
454// for (const auto& line: lines) {
455// if ((newLine.first==line.first && newLine.second==line.second) ||
456// (newLine.first==line.second && newLine.second==line.first))
457// return;
458// }
459 lines.push_back(newLine);
460 };
461
462 G4bool isAuxilaryEdgeVisible = fpViewer->GetViewParameters().IsAuxEdgeVisible();
463 G4bool notLastFace;
464 do {
465 G4int nEdges;
466 G4Point3D vertex [4];
467 G4int edgeFlag[4];
468 G4Normal3D normal [4];
469 notLastFace = a_polyhedron.GetNextFacet(nEdges, vertex, edgeFlag, normal);
470 vertices.push_back(vertex[0]);
471 vertices.push_back(vertex[1]);
472 vertices.push_back(vertex[2]);
473 normals.push_back(normal[0]);
474 normals.push_back(normal[1]);
475 normals.push_back(normal[2]);
476 if(isAuxilaryEdgeVisible||edgeFlag[0]>0)insertIfNew(Line(vertex[0],vertex[1]));
477 if(isAuxilaryEdgeVisible||edgeFlag[1]>0)insertIfNew(Line(vertex[1],vertex[2]));
478 if (nEdges == 3) {
479 // Face is a triangle
480 // One more line for wireframe, triangles for surfaces are complete
481 if(isAuxilaryEdgeVisible||edgeFlag[2]>0)insertIfNew(Line(vertex[2],vertex[0]));
482 } else if (nEdges == 4) {
483 // Face is a quadrilateral
484 // Create another triangle for surfaces, add two more lines for wireframe
485 vertices.push_back(vertex[2]);
486 vertices.push_back(vertex[3]);
487 vertices.push_back(vertex[0]);
488 normals.push_back(normal[2]);
489 normals.push_back(normal[3]);
490 normals.push_back(normal[0]);
491 if(isAuxilaryEdgeVisible||edgeFlag[2]>0)insertIfNew(Line(vertex[2],vertex[3]));
492 if(isAuxilaryEdgeVisible||edgeFlag[3]>0)insertIfNew(Line(vertex[3],vertex[0]));
493 } else {
494 G4cerr
495 << "ERROR: polyhedron face with unexpected number of edges (" << nEdges << ')'
496 << "\n Tag: " << fpModel->GetCurrentTag()
497 << G4endl;
498 return;
499 }
500 } while (notLastFace);
501
503 switch (drawing_style) {
505 //vertices.clear();
506 break;
508 break;
510 //lines.clear();
511 break;
513 break;
515 // Shouldn't happen in this function (it's a polyhedron!) - ignore
516 return;
517 }
518
519 auto currentNode = GetOrCreateNode();
520 if (!currentNode) return; // Node not available
521
522 tools::sg::separator* sep = new tools::sg::separator;
523 currentNode->add(sep);
524
525 // Transformation
526 {tools::sg::matrix* mtx = new tools::sg::matrix;
528 mtx->mtx.value().set_matrix(elem(0,0),elem(0,1),elem(0,2),elem(0,3),
529 elem(1,0),elem(1,1),elem(1,2),elem(1,3),
530 elem(2,0),elem(2,1),elem(2,2),elem(2,3),
531 0, 0, 0, 1);
532 sep->add(mtx);}
533
534 {const auto& colour = GetColour(a_polyhedron);
535 tools::sg::rgba* mat = new tools::sg::rgba();
536 mat->color =
537 tools::colorf(float(colour.GetRed()),
538 float(colour.GetGreen()),
539 float(colour.GetBlue()),
540 float(colour.GetAlpha()));
541 sep->add(mat);}
542
543 if (drawing_style == G4ViewParameters::hlr ||
544 drawing_style == G4ViewParameters::hsr ||
545 drawing_style == G4ViewParameters::hlhsr) {
546
547 {tools::sg::draw_style* ds = new tools::sg::draw_style;
548 ds->style = tools::sg::draw_filled;
549 //ds->cull_face = true;
550 sep->add(ds);}
551
552 tools::sg::atb_vertices* vtxs = new tools::sg::atb_vertices;
553 vtxs->mode = tools::gl::triangles();
554 sep->add(vtxs);
555
556 const auto nVerts = vertices.size();
557 for (size_t i = 0; i < nVerts; i++) {
558 vtxs->add(float(vertices[i].x()),float(vertices[i].y()),float(vertices[i].z()));
559 vtxs->add_normal(float(normals[i].x()),float(normals[i].y()),float(normals[i].z()));
560 }
561 }
562
563 if (drawing_style == G4ViewParameters::wireframe ||
564 drawing_style == G4ViewParameters::hlr ||
565 drawing_style == G4ViewParameters::hlhsr) {
566
567 {tools::sg::draw_style* ds = new tools::sg::draw_style;
568 ds->style = tools::sg::draw_lines;
569 ds->line_width = 1;
570 sep->add(ds);}
571
572 tools::sg::vertices* vtxs = new tools::sg::vertices;
573 vtxs->mode = tools::gl::lines(); //segments
574 sep->add(vtxs);
575
576 for (const auto& line: lines) {
577 vtxs->add(float(line.first.x()),float(line.first.y()),float(line.first.z()));
578 vtxs->add(float(line.second.x()),float(line.second.y()),float(line.second.z()));
579 }
580
581 }
582}
HepGeom::Normal3D< G4double > G4Normal3D
Definition G4Normal3D.hh:34
#define elem(i, j)
HepGeom::Point3D< G4double > G4Point3D
Definition G4Point3D.hh:34
HepGeom::Transform3D G4Transform3D
G4GLOB_DLL std::ostream G4cerr
const G4Colour & GetColour()
G4Transform3D fObjectTransformation
const G4VisAttributes * fpVisAttribs
G4ViewParameters::DrawingStyle GetDrawingStyle(const G4VisAttributes *)
const G4VisAttributes * GetVisAttributes() const
G4int GetNoFacets() const
G4bool GetNextFacet(G4int &n, G4Point3D *nodes, G4int *edgeFlags=nullptr, G4Normal3D *normals=nullptr) const

◆ AddPrimitive() [4/7]

void G4ToolsSGSceneHandler::AddPrimitive ( const G4Polyline & a_polyline)
virtual

Implements G4VSceneHandler.

Definition at line 211 of file G4ToolsSGSceneHandler.cc.

212{
213 //G4cout << "debug : G4ToolsSGSceneHandler::AddPrimitive(const G4Polyline&) : \n" << a_polyline << G4endl;
214 if (a_polyline.size() == 0) return;
215
216 tools::sg::separator* parentNode = 0;
217 if(fProcessing2D) {
218 parentNode = new tools::sg::separator;
220 fpTransient2DObjects.add(parentNode);
221 } else {
222 fpPersistent2DObjects.add(parentNode);
223 }
224
225 } else {
226 parentNode = GetOrCreateNode();
227 if(!parentNode) return;
228
229 tools::sg::matrix* mtx = new tools::sg::matrix;
231 mtx->mtx.value().set_matrix(elem(0,0),elem(0,1),elem(0,2),elem(0,3),
232 elem(1,0),elem(1,1),elem(1,2),elem(1,3),
233 elem(2,0),elem(2,1),elem(2,2),elem(2,3),
234 0, 0, 0, 1);
235 parentNode->add(mtx);
236 }
237
238 {const auto& colour = GetColour(a_polyline);
239 tools::sg::rgba* mat = new tools::sg::rgba();
240 mat->color =
241 tools::colorf(float(colour.GetRed()),
242 float(colour.GetGreen()),
243 float(colour.GetBlue()),
244 float(colour.GetAlpha()));
245 parentNode->add(mat);}
246
247 {tools::sg::draw_style* ds = new tools::sg::draw_style;
248 ds->style = tools::sg::draw_lines;
249 ds->line_width = 1;
250 parentNode->add(ds);}
251
252 tools::sg::vertices* vtxs = new tools::sg::vertices;
253 vtxs->mode = tools::gl::line_strip(); //polyline
254 parentNode->add(vtxs);
255
256 {for (size_t i = 0; i < a_polyline.size(); ++i) {
257 vtxs->add(float(a_polyline[i].x()),float(a_polyline[i].y()),float(a_polyline[i].z()));
258 }}
259
260}

Referenced by AddPrimitive(), and AddPrimitive().

◆ AddPrimitive() [5/7]

void G4ToolsSGSceneHandler::AddPrimitive ( const G4Polymarker & a_polymarker)
virtual

Reimplemented from G4VSceneHandler.

Definition at line 262 of file G4ToolsSGSceneHandler.cc.

263{
264 //::printf("debug G4ToolsSGSceneHandler::AddPrimitive(const G4Polymarker&) : %lu, type %d\n",
265 // a_polymarker.size(),a_polymarker.GetMarkerType());
266 if (a_polymarker.size() == 0) return;
267 auto currentNode = GetOrCreateNode();
268 if (!currentNode) return; // Node not available
269
270 // Transformation
271 {tools::sg::matrix* mtx = new tools::sg::matrix;
273 mtx->mtx.value().set_matrix(elem(0,0),elem(0,1),elem(0,2),elem(0,3),
274 elem(1,0),elem(1,1),elem(1,2),elem(1,3),
275 elem(2,0),elem(2,1),elem(2,2),elem(2,3),
276 0, 0, 0, 1);
277 currentNode->add(mtx);}
278
279 {const auto& colour = GetColour(a_polymarker);
280 tools::sg::rgba* mat = new tools::sg::rgba();
281 mat->color =
282 tools::colorf(float(colour.GetRed()),
283 float(colour.GetGreen()),
284 float(colour.GetBlue()),
285 float(colour.GetAlpha()));
286 currentNode->add(mat);}
287
288 MarkerSizeType markerSizeType;
289 G4double markerSize = GetMarkerSize(a_polymarker, markerSizeType);
290
291 switch (a_polymarker.GetMarkerType()) {
292 default:
293 case G4Polymarker::dots:{
294 //::printf("debug : GB : Add Markers : +++++++++++++++++++++++++++++++++++++++++++ : dots\n");
295 tools::sg::draw_style* ds = new tools::sg::draw_style;
296 ds->style = tools::sg::draw_points;
297 ds->point_size = 1;
298 currentNode->add(ds);
299 tools::sg::vertices* vtxs = new tools::sg::vertices;
300 vtxs->mode = tools::gl::points();
301 {for (size_t i = 0; i < a_polymarker.size(); ++i) {
302 vtxs->add(float(a_polymarker[i].x()),float(a_polymarker[i].y()),float(a_polymarker[i].z()));
303 }}
304 currentNode->add(vtxs);
305 }break;
307 //::printf("debug : GB : Add Markers : +++++++++++++++++++++++++++++++++++++++++++ : circles\n");
308 {tools::sg::markers* markers = new tools::sg::markers;
309 G4double diameter = markerSize; // OK for "screen-size" (the usual case)
310 if (markerSizeType == G4VSceneHandler::world ) {
311 const G4double scale = 200.; // Roughly pixels per scene
312 diameter *= fpScene->GetExtent().GetExtentRadius()/scale;
313 }
314 markers->size = diameter;
315 markers->style = tools::sg::marker_circle_line;
316 for (size_t i = 0; i < a_polymarker.size(); ++i) {
317 markers->add(float(a_polymarker[i].x()),float(a_polymarker[i].y()),float(a_polymarker[i].z()));
318 }
319 currentNode->add(markers);}
320 }break;
322 //::printf("debug : GB : Add Markers : +++++++++++++++++++++++++++++++++++++++++++ : square\n");
323 {tools::sg::markers* markers = new tools::sg::markers;
324 G4double side = markerSize; // OK for "screen-size" (the usual case)
325 if (markerSizeType == G4VSceneHandler::world ) {
326 const G4double scale = 200.; // Roughly pixels per scene
327 side *= fpScene->GetExtent().GetExtentRadius()/scale;
328 }
329 markers->size = side;
330 markers->style = tools::sg::marker_square_line;
331 for (size_t i = 0; i < a_polymarker.size(); ++i) {
332 markers->add(float(a_polymarker[i].x()),float(a_polymarker[i].y()),float(a_polymarker[i].z()));
333 }
334 currentNode->add(markers);}
335 }break;
336 }
337}
double G4double
Definition G4Types.hh:83
MarkerType GetMarkerType() const
G4double GetMarkerSize(const G4VMarker &, MarkerSizeType &)

◆ AddPrimitive() [6/7]

void G4ToolsSGSceneHandler::AddPrimitive ( const G4Square & a_square)
virtual

Implements G4VSceneHandler.

Definition at line 422 of file G4ToolsSGSceneHandler.cc.

423{
424 G4Polymarker oneSquare(a_square);
425 oneSquare.push_back(a_square.GetPosition());
426 oneSquare.SetMarkerType(G4Polymarker::squares);
427 // Call this AddPrimitive to avoid re-doing sub-class code.
429}

◆ AddPrimitive() [7/7]

void G4ToolsSGSceneHandler::AddPrimitive ( const G4Text & a_text)
virtual

Implements G4VSceneHandler.

Definition at line 339 of file G4ToolsSGSceneHandler.cc.

340{
341 //::printf("debug : G4ToolsSGSceneHandler::AddPrimitive(const G4Text&) : 000 : \"%s\"\n",a_text.GetText().c_str());
342 //::printf("debug : G4ToolsSGSceneHandler::AddPrimitive(const G4Text&) : 2D ? %d\n",fProcessing2D);
343 auto pos = a_text.GetPosition();
344 //::printf("debug : Add Text : pos %g %g %g\n",pos.x(),pos.y(),pos.z());
345
346 tools::sg::separator* parentNode = 0;
347 if(fProcessing2D) {
348 parentNode = new tools::sg::separator;
350 fpTransient2DObjects.add(parentNode);
351 } else {
352 fpPersistent2DObjects.add(parentNode);
353 }
354
355 tools::sg::matrix* mtx = new tools::sg::matrix;
356 mtx->set_translate(pos.x(),pos.y(),pos.z());
357 parentNode->add(mtx);
358
359 } else {
360 parentNode = GetOrCreateNode();
361 if (!parentNode) return;
362
363 tools::sg::matrix* mtx = new tools::sg::matrix;
365 mtx->mtx.value().set_matrix(elem(0,0),elem(0,1),elem(0,2),elem(0,3),
366 elem(1,0),elem(1,1),elem(1,2),elem(1,3),
367 elem(2,0),elem(2,1),elem(2,2),elem(2,3),
368 0, 0, 0, 1);
369 parentNode->add(mtx);
370 }
371
372 MarkerSizeType sizeType;
373 G4double size = GetMarkerSize(a_text, sizeType);
374
375 {const auto& colour = GetTextColour(a_text);
376 tools::sg::rgba* mat = new tools::sg::rgba();
377 mat->color =
378 tools::colorf(float(colour.GetRed()),
379 float(colour.GetGreen()),
380 float(colour.GetBlue()),
381 float(colour.GetAlpha()));
382 parentNode->add(mat);}
383
384#ifdef TOOLS_USE_FREETYPE
385 toolx::sg::text_freetype_marker* text = new toolx::sg::text_freetype_marker;
386 text->add_embedded_font(tools::sg::font_lato_regular_ttf(),tools::font::lato_regular_ttf);
387 text->font = tools::sg::font_lato_regular_ttf();
388 text->front_face = tools::sg::winding_cw;
389//text->modeling = tools::sg::font_pixmap; //problem with Qt/GL. It slows rendering!
390#else
391 tools::sg::text_hershey_marker* text = new tools::sg::text_hershey_marker;
392//text->encoding.value(a_encoding);
393#endif
394 text->height = float(size); //pixels
395 text->strings.add(a_text.GetText());
396 {switch (a_text.GetLayout()) {
397 default:
398 case G4Text::left:
399 text->hjust = tools::sg::left;
400 break;
401 case G4Text::centre:
402 text->hjust = tools::sg::center;
403 break;
404 case G4Text::right:
405 text->hjust = tools::sg::right;
406 break;
407 }}
408//text->vjust.value(a_vjust);
409 parentNode->add(text);
410
411}
HepGeom::Translate3D G4Translate3D
Layout GetLayout() const
G4String GetText() const
@ centre
Definition G4Text.hh:76
@ right
Definition G4Text.hh:76
@ left
Definition G4Text.hh:76
const G4Colour & GetTextColour(const G4Text &)

◆ ClearStore()

void G4ToolsSGSceneHandler::ClearStore ( )
virtual

Reimplemented from G4VSceneHandler.

Definition at line 196 of file G4ToolsSGSceneHandler.cc.

197{
198 fpTransient2DObjects.clear();
199 fpPersistent2DObjects.clear();
200 fpTransient3DObjects.clear();
201 fpPersistent3DObjects.clear();
203}

◆ ClearTransientStore()

void G4ToolsSGSceneHandler::ClearTransientStore ( )
virtual

Reimplemented from G4VSceneHandler.

Definition at line 205 of file G4ToolsSGSceneHandler.cc.

206{
207 fpTransient2DObjects.clear();
208 fpTransient3DObjects.clear();
209}

◆ CreateSG()

void G4ToolsSGSceneHandler::CreateSG ( )
protected

◆ EstablishBaseNodes()

void G4ToolsSGSceneHandler::EstablishBaseNodes ( )
protected

Definition at line 106 of file G4ToolsSGSceneHandler.cc.

107{
108 // Physical volume objects for each world hang from POs
109 G4TransportationManager* transportationManager = G4TransportationManager::GetTransportationManager ();
110 size_t nWorlds = transportationManager->GetNoWorlds();
111 std::vector<G4VPhysicalVolume*>::iterator iterWorld = transportationManager->GetWorldsIterator();
112 fpPhysicalVolumeObjects.resize(nWorlds);
113 for (size_t i = 0; i < nWorlds; ++i, ++iterWorld) {
114 G4VPhysicalVolume* _world = (*iterWorld);
115 auto entity = new G4ToolsSGNode;
116 fpPersistent3DObjects.add(entity);
117 entity->SetPVNodeID(G4PhysicalVolumeModel::G4PhysicalVolumeNodeID(_world));
118 fpPhysicalVolumeObjects[i] = entity;
119 }
120}
std::vector< G4ToolsSGNode * > fpPhysicalVolumeObjects
static G4TransportationManager * GetTransportationManager()
std::vector< G4VPhysicalVolume * >::iterator GetWorldsIterator()
std::size_t GetNoWorlds() const

Referenced by ClearStore(), and G4ToolsSGSceneHandler().

◆ GetOrCreateNode()

tools::sg::separator * G4ToolsSGSceneHandler::GetOrCreateNode ( )
protected

Definition at line 122 of file G4ToolsSGSceneHandler.cc.

123{ // Retrieve or create a G4ToolsSGNode node suitable for next solid or primitive
124
125 // For time being, avoid errors in MT mode - see G4ToolsSGViewer::SwitchToMasterThread
126 if (!G4Threading::IsMasterThread()) return nullptr;
127
128 if (fReadyForTransients) { // All transients hang from this node
129 tools::sg::separator* sep = new tools::sg::separator;
130 fpTransient3DObjects.add(sep);
131 return sep;
132 }
133
134 auto* pPVModel = dynamic_cast<G4PhysicalVolumeModel*>(fpModel);
135
136 if (!pPVModel) { // Persistent objects (e.g., axes)
137 tools::sg::separator* sep = new tools::sg::separator;
138 fpPersistent3DObjects.add(sep);
139 return sep;
140 }
141
142 // So this is a G4PhysicalVolumeModel
143 typedef G4PhysicalVolumeModel::G4PhysicalVolumeNodeID PVNodeID;
144 typedef std::vector<PVNodeID> PVPath;
145 //const PVPath& drawnPVPath = pPVModel->GetDrawnPVPath();
146 const PVPath& fullPVPath = pPVModel->GetFullPVPath();
147 //G4int currentDepth = pPVModel->GetCurrentDepth();
148 //G4VPhysicalVolume* pCurrentPV = pPVModel->GetCurrentPV();
149 //G4LogicalVolume* pCurrentLV = pPVModel->GetCurrentLV();
150 //G4Material* pCurrentMaterial = pPVModel->GetCurrentMaterial();
151 // Note: pCurrentMaterial may be zero (parallel world).
152
153 // Find appropriate root
154 const size_t nWorlds = fpPhysicalVolumeObjects.size();
155 size_t iWorld = 0;
156 for (; iWorld < nWorlds; ++iWorld) {
157 if (fullPVPath[0].GetPhysicalVolume() ==
158 fpPhysicalVolumeObjects[iWorld]->GetPVNodeID().GetPhysicalVolume()) break;
159 }
160 if (iWorld == nWorlds) {
161 G4Exception("G4ToolsSGSceneHandler::GetOrCreateNode", "ToolsSG-0000", FatalException,
162 "World mis-match - not possible(!?)");
163 }
164
165 // (Re-)establish pv path of root entity
166 G4ToolsSGNode* _world = fpPhysicalVolumeObjects[iWorld];
167 _world->SetPVNodeID(fullPVPath[0]);
168
169 // Provide nodes as required - may be a new node or a pre-existing node
170 G4ToolsSGNode* node = _world; // Working variable - default to world
171 const size_t depth = fullPVPath.size();
172 size_t iDepth = 1;
173 while (iDepth < depth) {
174 const auto& children = node->children();
175 const G4int nChildren = (G4int)children.size();
176 G4int iChild = 0;
177 G4ToolsSGNode* child = nullptr;
178 for (; iChild < nChildren; ++iChild) {
179 child = static_cast<G4ToolsSGNode*>(children[iChild]);
180 if (child->GetPVNodeID() == fullPVPath[iDepth]) break;
181 }
182 if (iChild != nChildren) { // Existing node found
183 node = child; // Must be the ancestor of new node (subsequent iteration)
184 } else {
185 // Add a new node as child of node
186 G4ToolsSGNode* newNode = new G4ToolsSGNode;
187 node->add(newNode);
188 newNode->SetPVNodeID(fullPVPath[iDepth]);
189 node = newNode;
190 }
191 ++iDepth;
192 }
193 return node;
194}
const G4PhysicalVolumeModel::G4PhysicalVolumeNodeID & GetPVNodeID() const
void SetPVNodeID(const G4PhysicalVolumeModel::G4PhysicalVolumeNodeID &id)
G4bool IsMasterThread()

Referenced by AddPrimitive(), AddPrimitive(), AddPrimitive(), AddPrimitive(), and AddPrimitive().

◆ GetPersistent2DObjects()

tools::sg::separator & G4ToolsSGSceneHandler::GetPersistent2DObjects ( )
inline

Definition at line 65 of file G4ToolsSGSceneHandler.hh.

◆ GetPersistent3DObjects()

tools::sg::separator & G4ToolsSGSceneHandler::GetPersistent3DObjects ( )
inline

Definition at line 67 of file G4ToolsSGSceneHandler.hh.

◆ GetTransient2DObjects()

tools::sg::separator & G4ToolsSGSceneHandler::GetTransient2DObjects ( )
inline

Definition at line 64 of file G4ToolsSGSceneHandler.hh.

◆ GetTransient3DObjects()

tools::sg::separator & G4ToolsSGSceneHandler::GetTransient3DObjects ( )
inline

Definition at line 66 of file G4ToolsSGSceneHandler.hh.

◆ operator=()

G4ToolsSGSceneHandler & G4ToolsSGSceneHandler::operator= ( const G4ToolsSGSceneHandler & )
inlineprotected

Definition at line 73 of file G4ToolsSGSceneHandler.hh.

73{return *this;}

◆ SetPlotterHistograms()

void G4ToolsSGSceneHandler::SetPlotterHistograms ( tools::sg::plots & a_plots)
protected

Definition at line 706 of file G4ToolsSGSceneHandler.cc.

706 {
707 a_plots.clear();
708 G4UImanager* UI = G4UImanager::GetUIpointer();
709 if(UI==NULL) return;
710 {tools_vforcit(Region_h1,fRegionH1s,it) {
711 tools::sg::plotter* _plotter = a_plots.find_plotter((*it).first);
712 if(_plotter) {
713 int hid = (*it).second;
714 std::ostringstream os;
715 os << hid;
716 std::string cmd("/analysis/h1/get ");
717 cmd += std::string(os.str());
718 auto keepControlVerbose = UI->GetVerboseLevel();
719 UI->SetVerboseLevel(0);
720 G4int status = UI->ApplyCommand(cmd.c_str());
721 UI->SetVerboseLevel(keepControlVerbose);
723 G4String hexString = UI->GetCurrentValues("/analysis/h1/get");
724 if(hexString.size()) {
725 void* ptr;
726 std::istringstream is(hexString);
727 is >> ptr;
728 tools::histo::h1d* _h = (tools::histo::h1d*)ptr;
729 tools::sg::plottable* p = new tools::sg::h1d2plot_cp(*_h);
730 _plotter->add_plottable(p); //give ownership of p to sg::plotter.
731 }
732 } else {
733 G4cerr <<
734 "G4ToolsSGSceneHandler::SetPlotterHistograms: cannot get histogram - maybe doesn't exist?"
735 "\n Maybe this app does not do analysis at all?"
736 << G4endl;
737 }
738 }
739 }}
740 {tools_vforcit(Region_h2,fRegionH2s,it) {
741 tools::sg::plotter* _plotter = a_plots.find_plotter((*it).first);
742 if(_plotter) {
743 int hid = (*it).second;
744 std::ostringstream os;
745 os << hid;
746 std::string cmd("/analysis/h2/get ");
747 cmd += std::string(os.str());
748 auto keepControlVerbose = UI->GetVerboseLevel();
749 UI->SetVerboseLevel(0);
750 G4int status = UI->ApplyCommand(cmd.c_str());
751 UI->SetVerboseLevel(keepControlVerbose);
753 G4String hexString = UI->GetCurrentValues("/analysis/h2/get");
754 if(hexString.size()) {
755 void* ptr;
756 std::istringstream is(hexString);
757 is >> ptr;
758 tools::histo::h2d* _h = (tools::histo::h2d*)ptr;
759 tools::sg::plottable* p = new tools::sg::h2d2plot_cp(*_h);
760 _plotter->add_plottable(p); //give ownership of p to sg::plotter.
761 }
762 } else {
763 G4cerr <<
764 "G4ToolsSGSceneHandler::SetPlotterHistograms: cannot get histogram - maybe doesn't exist?"
765 "\n Maybe this app does not do analysis at all?"
766 << G4endl;
767 }
768 }
769 }}
770}
@ fCommandSucceeded
std::pair< unsigned int, int > Region_h2
std::pair< unsigned int, int > Region_h1
G4int ApplyCommand(const char *aCommand)
G4int GetVerboseLevel() const
G4String GetCurrentValues(const char *aCommand)
static G4UImanager * GetUIpointer()
void SetVerboseLevel(G4int val)

Referenced by AddPrimitive(), and TouchPlotters().

◆ TouchPlotters()

void G4ToolsSGSceneHandler::TouchPlotters ( tools::sg::node & a_sg)

Definition at line 802 of file G4ToolsSGSceneHandler.cc.

802 {
803 tools::sg::search_action sa(G4cout);
804 const tools::sg::search_action::paths_t& paths = tools::sg::find_paths<tools::sg::plots>(sa,a_sg);
805 tools_vforcit(tools::sg::path_t,paths,it) {
806 tools::sg::plots* _plots = tools::sg::tail<tools::sg::plots>(*it);
807 if(_plots) {
808 SetPlotterHistograms(*_plots);
809 }
810 }
811}

Member Data Documentation

◆ fFreetypeNode

tools::sg::base_freetype* G4ToolsSGSceneHandler::fFreetypeNode
protected

◆ fpPersistent2DObjects

tools::sg::separator G4ToolsSGSceneHandler::fpPersistent2DObjects
protected

◆ fpPersistent3DObjects

tools::sg::separator G4ToolsSGSceneHandler::fpPersistent3DObjects
protected

◆ fpPhysicalVolumeObjects

std::vector<G4ToolsSGNode*> G4ToolsSGSceneHandler::fpPhysicalVolumeObjects
protected

Definition at line 90 of file G4ToolsSGSceneHandler.hh.

Referenced by EstablishBaseNodes(), and GetOrCreateNode().

◆ fpTransient2DObjects

tools::sg::separator G4ToolsSGSceneHandler::fpTransient2DObjects
protected

◆ fpTransient3DObjects

tools::sg::separator G4ToolsSGSceneHandler::fpTransient3DObjects
protected

◆ fRegionH1s

std::vector<Region_h1> G4ToolsSGSceneHandler::fRegionH1s
protected

Definition at line 96 of file G4ToolsSGSceneHandler.hh.

Referenced by AddPrimitive(), and SetPlotterHistograms().

◆ fRegionH2s

std::vector<Region_h2> G4ToolsSGSceneHandler::fRegionH2s
protected

Definition at line 97 of file G4ToolsSGSceneHandler.hh.

Referenced by AddPrimitive(), and SetPlotterHistograms().

◆ fSceneIdCount

G4int G4ToolsSGSceneHandler::fSceneIdCount = 0
staticprotected

Definition at line 82 of file G4ToolsSGSceneHandler.hh.

Referenced by G4ToolsSGSceneHandler().


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