Geant4 Cross Reference

Cross-Referencing   Geant4
Geant4/visualization/RayTracer/src/G4RTMessenger.cc

Version: [ ReleaseNotes ] [ 1.0 ] [ 1.1 ] [ 2.0 ] [ 3.0 ] [ 3.1 ] [ 3.2 ] [ 4.0 ] [ 4.0.p1 ] [ 4.0.p2 ] [ 4.1 ] [ 4.1.p1 ] [ 5.0 ] [ 5.0.p1 ] [ 5.1 ] [ 5.1.p1 ] [ 5.2 ] [ 5.2.p1 ] [ 5.2.p2 ] [ 6.0 ] [ 6.0.p1 ] [ 6.1 ] [ 6.2 ] [ 6.2.p1 ] [ 6.2.p2 ] [ 7.0 ] [ 7.0.p1 ] [ 7.1 ] [ 7.1.p1 ] [ 8.0 ] [ 8.0.p1 ] [ 8.1 ] [ 8.1.p1 ] [ 8.1.p2 ] [ 8.2 ] [ 8.2.p1 ] [ 8.3 ] [ 8.3.p1 ] [ 8.3.p2 ] [ 9.0 ] [ 9.0.p1 ] [ 9.0.p2 ] [ 9.1 ] [ 9.1.p1 ] [ 9.1.p2 ] [ 9.1.p3 ] [ 9.2 ] [ 9.2.p1 ] [ 9.2.p2 ] [ 9.2.p3 ] [ 9.2.p4 ] [ 9.3 ] [ 9.3.p1 ] [ 9.3.p2 ] [ 9.4 ] [ 9.4.p1 ] [ 9.4.p2 ] [ 9.4.p3 ] [ 9.4.p4 ] [ 9.5 ] [ 9.5.p1 ] [ 9.5.p2 ] [ 9.6 ] [ 9.6.p1 ] [ 9.6.p2 ] [ 9.6.p3 ] [ 9.6.p4 ] [ 10.0 ] [ 10.0.p1 ] [ 10.0.p2 ] [ 10.0.p3 ] [ 10.0.p4 ] [ 10.1 ] [ 10.1.p1 ] [ 10.1.p2 ] [ 10.1.p3 ] [ 10.2 ] [ 10.2.p1 ] [ 10.2.p2 ] [ 10.2.p3 ] [ 10.3 ] [ 10.3.p1 ] [ 10.3.p2 ] [ 10.3.p3 ] [ 10.4 ] [ 10.4.p1 ] [ 10.4.p2 ] [ 10.4.p3 ] [ 10.5 ] [ 10.5.p1 ] [ 10.6 ] [ 10.6.p1 ] [ 10.6.p2 ] [ 10.6.p3 ] [ 10.7 ] [ 10.7.p1 ] [ 10.7.p2 ] [ 10.7.p3 ] [ 10.7.p4 ] [ 11.0 ] [ 11.0.p1 ] [ 11.0.p2 ] [ 11.0.p3, ] [ 11.0.p4 ] [ 11.1 ] [ 11.1.1 ] [ 11.1.2 ] [ 11.1.3 ] [ 11.2 ] [ 11.2.1 ] [ 11.2.2 ] [ 11.3.0 ]

Diff markup

