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

#include <G4VisCommandsCompound.hh>

+ Inheritance diagram for G4VisCommandDrawTree:

Public Member Functions

 G4VisCommandDrawTree ()
 
virtual ~G4VisCommandDrawTree ()
 
void SetNewValue (G4UIcommand *command, G4String newValue)
 
- Public Member Functions inherited from G4VVisCommand
 G4VVisCommand ()
 
virtual ~G4VVisCommand ()
 
- Public Member Functions inherited from G4UImessenger
 G4UImessenger ()
 
 G4UImessenger (const G4String &path, const G4String &dsc, G4bool commandsToBeBroadcasted=true)
 
virtual ~G4UImessenger ()
 
virtual G4String GetCurrentValue (G4UIcommand *command)
 
virtual void SetNewValue (G4UIcommand *command, G4String newValue)
 
G4bool operator== (const G4UImessenger &messenger) const
 
G4bool operator!= (const G4UImessenger &messenger) const
 
G4bool CommandsShouldBeInMaster () const
 

Additional Inherited Members

- Static Public Member Functions inherited from G4VVisCommand
static void SetVisManager (G4VisManager *pVisManager)
 
static const G4ColourGetCurrentTextColour ()
 
- Protected Member Functions inherited from G4VVisCommand
void SetViewParameters (G4VViewer *viewer, const G4ViewParameters &viewParams)
 
void RefreshIfRequired (G4VViewer *viewer)
 
void InterpolateViews (G4VViewer *currentViewer, std::vector< G4ViewParameters > viewVector, const G4int nInterpolationPoints=50, const G4int waitTimePerPointmilliseconds=20, const G4String exportString="")
 
void InterpolateToNewView (G4VViewer *currentViewer, const G4ViewParameters &oldVP, const G4ViewParameters &newVP, const G4int nInterpolationPoints=50, const G4int waitTimePerPointmilliseconds=20, const G4String exportString="")
 
const G4StringConvertToColourGuidance ()
 
void ConvertToColour (G4Colour &colour, const G4String &redOrString, G4double green, G4double blue, G4double opacity)
 
G4bool ProvideValueOfUnit (const G4String &where, const G4String &unit, const G4String &category, G4double &value)
 
void CheckSceneAndNotifyHandlers (G4Scene *=nullptr)
 
G4bool CheckView ()
 
void G4VisCommandsSceneAddUnsuccessful (G4VisManager::Verbosity verbosity)
 
void CopyGuidanceFrom (const G4UIcommand *fromCmd, G4UIcommand *toCmd, G4int startLine=0)
 
void CopyParametersFrom (const G4UIcommand *fromCmd, G4UIcommand *toCmd)
 
void DrawExtent (const G4VisExtent &)
 
- Protected Member Functions inherited from G4UImessenger
G4String ItoS (G4int i)
 
G4String DtoS (G4double a)
 
G4String BtoS (G4bool b)
 
G4int StoI (G4String s)
 
G4long StoL (G4String s)
 
G4double StoD (G4String s)
 
G4bool StoB (G4String s)
 
void AddUIcommand (G4UIcommand *newCommand)
 
void CreateDirectory (const G4String &path, const G4String &dsc, G4bool commandsToBeBroadcasted=true)
 
template<typename T >
T * CreateCommand (const G4String &cname, const G4String &dsc)
 
- Static Protected Member Functions inherited from G4VVisCommand
static G4String ConvertToString (G4double x, G4double y, const char *unitName)
 
static G4bool ConvertToDoublePair (const G4String &paramString, G4double &xval, G4double &yval)
 
- Protected Attributes inherited from G4UImessenger
G4UIdirectorybaseDir = nullptr
 
G4String baseDirName = ""
 
G4bool commandsShouldBeInMaster = false
 
- Static Protected Attributes inherited from G4VVisCommand
static G4VisManagerfpVisManager = 0
 
static G4int fCurrentArrow3DLineSegmentsPerCircle = 6
 
static G4Colour fCurrentColour = G4Colour::White()
 
static G4double fCurrentLineWidth = 1.
 
static G4Colour fCurrentTextColour = G4Colour::Blue()
 
static G4Text::Layout fCurrentTextLayout = G4Text::left
 
static G4double fCurrentTextSize = 12.
 
static G4PhysicalVolumeModel::TouchableProperties fCurrentTouchableProperties
 
static G4VisExtent fCurrentExtentForField
 
static std::vector< G4PhysicalVolumesSearchScene::FindingsfCurrrentPVFindingsForField
 

Detailed Description

Definition at line 35 of file G4VisCommandsCompound.hh.

Constructor & Destructor Documentation

◆ G4VisCommandDrawTree()

G4VisCommandDrawTree::G4VisCommandDrawTree ( )

Definition at line 42 of file G4VisCommandsCompound.cc.

