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

#include <G4VisCommandsSceneAdd.hh>

+ Inheritance diagram for G4VisCommandSceneAddExtent:

Public Member Functions

 G4VisCommandSceneAddExtent ()
 
virtual ~G4VisCommandSceneAddExtent ()
 
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 ()=default
 
 G4UImessenger (const G4String &path, const G4String &dsc, G4bool commandsToBeBroadcasted=true)
 
virtual ~G4UImessenger ()
 
G4bool CommandsShouldBeInMaster () const
 

Additional Inherited Members

- Static Public Member Functions inherited from G4VVisCommand
static G4VisManagerGetVisManager ()
 
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="")
 
void Twinkle (G4VViewer *currentViewer, const G4ViewParameters &baseVP, const std::vector< std::vector< G4PhysicalVolumeModel::G4PhysicalVolumeNodeID > > &paths)
 
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 CopyCameraParameters (G4ViewParameters &target, const G4ViewParameters &from)
 
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 LtoS (G4long l)
 
G4String DtoS (G4double a)
 
G4String BtoS (G4bool b)
 
G4int StoI (const G4String &s)
 
G4long StoL (const G4String &s)
 
G4double StoD (const 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 = nullptr
 
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
 
static G4bool fThereWasAViewer = false
 
static G4ViewParameters fExistingVP
 
static G4SceneTreeItem fExistingSceneTree
 

Detailed Description

Definition at line 156 of file G4VisCommandsSceneAdd.hh.

Constructor & Destructor Documentation

◆ G4VisCommandSceneAddExtent()

G4VisCommandSceneAddExtent::G4VisCommandSceneAddExtent ( )

Definition at line 771 of file G4VisCommandsSceneAdd.cc.

771 {
772 fpCommand = new G4UIcommand("/vis/scene/add/extent", this);
773 fpCommand -> SetGuidance
774 ("Adds a dummy model with given extent to the current scene."
775 "\nRequires the limits: xmin, xmax, ymin, ymax, zmin, zmax unit."
776 "\nThis can be used to provide an extent to the scene even if"
777 "\nno other models with extent are available. For example,"
778 "\neven if there is no geometry. In that case, for example:"
779 "\n /vis/open OGL"
780 "\n /vis/scene/create"
781 "\n /vis/scene/add/extent -300 300 -300 300 -300 300 cm"
782 "\n /vis/sceneHandler/attach");
783 G4bool omitable;
784 G4UIparameter* parameter;
785 parameter = new G4UIparameter ("xmin", 'd', omitable = true);
786 parameter -> SetDefaultValue (0.);
787 fpCommand -> SetParameter (parameter);
788 parameter = new G4UIparameter ("xmax", 'd', omitable = true);
789 parameter -> SetDefaultValue (0.);
790 fpCommand -> SetParameter (parameter);
791 parameter = new G4UIparameter ("ymin", 'd', omitable = true);
792 parameter -> SetDefaultValue (0.);
793 fpCommand -> SetParameter (parameter);
794 parameter = new G4UIparameter ("ymax", 'd', omitable = true);
795 parameter -> SetDefaultValue (0.);
796 fpCommand -> SetParameter (parameter);
797 parameter = new G4UIparameter ("zmin", 'd', omitable = true);
798 parameter -> SetDefaultValue (0.);
799 fpCommand -> SetParameter (parameter);
800 parameter = new G4UIparameter ("zmax", 'd', omitable = true);
801 parameter -> SetDefaultValue (0.);
802 fpCommand -> SetParameter (parameter);
803 parameter = new G4UIparameter ("unit", 's', omitable = true);
804 parameter -> SetDefaultValue ("m");
805 fpCommand -> SetParameter (parameter);
806}
bool G4bool
Definition G4Types.hh:86

◆ ~G4VisCommandSceneAddExtent()

G4VisCommandSceneAddExtent::~G4VisCommandSceneAddExtent ( )
virtual

Definition at line 808 of file G4VisCommandsSceneAdd.cc.

808 {
809 delete fpCommand;
810}

Member Function Documentation

◆ GetCurrentValue()

G4String G4VisCommandSceneAddExtent::GetCurrentValue ( G4UIcommand * command)
virtual

Reimplemented from G4UImessenger.

Definition at line 812 of file G4VisCommandsSceneAdd.cc.

812 {
813 return "";
814}

◆ SetNewValue()

void G4VisCommandSceneAddExtent::SetNewValue ( G4UIcommand * command,
G4String newValue )
virtual

Reimplemented from G4UImessenger.

Definition at line 816 of file G4VisCommandsSceneAdd.cc.

817{
819 G4bool warn(verbosity >= G4VisManager::warnings);
820
822 if (!pScene) {
823 if (verbosity >= G4VisManager::errors) {
824 G4warn << "ERROR: No current scene. Please create one." << G4endl;
825 }
826 return;
827 }
828
829 G4double xmin, xmax, ymin, ymax, zmin, zmax;
830 G4String unitString;
831 std::istringstream is(newValue);
832 is >> xmin >> xmax >> ymin >> ymax >> zmin >> zmax >> unitString;
833 G4double unit = G4UIcommand::ValueOf(unitString);
834 xmin *= unit; xmax *= unit;
835 ymin *= unit; ymax *= unit;
836 zmin *= unit; zmax *= unit;
837
838 G4VisExtent visExtent(xmin, xmax, ymin, ymax, zmin, zmax);
839 Extent* extent = new Extent(xmin, xmax, ymin, ymax, zmin, zmax);
840 G4VModel* model =
842 model->SetType("Extent");
843 model->SetGlobalTag("Extent");
844 model->SetGlobalDescription("Extent: " + newValue);
845 model->SetExtent(visExtent);
846 const G4String& currentSceneName = pScene -> GetName ();
847 G4bool successful = pScene -> AddRunDurationModel (model, warn);
848 if (successful) {
849 if (verbosity >= G4VisManager::confirmations) {
850 G4cout << "A benign model with extent "
851 << visExtent
852 << " has been added to scene \""
853 << currentSceneName << "\"."
854 << G4endl;
855 }
856 }
857 else G4VisCommandsSceneAddUnsuccessful(verbosity);
858
860}
#define G4warn
Definition G4Scene.cc:41
double G4double
Definition G4Types.hh:83
#define G4endl
Definition G4ios.hh:67
G4GLOB_DLL std::ostream G4cout
static G4double ValueOf(const char *unitName)
void SetType(const G4String &)
void SetGlobalDescription(const G4String &)
void SetGlobalTag(const G4String &)
void SetExtent(const G4VisExtent &)
void G4VisCommandsSceneAddUnsuccessful(G4VisManager::Verbosity verbosity)
void CheckSceneAndNotifyHandlers(G4Scene *=nullptr)
static G4VisManager * fpVisManager
G4Scene * GetCurrentScene() const
static Verbosity GetVerbosity()

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