Geant4  10.03
BrachyDetectorMessenger.cc
Go to the documentation of this file.
1 //
2 // ********************************************************************
3 // * License and Disclaimer *
4 // * *
5 // * The Geant4 software is copyright of the Copyright Holders of *
6 // * the Geant4 Collaboration. It is provided under the terms and *
7 // * conditions of the Geant4 Software License, included in the file *
8 // * LICENSE and available at http://cern.ch/geant4/license . These *
9 // * include a list of copyright holders. *
10 // * *
11 // * Neither the authors of this software system, nor their employing *
12 // * institutes,nor the agencies providing financial support for this *
13 // * work make any representation or warranty, express or implied, *
14 // * regarding this software system or assume any liability for its *
15 // * use. Please see the license in the file LICENSE and URL above *
16 // * for the full disclaimer and the limitation of liability. *
17 // * *
18 // * This code implementation is the result of the scientific and *
19 // * technical work of the GEANT4 collaboration. *
20 // * By using, copying, modifying or distributing the software (or *
21 // * any work based on the software) you agree to acknowledge its *
22 // * use in resulting scientific publications, and indicate your *
23 // * acceptance of all terms of the Geant4 Software license. *
24 // ********************************************************************
25 //
26 //
27 // Code developed by:
28 // S.Guatelli
29 //
30 // *********************************
31 // * *
32 // * BrachyDetectorMessenger.cc *
33 // * *
34 // *********************************
35 //
36 //
37 // $Id: BrachyDetectorMessenger.cc 100821 2016-11-02 15:21:34Z gcosmo $
38 //
39 //
40 
43 #include "G4UIdirectory.hh"
44 #include "G4UIcmdWithAString.hh"
45 
46 
48 {
49  detectorDir = new G4UIdirectory("/phantom/");
50  detectorDir -> SetGuidance(" phantom control.");
51 
52  phantomMaterialCmd = new G4UIcmdWithAString("/phantom/selectMaterial",this);
53  phantomMaterialCmd -> SetGuidance("Select Material of the phantom.");
54  phantomMaterialCmd -> SetParameterName("choice",false);
55  phantomMaterialCmd -> AvailableForStates(G4State_Idle);
56 
57  sourceCmd = new G4UIcmdWithAString("/source/switch",this);
58  sourceCmd -> SetGuidance("Assign the selected geometry to G4RunManager.");
59  sourceCmd -> SetParameterName("choice",true);
60  sourceCmd -> SetDefaultValue(" ");
61  sourceCmd -> SetCandidates("TG186 Flexi Iodine Leipzig");
62  sourceCmd -> AvailableForStates(G4State_PreInit,G4State_Idle);
63  }
64 
66 {
67  delete sourceCmd;
68  delete phantomMaterialCmd;
69  delete detectorDir;
70 }
71 
73 {
74  // Change the material of the phantom
75  if( command == phantomMaterialCmd )
76  { detector -> SetPhantomMaterial(newValue);}
77 
78  // Switch the source in the phantom
79  if( command == sourceCmd )
80  {
81  if(newValue=="Iodine" || newValue=="TG186"|| newValue=="Leipzig" || newValue== "Flexi")
82  {
83  detector -> SelectBrachytherapicSeed(newValue);
84  detector -> SwitchBrachytherapicSeed();
85  }
86  }
87 }
88 
BrachyDetectorMessenger(BrachyDetectorConstruction *)
G4UIcmdWithAString * phantomMaterialCmd
BrachyDetectorConstruction * detector
void SetNewValue(G4UIcommand *, G4String)
G4UIcmdWithAString * sourceCmd