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 9.1.p3)


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