54 if (!fpInstance) fpInstance =
new G4RTMessenger(p1);
60 theDefaultTracer = p1;
61 theTracer = theDefaultTracer;
68 fileCmd->
SetGuidance(
"Define the name of output JPEG file.");
74 columnCmd->
SetGuidance(
"Define the number of horizontal pixels.");
79 rowCmd->
SetGuidance(
"Define the number of vertical pixels.");
84 targetCmd->
SetGuidance(
"Define the center position of the target.");
91 eyePosCmd->
SetGuidance(
"Eye direction is calculated from (target - eyePosition).");
97 lightCmd->
SetGuidance(
"Define the direction of illumination light.");
98 lightCmd->
SetGuidance(
"The vector needs not to be a unit vector, but it must not be a zero vector.");
101 lightCmd->
SetRange(
"Px != 0 || Py != 0 || Pz != 0");
104 spanXCmd->
SetGuidance(
"Define the angle per 100 pixels.");
111 headCmd->
SetGuidance(
"Define the head direction.");
115 headCmd->
SetRange(
"headAngle>=0. && headAngle<360.");
118 attCmd->
SetGuidance(
"Define the attenuation length for transparent material.");
119 attCmd->
SetGuidance(
"Note that this value is independent to the attenuation length for the optical photon processes.");
126 distCmd->
SetGuidance(
"Distortion effect of the fish eye lens.");
131 transCmd->
SetGuidance(
"Ignore transparency even if the alpha of G4Colour < 1.");
136 bkgColCmd->
SetGuidance(
"Command has been deprecated. Use /vis/viewer/set/background instead.");
161 if(command==columnCmd)
162 { currentValue = columnCmd->ConvertToString(theTracer->GetNColumn()); }
163 else if(command==rowCmd)
164 { currentValue = rowCmd->ConvertToString(theTracer->GetNRow()); }
165 else if(command==targetCmd)
166 { currentValue = targetCmd->ConvertToString(theTracer->GetTargetPosition(),
"m"); }
167 else if(command==eyePosCmd)
168 { currentValue = eyePosCmd->ConvertToString(theTracer->GetEyePosition(),
"m"); }
169 else if(command==lightCmd)
170 { currentValue = lightCmd->ConvertToString(theTracer->GetLightDirection()); }
171 else if(command==spanXCmd)
172 { currentValue = spanXCmd->ConvertToString(theTracer->GetViewSpan(),
"deg"); }
173 else if(command==headCmd)
174 { currentValue = headCmd->ConvertToString(theTracer->GetHeadAngle(),
"deg"); }
175 else if(command==attCmd)
176 { currentValue = attCmd->ConvertToString(theTracer->GetAttenuationLength(),
"m");}
177 else if(command==distCmd)
178 { currentValue = distCmd->ConvertToString(theTracer->GetDistortion()); }
179 else if(command==transCmd)
181 else if(command==bkgColCmd)
182 { currentValue = bkgColCmd->ConvertToString(theTracer->GetBackgroundColour()); }
190 theTracer = theDefaultTracer;
199 "G4RTMessenger::SetNewValue: Current viewer is not of type RayTracer."
200 "\n Use \"/vis/viewer/select\" or \"/vis/open\"."
205 if (theTracer == theDefaultTracer) {
207"G4RTMessenger::SetNewValue: No valid current viewer. Using default RayTracer."
211 if(command==columnCmd)
212 { theTracer->SetNColumn(columnCmd->GetNewIntValue(newValue)); }
213 else if(command==rowCmd)
214 { theTracer->SetNRow(rowCmd->GetNewIntValue(newValue)); }
215 else if(command==targetCmd)
216 { theTracer->SetTargetPosition(targetCmd->GetNew3VectorValue(newValue)); }
217 else if(command==eyePosCmd)
218 { theTracer->SetEyePosition(eyePosCmd->GetNew3VectorValue(newValue)); }
219 else if(command==lightCmd)
220 { theTracer->SetLightDirection(lightCmd->GetNew3VectorValue(newValue)); }
221 else if(command==spanXCmd)
222 { theTracer->SetViewSpan(spanXCmd->GetNewDoubleValue(newValue)); }
223 else if(command==headCmd)
224 { theTracer->SetHeadAngle(headCmd->GetNewDoubleValue(newValue)); }
225 else if(command==attCmd)
226 { theTracer->SetAttenuationLength(attCmd->GetNewDoubleValue(newValue)); }
227 else if(command==distCmd)
228 { theTracer->SetDistortion(distCmd->GetNewBoolValue(newValue)); }
229 else if(command==bkgColCmd)
231 G4warn <<
"WARNING: /vis/rayTracer/backgroundColour has been deprecated."
232 "\n Use \"/vis/viewer/set/background\" instead."
235 else if(command==transCmd)
237 else if(command==fileCmd)
238 { theTracer->Trace(newValue); }
CLHEP::Hep3Vector G4ThreeVector
virtual void SetNewValue(G4UIcommand *command, G4String newValue)
virtual G4String GetCurrentValue(G4UIcommand *command)
static G4RTMessenger * GetInstance(G4TheRayTracer *p1)
static G4bool GetIgnoreTransparency()
static void SetIgnoreTransparency(G4bool val)
G4TheRayTracer * GetTracer()
void SetDefaultUnit(const char *defUnit)
void SetParameterName(const char *theNameX, const char *theNameY, const char *theNameZ, G4bool omittable, G4bool currentAsDefault=false)
void SetDefaultValue(const G4ThreeVector &defVal)
void SetDefaultValue(const G4ThreeVector &defVal)
void SetParameterName(const char *theNameX, const char *theNameY, const char *theNameZ, G4bool omittable, G4bool currentAsDefault=false)
void SetParameterName(const char *theName, G4bool omittable, G4bool currentAsDefault=false)
void SetDefaultValue(G4bool defVal)
void SetDefaultValue(G4double defVal)
void SetDefaultUnit(const char *defUnit)
void SetParameterName(const char *theName, G4bool omittable, G4bool currentAsDefault=false)
void SetParameterName(const char *theName, G4bool omittable, G4bool currentAsDefault=false)
void SetDefaultValue(const char *defVal)
void SetParameterName(const char *theName, G4bool omittable, G4bool currentAsDefault=false)
void SetGuidance(const char *aGuidance)
void SetRange(const char *rs)
void AvailableForStates(G4ApplicationState s1)
G4VViewer * GetCurrentViewer() const
static G4VisManager * GetInstance()