Differences between /visualization/RayTracer/src/G4RTMessenger.cc (Version 11.3.0) and /visualization/RayTracer/src/G4RTMessenger.cc (Version 6.1)


  1 //                                                  1 //
  2 // *******************************************      2 // ********************************************************************
  3 // * License and Disclaimer                    <<   3 // * DISCLAIMER                                                       *
  4 // *                                                4 // *                                                                  *
  5 // * The  Geant4 software  is  copyright of th <<   5 // * The following disclaimer summarizes all the specific disclaimers *
  6 // * the Geant4 Collaboration.  It is provided <<   6 // * of contributors to this software. The specific disclaimers,which *
  7 // * conditions of the Geant4 Software License <<   7 // * govern, are listed with their locations in:                      *
  8 // * LICENSE and available at  http://cern.ch/ <<   8 // *   http://cern.ch/geant4/license                                  *
  9 // * include a list of copyright holders.      << 
 10 // *                                                9 // *                                                                  *
 11 // * Neither the authors of this software syst     10 // * Neither the authors of this software system, nor their employing *
 12 // * institutes,nor the agencies providing fin     11 // * institutes,nor the agencies providing financial support for this *
 13 // * work  make  any representation or  warran     12 // * work  make  any representation or  warranty, express or implied, *
 14 // * regarding  this  software system or assum     13 // * regarding  this  software system or assume any liability for its *
 15 // * use.  Please see the license in the file  <<  14 // * use.                                                             *
 16 // * for the full disclaimer and the limitatio << 
 17 // *                                               15 // *                                                                  *
 18 // * This  code  implementation is the result  <<  16 // * This  code  implementation is the  intellectual property  of the *
 19 // * technical work of the GEANT4 collaboratio <<  17 // * GEANT4 collaboration.                                            *
 20 // * By using,  copying,  modifying or  distri <<  18 // * By copying,  distributing  or modifying the Program (or any work *
 21 // * any work based  on the software)  you  ag <<  19 // * based  on  the Program)  you indicate  your  acceptance of  this *
 22 // * use  in  resulting  scientific  publicati <<  20 // * statement, and all its terms.                                    *
 23 // * acceptance of all terms of the Geant4 Sof << 
 24 // *******************************************     21 // ********************************************************************
 25 //                                                 22 //
 26 //                                                 23 //
                                                   >>  24 // $Id: G4RTMessenger.cc,v 1.7 2003/09/18 11:13:25 johna Exp $
                                                   >>  25 // GEANT4 tag $Name: geant4-06-00-patch-01 $
 27 //                                                 26 //
 28 //                                                 27 //
 29 //                                                 28 //
 30                                                    29 
 31                                                    30 
 32 #include "G4RTMessenger.hh"                        31 #include "G4RTMessenger.hh"
 33                                                    32 
 34 #include "G4UIdirectory.hh"                        33 #include "G4UIdirectory.hh"
 35 #include "G4UIcmdWithABool.hh"                     34 #include "G4UIcmdWithABool.hh"
 36 #include "G4UIcmdWith3Vector.hh"                   35 #include "G4UIcmdWith3Vector.hh"
 37 #include "G4UIcmdWith3VectorAndUnit.hh"            36 #include "G4UIcmdWith3VectorAndUnit.hh"
 38 #include "G4UIcmdWithADoubleAndUnit.hh"            37 #include "G4UIcmdWithADoubleAndUnit.hh"
 39 #include "G4UIcmdWithAnInteger.hh"                 38 #include "G4UIcmdWithAnInteger.hh"
 40 #include "G4UIcmdWithAString.hh"                   39 #include "G4UIcmdWithAString.hh"
                                                   >>  40 #include "G4RayTracer.hh"
 41 #include "G4RTSteppingAction.hh"                   41 #include "G4RTSteppingAction.hh"
 42 #include "G4ThreeVector.hh"                        42 #include "G4ThreeVector.hh"
 43 #include "G4VisManager.hh"                     << 
 44 #include "G4RayTracerViewer.hh"                << 
 45 #include "G4TheRayTracer.hh"                   << 
 46                                                    43 
 47 #define G4warn G4cout                          <<  44 G4RTMessenger::G4RTMessenger(G4RayTracer* p1,G4RTSteppingAction* p2)
 48                                                << 
 49 G4RTMessenger* G4RTMessenger::fpInstance = 0;  << 
 50                                                << 
 51 G4RTMessenger* G4RTMessenger::GetInstance      << 
 52 (G4TheRayTracer* p1)                           << 
 53 {                                              << 
 54   if (!fpInstance) fpInstance = new G4RTMessen << 
 55   return fpInstance;                           << 
 56 }                                              << 
 57                                                << 
 58 G4RTMessenger::G4RTMessenger(G4TheRayTracer* p << 
 59 {                                                  45 {
 60   theDefaultTracer = p1;                       <<  46   theTracer = p1;
 61   theTracer = theDefaultTracer;                <<  47   theSteppingAction = p2;
 62                                                    48 
 63   rayDirectory = new G4UIdirectory("/vis/rayTr     49   rayDirectory = new G4UIdirectory("/vis/rayTracer/");
 64   rayDirectory->SetGuidance("RayTracer command     50   rayDirectory->SetGuidance("RayTracer commands.");
 65                                                    51 
 66   fileCmd = new G4UIcmdWithAString("/vis/rayTr     52   fileCmd = new G4UIcmdWithAString("/vis/rayTracer/trace",this);
 67   fileCmd->SetGuidance("Start the ray tracing.     53   fileCmd->SetGuidance("Start the ray tracing.");
 68   fileCmd->SetGuidance("Define the name of out     54   fileCmd->SetGuidance("Define the name of output JPEG file.");
 69   fileCmd->SetParameterName("fileName",true);      55   fileCmd->SetParameterName("fileName",true);
 70   fileCmd->SetDefaultValue("g4RayTracer.jpeg")     56   fileCmd->SetDefaultValue("g4RayTracer.jpeg");
 71   fileCmd->AvailableForStates(G4State_Idle);       57   fileCmd->AvailableForStates(G4State_Idle);
 72                                                    58 
 73   columnCmd = new G4UIcmdWithAnInteger("/vis/r     59   columnCmd = new G4UIcmdWithAnInteger("/vis/rayTracer/column",this);
 74   columnCmd->SetGuidance("Define the number of     60   columnCmd->SetGuidance("Define the number of horizontal pixels.");
 75   columnCmd->SetParameterName("nPixel",false);     61   columnCmd->SetParameterName("nPixel",false);
 76   columnCmd->SetRange("nPixel > 0");               62   columnCmd->SetRange("nPixel > 0");
 77                                                    63 
 78   rowCmd = new G4UIcmdWithAnInteger("/vis/rayT     64   rowCmd = new G4UIcmdWithAnInteger("/vis/rayTracer/row",this);
 79   rowCmd->SetGuidance("Define the number of ve <<  65   rowCmd->SetGuidance("Define the number of virtical pixels.");
 80   rowCmd->SetParameterName("nPixel",false);        66   rowCmd->SetParameterName("nPixel",false);
 81   rowCmd->SetRange("nPixel > 0");                  67   rowCmd->SetRange("nPixel > 0");
 82                                                    68 
 83   targetCmd = new G4UIcmdWith3VectorAndUnit("/     69   targetCmd = new G4UIcmdWith3VectorAndUnit("/vis/rayTracer/target",this);
 84   targetCmd->SetGuidance("Define the center po     70   targetCmd->SetGuidance("Define the center position of the target.");
 85   targetCmd->SetParameterName("X","Y","Z",true     71   targetCmd->SetParameterName("X","Y","Z",true);
 86   targetCmd->SetDefaultValue(G4ThreeVector(0.,     72   targetCmd->SetDefaultValue(G4ThreeVector(0.,0.,0.));
 87   targetCmd->SetDefaultUnit("m");                  73   targetCmd->SetDefaultUnit("m");
 88                                                    74 
 89   eyePosCmd = new G4UIcmdWith3VectorAndUnit("/     75   eyePosCmd = new G4UIcmdWith3VectorAndUnit("/vis/rayTracer/eyePosition",this);
 90   eyePosCmd->SetGuidance("Define the eye posit     76   eyePosCmd->SetGuidance("Define the eye position.");
 91   eyePosCmd->SetGuidance("Eye direction is cal <<  77   eyePosCmd->SetGuidance("Eye direction is calsurated from (target - eyePosition).");
 92   eyePosCmd->SetParameterName("X","Y","Z",true     78   eyePosCmd->SetParameterName("X","Y","Z",true);
 93   eyePosCmd->SetDefaultValue(G4ThreeVector(0.,     79   eyePosCmd->SetDefaultValue(G4ThreeVector(0.,0.,0.));
 94   eyePosCmd->SetDefaultUnit("m");                  80   eyePosCmd->SetDefaultUnit("m");
 95                                                    81 
 96   lightCmd = new G4UIcmdWith3Vector("/vis/rayT     82   lightCmd = new G4UIcmdWith3Vector("/vis/rayTracer/lightDirection",this);
 97   lightCmd->SetGuidance("Define the direction      83   lightCmd->SetGuidance("Define the direction of illumination light.");
 98   lightCmd->SetGuidance("The vector needs not      84   lightCmd->SetGuidance("The vector needs not to be a unit vector, but it must not be a zero vector.");
 99   lightCmd->SetParameterName("Px","Py","Pz",tr     85   lightCmd->SetParameterName("Px","Py","Pz",true);
100   lightCmd->SetDefaultValue(G4ThreeVector(0.1,     86   lightCmd->SetDefaultValue(G4ThreeVector(0.1,0.2,0.3));
101   lightCmd->SetRange("Px != 0 || Py != 0 || Pz     87   lightCmd->SetRange("Px != 0 || Py != 0 || Pz != 0");
102                                                    88 
103   spanXCmd = new G4UIcmdWithADoubleAndUnit("/v     89   spanXCmd = new G4UIcmdWithADoubleAndUnit("/vis/rayTracer/span",this);
104   spanXCmd->SetGuidance("Define the angle per      90   spanXCmd->SetGuidance("Define the angle per 100 pixels.");
105   spanXCmd->SetParameterName("span",true);         91   spanXCmd->SetParameterName("span",true);
106   spanXCmd->SetDefaultValue(50.);                  92   spanXCmd->SetDefaultValue(50.);
107   spanXCmd->SetDefaultUnit("deg");                 93   spanXCmd->SetDefaultUnit("deg");
108   spanXCmd->SetRange("span>0.");                   94   spanXCmd->SetRange("span>0.");
109                                                    95 
110   headCmd = new G4UIcmdWithADoubleAndUnit("/vi     96   headCmd = new G4UIcmdWithADoubleAndUnit("/vis/rayTracer/headAngle",this);
111   headCmd->SetGuidance("Define the head direct     97   headCmd->SetGuidance("Define the head direction.");
112   headCmd->SetParameterName("headAngle",true);     98   headCmd->SetParameterName("headAngle",true);
113   headCmd->SetDefaultValue(270.);                  99   headCmd->SetDefaultValue(270.);
114   headCmd->SetDefaultUnit("deg");                 100   headCmd->SetDefaultUnit("deg");
115   headCmd->SetRange("headAngle>=0. && headAngl    101   headCmd->SetRange("headAngle>=0. && headAngle<360.");
116                                                   102 
117   attCmd = new G4UIcmdWithADoubleAndUnit("/vis    103   attCmd = new G4UIcmdWithADoubleAndUnit("/vis/rayTracer/attenuation",this);
118   attCmd->SetGuidance("Define the attenuation     104   attCmd->SetGuidance("Define the attenuation length for transparent material.");
119   attCmd->SetGuidance("Note that this value is    105   attCmd->SetGuidance("Note that this value is independent to the attenuation length for the optical photon processes.");
120   attCmd->SetParameterName("Length",true);        106   attCmd->SetParameterName("Length",true);
121   attCmd->SetDefaultValue(1.0);                   107   attCmd->SetDefaultValue(1.0);
122   attCmd->SetDefaultUnit("m");                    108   attCmd->SetDefaultUnit("m");
123   attCmd->SetRange("Length > 0.");                109   attCmd->SetRange("Length > 0.");
124                                                   110 
125   distCmd = new G4UIcmdWithABool("/vis/rayTrac    111   distCmd = new G4UIcmdWithABool("/vis/rayTracer/distortion",this);
126   distCmd->SetGuidance("Distortion effect of t    112   distCmd->SetGuidance("Distortion effect of the fish eye lens.");
127   distCmd->SetParameterName("flag",true);         113   distCmd->SetParameterName("flag",true);
128   distCmd->SetDefaultValue(false);                114   distCmd->SetDefaultValue(false);
129                                                   115 
130   transCmd = new G4UIcmdWithABool("/vis/rayTra    116   transCmd = new G4UIcmdWithABool("/vis/rayTracer/ignoreTransparency",this);
131   transCmd->SetGuidance("Ignore transparency e    117   transCmd->SetGuidance("Ignore transparency even if the alpha of G4Colour < 1.");
132   transCmd->SetParameterName("flag",true);        118   transCmd->SetParameterName("flag",true);
133   transCmd->SetDefaultValue(false);               119   transCmd->SetDefaultValue(false);
134                                                   120 
135   bkgColCmd = new G4UIcmdWith3Vector("/vis/ray    121   bkgColCmd = new G4UIcmdWith3Vector("/vis/rayTracer/backgroundColour",this);
136   bkgColCmd->SetGuidance("Command has been dep << 122   bkgColCmd->SetGuidance("Set background colour: red green blue: range 0.->1.");  bkgColCmd->SetGuidance("E.g: /vis/rayTracer/backgroundColour 0 0 0");
137   bkgColCmd->SetParameterName("red","green","b    123   bkgColCmd->SetParameterName("red","green","blue",true);
138   bkgColCmd->SetDefaultValue(G4ThreeVector(1.,    124   bkgColCmd->SetDefaultValue(G4ThreeVector(1.,1.,1.));
139 }                                                 125 }
140                                                   126 
141 G4RTMessenger::~G4RTMessenger()                   127 G4RTMessenger::~G4RTMessenger()
142 {                                                 128 {
143   delete columnCmd;                               129   delete columnCmd;
144   delete rowCmd;                                  130   delete rowCmd;
145   delete targetCmd;                               131   delete targetCmd;
146   delete eyePosCmd;                               132   delete eyePosCmd;
147   delete lightCmd;                                133   delete lightCmd;
148   delete spanXCmd;                                134   delete spanXCmd;
149   delete headCmd;                                 135   delete headCmd;
150   delete attCmd;                                  136   delete attCmd;
151   delete distCmd;                                 137   delete distCmd;
152   delete transCmd;                                138   delete transCmd;
153   delete fileCmd;                                 139   delete fileCmd;
154   delete bkgColCmd;                               140   delete bkgColCmd;
155   delete rayDirectory;                            141   delete rayDirectory;
156 }                                                 142 }
157                                                   143 
158 G4String G4RTMessenger::GetCurrentValue(G4UIco    144 G4String G4RTMessenger::GetCurrentValue(G4UIcommand * command)
159 {                                                 145 {
160   G4String currentValue;                          146   G4String currentValue;
161   if(command==columnCmd)                          147   if(command==columnCmd)
162   { currentValue = columnCmd->ConvertToString(    148   { currentValue = columnCmd->ConvertToString(theTracer->GetNColumn()); }
163   else if(command==rowCmd)                        149   else if(command==rowCmd)
164   { currentValue = rowCmd->ConvertToString(the    150   { currentValue = rowCmd->ConvertToString(theTracer->GetNRow()); }
165   else if(command==targetCmd)                     151   else if(command==targetCmd)
166   { currentValue = targetCmd->ConvertToString(    152   { currentValue = targetCmd->ConvertToString(theTracer->GetTargetPosition(),"m"); }
167   else if(command==eyePosCmd)                     153   else if(command==eyePosCmd)
168   { currentValue = eyePosCmd->ConvertToString(    154   { currentValue = eyePosCmd->ConvertToString(theTracer->GetEyePosition(),"m"); }
169   else if(command==lightCmd)                      155   else if(command==lightCmd)
170   { currentValue = lightCmd->ConvertToString(t    156   { currentValue = lightCmd->ConvertToString(theTracer->GetLightDirection()); }
171   else if(command==spanXCmd)                      157   else if(command==spanXCmd)
172   { currentValue = spanXCmd->ConvertToString(t    158   { currentValue = spanXCmd->ConvertToString(theTracer->GetViewSpan(),"deg"); }
173   else if(command==headCmd)                       159   else if(command==headCmd)
174   { currentValue = headCmd->ConvertToString(th    160   { currentValue = headCmd->ConvertToString(theTracer->GetHeadAngle(),"deg"); }
175   else if(command==attCmd)                        161   else if(command==attCmd)
176   { currentValue = attCmd->ConvertToString(the    162   { currentValue = attCmd->ConvertToString(theTracer->GetAttenuationLength(),"m");}
177   else if(command==distCmd)                       163   else if(command==distCmd)
178   { currentValue = distCmd->ConvertToString(th    164   { currentValue = distCmd->ConvertToString(theTracer->GetDistortion()); }
179   else if(command==transCmd)                      165   else if(command==transCmd)
180   { currentValue = transCmd->ConvertToString(G << 166   { currentValue = transCmd->ConvertToString(theSteppingAction->GetIgnoreTransparency()); }
181   else if(command==bkgColCmd)                     167   else if(command==bkgColCmd)
182   { currentValue = bkgColCmd->ConvertToString(    168   { currentValue = bkgColCmd->ConvertToString(theTracer->GetBackgroundColour()); }
183   return currentValue;                            169   return currentValue;
184 }                                                 170 }
185                                                   171 
186 void G4RTMessenger::SetNewValue(G4UIcommand *     172 void G4RTMessenger::SetNewValue(G4UIcommand * command,G4String newValue)
187 {                                                 173 {
188   G4VisManager* pVisManager = G4VisManager::Ge << 
189                                                << 
190   theTracer = theDefaultTracer;                << 
191                                                << 
192   G4VViewer* pVViewer = pVisManager->GetCurren << 
193   if (pVViewer) {                              << 
194     G4RayTracerViewer* pViewer = dynamic_cast< << 
195     if (pViewer) {                             << 
196       theTracer = pViewer->GetTracer();        << 
197     } else {                                   << 
198       G4warn <<                                << 
199   "G4RTMessenger::SetNewValue: Current viewer  << 
200   "\n  Use \"/vis/viewer/select\" or \"/vis/op << 
201        << G4endl;                              << 
202     }                                          << 
203   }                                            << 
204                                                << 
205   if (theTracer == theDefaultTracer) {         << 
206     G4warn <<                                  << 
207 "G4RTMessenger::SetNewValue: No valid current  << 
208      << G4endl;                                << 
209   }                                            << 
210                                                << 
211   if(command==columnCmd)                          174   if(command==columnCmd)
212   { theTracer->SetNColumn(columnCmd->GetNewInt    175   { theTracer->SetNColumn(columnCmd->GetNewIntValue(newValue)); }
213   else if(command==rowCmd)                        176   else if(command==rowCmd)
214   { theTracer->SetNRow(rowCmd->GetNewIntValue(    177   { theTracer->SetNRow(rowCmd->GetNewIntValue(newValue)); }
215   else if(command==targetCmd)                     178   else if(command==targetCmd)
216   { theTracer->SetTargetPosition(targetCmd->Ge    179   { theTracer->SetTargetPosition(targetCmd->GetNew3VectorValue(newValue)); }
217   else if(command==eyePosCmd)                     180   else if(command==eyePosCmd)
218   { theTracer->SetEyePosition(eyePosCmd->GetNe    181   { theTracer->SetEyePosition(eyePosCmd->GetNew3VectorValue(newValue)); }
219   else if(command==lightCmd)                      182   else if(command==lightCmd)
220   { theTracer->SetLightDirection(lightCmd->Get    183   { theTracer->SetLightDirection(lightCmd->GetNew3VectorValue(newValue)); }
221   else if(command==spanXCmd)                      184   else if(command==spanXCmd)
222   { theTracer->SetViewSpan(spanXCmd->GetNewDou    185   { theTracer->SetViewSpan(spanXCmd->GetNewDoubleValue(newValue)); }
223   else if(command==headCmd)                       186   else if(command==headCmd)
224   { theTracer->SetHeadAngle(headCmd->GetNewDou    187   { theTracer->SetHeadAngle(headCmd->GetNewDoubleValue(newValue)); }
225   else if(command==attCmd)                        188   else if(command==attCmd)
226   { theTracer->SetAttenuationLength(attCmd->Ge    189   { theTracer->SetAttenuationLength(attCmd->GetNewDoubleValue(newValue)); }
227   else if(command==distCmd)                       190   else if(command==distCmd)
228   { theTracer->SetDistortion(distCmd->GetNewBo    191   { theTracer->SetDistortion(distCmd->GetNewBoolValue(newValue)); }
229   else if(command==bkgColCmd)                     192   else if(command==bkgColCmd)
230   {                                            << 193   { theTracer->SetBackgroundColour(bkgColCmd->GetNew3VectorValue(newValue)); }
231   G4warn << "WARNING: /vis/rayTracer/backgroun << 
232   "\n  Use \"/vis/viewer/set/background\" inst << 
233     << G4endl;                                 << 
234   }                                            << 
235   else if(command==transCmd)                      194   else if(command==transCmd)
236   { G4RTSteppingAction::SetIgnoreTransparency( << 195   { theSteppingAction->SetIgnoreTransparency(transCmd->GetNewBoolValue(newValue)); }
237   else if(command==fileCmd)                       196   else if(command==fileCmd)
238   { theTracer->Trace(newValue); }                 197   { theTracer->Trace(newValue); }
239 }                                                 198 }
240                                                   199 
241                                                   200 
242                                                   201  
243                                                   202 
244                                                   203 
245                                                   204