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

#include <G4VisCommandsSceneAdd.hh>

Inheritance diagram for G4VisCommandSceneAddMagneticField:

Public Member Functions

 G4VisCommandSceneAddMagneticField ()
virtual ~G4VisCommandSceneAddMagneticField ()
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, const 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 (const 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 373 of file G4VisCommandsSceneAdd.hh.

Constructor & Destructor Documentation

◆ G4VisCommandSceneAddMagneticField()

G4VisCommandSceneAddMagneticField::G4VisCommandSceneAddMagneticField ( )

Definition at line 2083 of file G4VisCommandsSceneAdd.cc.

2083 {
2084 fpCommand = new G4UIcommand ("/vis/scene/add/magneticField", this);
2085 fpCommand -> SetGuidance
2086 ("Adds magnetic field representation to current scene.");
2087 const G4UIcommandTree* tree = G4UImanager::GetUIpointer()->GetTree();
2088 const G4UIcommand* addElecFieldCmd = tree->FindPath("/vis/scene/add/electricField");
2089 // Pick up additional guidance from /vis/scene/add/electricField
2090 CopyGuidanceFrom(addElecFieldCmd,fpCommand,1);
2091 // Pick up parameters from /vis/scene/add/electricField
2092 CopyParametersFrom(addElecFieldCmd,fpCommand);
2093}
G4UIcommand * FindPath(const char *commandPath) const
G4UIcommandTree * GetTree() const
static G4UImanager * GetUIpointer()
void CopyParametersFrom(const G4UIcommand *fromCmd, G4UIcommand *toCmd)
void CopyGuidanceFrom(const G4UIcommand *fromCmd, G4UIcommand *toCmd, G4int startLine=0)

◆ ~G4VisCommandSceneAddMagneticField()

G4VisCommandSceneAddMagneticField::~G4VisCommandSceneAddMagneticField ( )
virtual

Definition at line 2095 of file G4VisCommandsSceneAdd.cc.

2095 {
2096 delete fpCommand;
2097}

Member Function Documentation

◆ GetCurrentValue()

G4String G4VisCommandSceneAddMagneticField::GetCurrentValue ( G4UIcommand * command)
virtual

Reimplemented from G4UImessenger.

Definition at line 2099 of file G4VisCommandsSceneAdd.cc.

2099 {
2100 return "";
2101}

◆ SetNewValue()

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

Reimplemented from G4UImessenger.

Definition at line 2103 of file G4VisCommandsSceneAdd.cc.

2104 {
2105
2106 G4VisManager::Verbosity verbosity = fpVisManager->GetVerbosity();
2107 G4bool warn(verbosity >= G4VisManager::warnings);
2108
2109 G4Scene* pScene = fpVisManager->GetCurrentScene();
2110 if (!pScene) {
2111 if (verbosity >= G4VisManager::errors) {
2112 G4warn << "ERROR: No current scene. Please create one." << G4endl;
2113 }
2114 return;
2115 }
2116
2117 G4int nDataPointsPerHalfScene;
2118 G4String representation;
2119 std::istringstream iss(newValue);
2120 iss >> nDataPointsPerHalfScene >> representation;
2122 modelRepresentation = G4ElectricFieldModel::fullArrow;
2123 if (representation == "lightArrow") {
2124 modelRepresentation = G4ElectricFieldModel::lightArrow;
2125 }
2126 G4VModel* model;
2127 model = new G4MagneticFieldModel
2128 (nDataPointsPerHalfScene,modelRepresentation,
2132 const G4String& currentSceneName = pScene -> GetName ();
2133 G4bool successful = pScene -> AddRunDurationModel (model, warn);
2134 if (successful) {
2135 if (verbosity >= G4VisManager::confirmations) {
2136 G4cout
2137 << "Magnetic field, if any, will be drawn in scene \""
2138 << currentSceneName
2139 << "\"\n with "
2140 << nDataPointsPerHalfScene
2141 << " data points per half extent and with representation \""
2142 << representation
2143 << '\"'
2144 << G4endl;
2145 }
2146 }
2147 else G4VisCommandsSceneAddUnsuccessful(verbosity);
2148
2150}
#define G4warn
Definition G4Scene.cc:41
bool G4bool
Definition G4Types.hh:86
int G4int
Definition G4Types.hh:85
#define G4endl
Definition G4ios.hh:67
G4GLOB_DLL std::ostream G4cout
void G4VisCommandsSceneAddUnsuccessful(G4VisManager::Verbosity verbosity)
void CheckSceneAndNotifyHandlers(G4Scene *=nullptr)
static std::vector< G4PhysicalVolumesSearchScene::Findings > fCurrrentPVFindingsForField
static G4VisManager * fpVisManager
static G4VisExtent fCurrentExtentForField
static G4int fCurrentArrow3DLineSegmentsPerCircle

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