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

#include <G4VisCommandsSceneAdd.hh>

+ Inheritance diagram for G4VisCommandSceneAddArrow:

Public Member Functions

 G4VisCommandSceneAddArrow ()
 
virtual ~G4VisCommandSceneAddArrow ()
 
G4String GetCurrentValue (G4UIcommand *command)
 
void SetNewValue (G4UIcommand *command, G4String newValue)
 
- Public Member Functions inherited from G4VVisCommandScene
 G4VVisCommandScene ()
 
virtual ~G4VVisCommandScene ()
 
- 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 G4VVisCommandScene
G4String CurrentSceneName ()
 
- 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 46 of file G4VisCommandsSceneAdd.hh.

Constructor & Destructor Documentation

◆ G4VisCommandSceneAddArrow()

G4VisCommandSceneAddArrow::G4VisCommandSceneAddArrow ( )

Definition at line 86 of file G4VisCommandsSceneAdd.cc.

86 {
87 fpCommand = new G4UIcommand("/vis/scene/add/arrow", this);
88 fpCommand -> SetGuidance ("Adds arrow to current scene.");
89 G4bool omitable;
90 G4UIparameter* parameter;
91 parameter = new G4UIparameter ("x1", 'd', omitable = false);
92 fpCommand -> SetParameter (parameter);
93 parameter = new G4UIparameter ("y1", 'd', omitable = false);
94 fpCommand -> SetParameter (parameter);
95 parameter = new G4UIparameter ("z1", 'd', omitable = false);
96 fpCommand -> SetParameter (parameter);
97 parameter = new G4UIparameter ("x2", 'd', omitable = false);
98 fpCommand -> SetParameter (parameter);
99 parameter = new G4UIparameter ("y2", 'd', omitable = false);
100 fpCommand -> SetParameter (parameter);
101 parameter = new G4UIparameter ("z2", 'd', omitable = false);
102 fpCommand -> SetParameter (parameter);
103 parameter = new G4UIparameter ("unit", 's', omitable = true);
104 parameter->SetDefaultValue ("m");
105 fpCommand->SetParameter (parameter);
106}
bool G4bool
Definition: G4Types.hh:86
void SetParameter(G4UIparameter *const newParameter)
Definition: G4UIcommand.hh:146
void SetDefaultValue(const char *theDefaultValue)

◆ ~G4VisCommandSceneAddArrow()

G4VisCommandSceneAddArrow::~G4VisCommandSceneAddArrow ( )
virtual

Definition at line 108 of file G4VisCommandsSceneAdd.cc.

108 {
109 delete fpCommand;
110}

Member Function Documentation

◆ GetCurrentValue()

G4String G4VisCommandSceneAddArrow::GetCurrentValue ( G4UIcommand command)
virtual

Reimplemented from G4UImessenger.

Definition at line 112 of file G4VisCommandsSceneAdd.cc.

112 {
113 return "";
114}

◆ SetNewValue()

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

Reimplemented from G4UImessenger.

Definition at line 116 of file G4VisCommandsSceneAdd.cc.

117{
119 G4bool warn(verbosity >= G4VisManager::warnings);
120
122 if (!pScene) {
123 if (verbosity >= G4VisManager::errors) {
124 G4cerr << "ERROR: No current scene. Please create one." << G4endl;
125 }
126 return;
127 }
128
129 G4String unitString;
130 G4double x1, y1, z1, x2, y2, z2;
131 std::istringstream is(newValue);
132 is >> x1 >> y1 >> z1 >> x2 >> y2 >> z2 >> unitString;
133 G4double unit = G4UIcommand::ValueOf(unitString);
134 x1 *= unit; y1 *= unit; z1 *= unit;
135 x2 *= unit; y2 *= unit; z2 *= unit;
136
137 // Consult scene for arrow width.
138 const G4VisExtent& sceneExtent = pScene->GetExtent();
139 G4double arrowWidth =
140 0.005 * fCurrentLineWidth * sceneExtent.GetExtentRadius();
141
142 G4VModel* model = new G4ArrowModel
143 (x1, y1, z1, x2, y2, z2,
144 arrowWidth, fCurrentColour, newValue,
146
147 const G4String& currentSceneName = pScene -> GetName ();
148 G4bool successful = pScene -> AddRunDurationModel (model, warn);
149 if (successful) {
150 if (verbosity >= G4VisManager::confirmations) {
151 G4cout << "Arrow has been added to scene \""
152 << currentSceneName << "\"."
153 << G4endl;
154 }
155 }
156 else G4VisCommandsSceneAddUnsuccessful(verbosity);
157
159}
double G4double
Definition: G4Types.hh:83
G4GLOB_DLL std::ostream G4cerr
#define G4endl
Definition: G4ios.hh:57
G4GLOB_DLL std::ostream G4cout
const G4VisExtent & GetExtent() const
static G4double ValueOf(const char *unitName)
Definition: G4UIcommand.cc:348
void G4VisCommandsSceneAddUnsuccessful(G4VisManager::Verbosity verbosity)
void CheckSceneAndNotifyHandlers(G4Scene *=nullptr)
static G4VisManager * fpVisManager
static G4int fCurrentArrow3DLineSegmentsPerCircle
static G4double fCurrentLineWidth
static G4Colour fCurrentColour
G4double GetExtentRadius() const
Definition: G4VisExtent.cc:75
G4Scene * GetCurrentScene() const
static Verbosity GetVerbosity()

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