42 {
43 G4bool omitable;
44 fpCommand = new G4UIcommand("/vis/drawTree", this);
45 fpCommand->SetGuidance
46 ("Produces a representation of the geometry hierarchy. Further"
47 "\nguidance is given on running the command. Or look at the guidance"
48 "\nfor \"/vis/ASCIITree/verbose\".");
49 fpCommand->SetGuidance("The pre-existing scene and view are preserved.");
50 G4UIparameter* parameter;
51 parameter = new G4UIparameter("physical-volume-name", 's', omitable = true);
52 parameter -> SetDefaultValue("world");
53 fpCommand -> SetParameter (parameter);
54 parameter = new G4UIparameter("system", 's', omitable = true);
55 parameter -> SetDefaultValue("ATree");
56 fpCommand -> SetParameter (parameter);
57}
bool G4bool
Definition: G4Types.hh:86
void SetGuidance(const char *aGuidance)
Definition: G4UIcommand.hh:156

◆ ~G4VisCommandDrawTree()

G4VisCommandDrawTree::~G4VisCommandDrawTree ( )
virtual

Definition at line 59 of file G4VisCommandsCompound.cc.

59 {
60 delete fpCommand;
61}

Member Function Documentation

◆ SetNewValue()

void G4VisCommandDrawTree::SetNewValue ( G4UIcommand command,
G4String  newValue 
)
virtual

Reimplemented from G4UImessenger.

Definition at line 63 of file G4VisCommandsCompound.cc.

63 {
64
65 G4String pvname, system;
66 std::istringstream is(newValue);
67 is >> pvname >> system;
68
69 // Note: The second parameter, "system", is intended to allow the user
70 // a choice of dedicated tree printing/displaying systems but at present
71 // the only such dedicated system is ASCIITree. It doesn't make sense to
72 // specify OGLSX, for example. So to avoid confusion we restrict this
73 // feature to systems that have "Tree" in the name or nickname.
74
75 // Of course, some other systems, such as OGLSQt, have a tree browser
76 // built-in. The HepRApp offline browser also has a tree browser
77 // built in.
78
79 if (!system.contains("Tree")) {
80 system = "ATree";
81 }
82
84 G4Scene* keepScene = fpVisManager->GetCurrentScene();
88
90 G4int keepUIVerbose = UImanager->GetVerboseLevel();
91 G4int newVerbose(0);
92 if (keepUIVerbose >= 2 ||
94 newVerbose = 2;
95 UImanager->SetVerboseLevel(newVerbose);
96
97 G4bool keepAbleness = fpVisManager->GetConcreteInstance()? true: false;
98
99 auto errorCode = UImanager->ApplyCommand(G4String("/vis/open " + system));
100 if (errorCode == 0) {
101 if (!keepAbleness) { // Enable temporarily
103 UImanager->ApplyCommand("/vis/enable");
104 fpVisManager->SetVerboseLevel(keepVisVerbosity);
105 }
106 UImanager->ApplyCommand(G4String("/vis/drawVolume " + pvname));
107 UImanager->ApplyCommand("/vis/viewer/flush");
108 if (!keepAbleness) { // Disable again
110 UImanager->ApplyCommand("/vis/disable");
111 fpVisManager->SetVerboseLevel(keepVisVerbosity);
112 }
113 if (keepViewer) {
115 G4cout << "Reverting to " << keepViewer->GetName() << G4endl;
116 }
118 fpVisManager->SetCurrentScene(keepScene);
119 fpVisManager->SetCurrentSceneHandler(keepSceneHandler);
120 fpVisManager->SetCurrentViewer(keepViewer);
121 }
122 }
123 UImanager->SetVerboseLevel(keepUIVerbose);
124}
int G4int
Definition: G4Types.hh:85
#define G4endl
Definition: G4ios.hh:57
G4GLOB_DLL std::ostream G4cout
G4bool contains(const std::string &) const
G4int ApplyCommand(const char *aCommand)
Definition: G4UImanager.cc:485
G4int GetVerboseLevel() const
Definition: G4UImanager.hh:193
static G4UImanager * GetUIpointer()
Definition: G4UImanager.cc:77
void SetVerboseLevel(G4int val)
Definition: G4UImanager.hh:192
const G4String & GetName() const
static G4VisManager * fpVisManager
static G4VVisManager * GetConcreteInstance()
void SetCurrentGraphicsSystem(G4VGraphicsSystem *)
G4Scene * GetCurrentScene() const
void SetCurrentSceneHandler(G4VSceneHandler *)
void SetCurrentScene(G4Scene *)
void SetCurrentViewer(G4VViewer *)
G4VGraphicsSystem * GetCurrentGraphicsSystem() const
G4VViewer * GetCurrentViewer() const
G4VSceneHandler * GetCurrentSceneHandler() const
static Verbosity GetVerbosity()
void SetVerboseLevel(G4int)
#define errorCode
Definition: xmlparse.cc:618

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