Geant4.10
 All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
Public Member Functions
XrayFluoMercuryDetectorMessenger Class Reference

#include <XrayFluoMercuryDetectorMessenger.hh>

Inheritance diagram for XrayFluoMercuryDetectorMessenger:
G4UImessenger

Public Member Functions

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

Additional Inherited Members

- Protected Member Functions inherited from G4UImessenger
G4String ItoS (G4int i)
 
G4String DtoS (G4double a)
 
G4String BtoS (G4bool b)
 
G4int StoI (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)
 
- Protected Attributes inherited from G4UImessenger
G4UIdirectorybaseDir
 
G4String baseDirName
 

Detailed Description

Definition at line 56 of file XrayFluoMercuryDetectorMessenger.hh.

Constructor & Destructor Documentation

XrayFluoMercuryDetectorMessenger::XrayFluoMercuryDetectorMessenger ( XrayFluoMercuryDetectorConstruction Det)

Definition at line 50 of file XrayFluoMercuryDetectorMessenger.cc.

References G4UIcommand::AvailableForStates(), G4State_Idle, G4UIcmdWithAString::SetCandidates(), G4UIcmdWithADoubleAndUnit::SetDefaultUnit(), G4UIcmdWithAString::SetDefaultValue(), G4UIcommand::SetGuidance(), G4UIcmdWithAString::SetParameterName(), G4UIcmdWithADoubleAndUnit::SetParameterName(), and G4UIcmdWithADoubleAndUnit::SetUnitCategory().

51 :Detector(Det)
52 {
53  detDir = new G4UIdirectory("/apparate/");
54  detDir->SetGuidance("detector control.");
55 
56  UpdateCmd = new G4UIcmdWithoutParameter("/apparate/update",this);
57  UpdateCmd->SetGuidance("Update apparate geometry.");
58  UpdateCmd->SetGuidance("This command MUST be applied before \"beamOn\" ");
59  UpdateCmd->SetGuidance("if you changed geometrical value(s): /apparate/GrainDiameter and /apparate/sampleGranularity");
60 
61  UpdateCmd->AvailableForStates(G4State_Idle);
62 
63  sampleCmd = new G4UIcmdWithAString("/apparate/mercuryMaterial",this);
64  sampleCmd->SetGuidance("select a diferent material for the mercury");
65  sampleCmd->SetParameterName("material",true);
66  sampleCmd->SetDefaultValue("mars1");
67  sampleCmd->SetCandidates("Dolorite Anorthosite Mars1 IceBasalt");
68  sampleCmd->AvailableForStates(G4State_Idle);
69 
70  detectorCmd = new G4UIcmdWithAString("/apparate/detector",this);
71  detectorCmd->SetGuidance("select a diferent detectorType");
72  detectorCmd->SetParameterName("detector",true);
73  detectorCmd->SetDefaultValue("sili");
74  detectorCmd->SetCandidates("sili hpge");
75  detectorCmd->AvailableForStates(G4State_Idle);
76 
77  latitudeAngleCmd = new G4UIcmdWithADoubleAndUnit( "/apparate/latitude",this );
78  latitudeAngleCmd->SetGuidance( "Set latitude angle of the spacecraft" );
79  latitudeAngleCmd->SetGuidance( "After this, /apparate/update must be executed before BeamOn" );
80  latitudeAngleCmd->SetGuidance( "Default: 45 deg " );
81  latitudeAngleCmd->SetParameterName( "Latitude Angle", true, true );
82  latitudeAngleCmd->SetDefaultUnit( "deg" );
83  latitudeAngleCmd->SetUnitCategory( "Angle" );
84  latitudeAngleCmd->AvailableForStates(G4State_Idle);
85 
86  orbitHeightCmd = new G4UIcmdWithADoubleAndUnit( "/apparate/orbitHeight",this );
87  orbitHeightCmd->SetGuidance( "Set height of the spacecraft above Mercuey Surface" );
88  orbitHeightCmd->SetGuidance( "After this, /apparate/update must be executed before BeamOn" );
89  orbitHeightCmd->SetGuidance( "Default: 400 km " );
90  orbitHeightCmd->SetParameterName( "Spacecraft Altitude", true, true );
91  orbitHeightCmd->SetDefaultUnit( "km" );
92  orbitHeightCmd->SetUnitCategory( "Length" );
93  orbitHeightCmd->AvailableForStates(G4State_Idle);
94 
95 
96 
97 // granularityFlagCmd= new G4UIcmdWithABool("/apparate/sampleGranularity",this);
98 // granularityFlagCmd->SetGuidance("Set if sample granularity is present");
99 // granularityFlagCmd->SetGuidance( "After this, /apparate/update must be executed before BeamOn" );
100 // granularityFlagCmd->SetParameterName("Granularity Flag",true);
101 // granularityFlagCmd->SetDefaultValue(false);
102 // granularityFlagCmd->AvailableForStates(G4State_Idle);
103 
104 }
void SetParameterName(const char *theName, G4bool omittable, G4bool currentAsDefault=false)
void SetUnitCategory(const char *unitCategory)
void SetGuidance(const char *aGuidance)
Definition: G4UIcommand.hh:161
void AvailableForStates(G4ApplicationState s1)
Definition: G4UIcommand.cc:225
void SetDefaultValue(const char *defVal)
void SetDefaultUnit(const char *defUnit)
void SetCandidates(const char *candidateList)
void SetParameterName(const char *theName, G4bool omittable, G4bool currentAsDefault=false)
XrayFluoMercuryDetectorMessenger::~XrayFluoMercuryDetectorMessenger ( )

Definition at line 108 of file XrayFluoMercuryDetectorMessenger.cc.

109 {
110  delete UpdateCmd;
111  delete detDir;
112 }

Member Function Documentation

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

Reimplemented from G4UImessenger.

Definition at line 116 of file XrayFluoMercuryDetectorMessenger.cc.

References G4UIcmdWithADoubleAndUnit::GetNewDoubleValue(), XrayFluoMercuryDetectorConstruction::SetDetectorType(), XrayFluoMercuryDetectorConstruction::SetLatitude(), XrayFluoMercuryDetectorConstruction::SetMercuryMaterial(), XrayFluoMercuryDetectorConstruction::SetOribitHeight(), and XrayFluoMercuryDetectorConstruction::UpdateGeometry().

117 {
118  if( command == UpdateCmd )
119  { Detector->UpdateGeometry(); }
120 
121  else if ( command == sampleCmd )
122  { Detector->SetMercuryMaterial(newValue);}
123 
124  else if ( command == detectorCmd )
125  { Detector->SetDetectorType(newValue);}
126 
127  else if ( command == latitudeAngleCmd )
128  {
129  G4double newAngle = latitudeAngleCmd->GetNewDoubleValue(newValue);
130  Detector->SetLatitude(newAngle);
131  }
132 
133  else if ( command == orbitHeightCmd )
134  {
135  G4double newAngle = orbitHeightCmd->GetNewDoubleValue(newValue);
136  Detector->SetOribitHeight(newAngle);
137  }
138 
139 
140 // else if ( command == granularityFlagCmd )
141 // {
142 // Detector->DeleteGrainObjects();
143 // G4bool newGranFlag = granularityFlagCmd->GetNewBoolValue(newValue);
144 // Detector->SetMercuryGranularity(newGranFlag);
145 // }
146 
147 }
static G4double GetNewDoubleValue(const char *paramString)
double G4double
Definition: G4Types.hh:76

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