File indexing completed on 2025-02-23 09:22:09
0001
0002
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013
0014
0015
0016
0017
0018
0019
0020
0021
0022
0023
0024
0025
0026
0027
0028
0029
0030
0031
0032
0033
0034
0035
0036
0037
0038
0039 #include "DetectorMessenger.hh"
0040
0041 #include "DetectorConstruction.hh"
0042
0043 #include "G4UIcmdWithADoubleAndUnit.hh"
0044 #include "G4UIcmdWithAString.hh"
0045
0046
0047
0048 DetectorMessenger::DetectorMessenger(DetectorConstruction* Det)
0049 : G4UImessenger(),
0050 fDetector(Det),
0051 fTestemDir(0),
0052 fDetDir(0),
0053 fMaterWorldCmd(0),
0054 fMaterCytoCmd(0),
0055 fMaterNuclCmd(0),
0056 fNuclRadiusCmd(0),
0057 fCytoThicknessCmd(0),
0058 fTrackingCutCmd(0)
0059 {
0060 fTestemDir = new G4UIdirectory("/svalue/");
0061 fTestemDir->SetGuidance("Detector control");
0062
0063 fDetDir = new G4UIdirectory("/svalue/det/");
0064 fDetDir->SetGuidance("Detector construction commands");
0065
0066 fMaterWorldCmd = new G4UIcmdWithAString("/svalue/det/setWorldMat", this);
0067 fMaterWorldCmd->SetGuidance("Select material of the World");
0068 fMaterWorldCmd->SetParameterName("choice", false);
0069 fMaterWorldCmd->AvailableForStates(G4State_PreInit, G4State_Idle);
0070 fMaterWorldCmd->SetToBeBroadcasted(false);
0071
0072 fMaterNuclCmd = new G4UIcmdWithAString("/svalue/det/setNuclMat", this);
0073 fMaterNuclCmd->SetGuidance("Select material of the nucleus");
0074 fMaterNuclCmd->SetParameterName("choice", false);
0075 fMaterNuclCmd->AvailableForStates(G4State_PreInit, G4State_Idle);
0076 fMaterNuclCmd->SetToBeBroadcasted(false);
0077
0078 fMaterCytoCmd = new G4UIcmdWithAString("/svalue/det/setCytoMat", this);
0079 fMaterCytoCmd->SetGuidance("Select material of the cytoplasm");
0080 fMaterCytoCmd->SetParameterName("choice", false);
0081 fMaterCytoCmd->AvailableForStates(G4State_PreInit, G4State_Idle);
0082 fMaterCytoCmd->SetToBeBroadcasted(false);
0083
0084 fNuclRadiusCmd = new G4UIcmdWithADoubleAndUnit("/svalue/det/setNuclRadius", this);
0085 fNuclRadiusCmd->SetGuidance("Set radius of the nucleus");
0086 fNuclRadiusCmd->SetParameterName("Radius", false);
0087 fNuclRadiusCmd->SetRange("Radius>0.");
0088 fNuclRadiusCmd->SetUnitCategory("Length");
0089 fNuclRadiusCmd->AvailableForStates(G4State_PreInit);
0090 fNuclRadiusCmd->SetToBeBroadcasted(false);
0091
0092 fCytoThicknessCmd = new G4UIcmdWithADoubleAndUnit("/svalue/det/setCytoThickness", this);
0093 fCytoThicknessCmd->SetGuidance("Set thickness of the cytoplasm");
0094 fCytoThicknessCmd->SetParameterName("Thickness", false);
0095 fCytoThicknessCmd->SetRange("Thickness>0.");
0096 fCytoThicknessCmd->SetUnitCategory("Length");
0097 fCytoThicknessCmd->AvailableForStates(G4State_PreInit);
0098 fCytoThicknessCmd->SetToBeBroadcasted(false);
0099
0100 fTrackingCutCmd = new G4UIcmdWithADoubleAndUnit("/svalue/det/setTrackingCut", this);
0101 fTrackingCutCmd->SetGuidance("Set tracking cut in the absorber");
0102 fTrackingCutCmd->SetParameterName("Cut", false);
0103 fTrackingCutCmd->SetRange("Cut>0.");
0104 fTrackingCutCmd->SetUnitCategory("Energy");
0105 fTrackingCutCmd->AvailableForStates(G4State_PreInit);
0106 fTrackingCutCmd->SetToBeBroadcasted(false);
0107 }
0108
0109
0110
0111 DetectorMessenger::~DetectorMessenger()
0112 {
0113 delete fMaterWorldCmd;
0114 delete fMaterCytoCmd;
0115 delete fMaterNuclCmd;
0116 delete fNuclRadiusCmd;
0117 delete fCytoThicknessCmd;
0118 delete fTrackingCutCmd;
0119 delete fDetDir;
0120 delete fTestemDir;
0121 }
0122
0123
0124
0125 void DetectorMessenger::SetNewValue(G4UIcommand* command, G4String newValue)
0126 {
0127 if (command == fMaterWorldCmd) {
0128 fDetector->SetWorldMaterial(newValue);
0129 }
0130
0131 if (command == fMaterCytoCmd) {
0132 fDetector->SetCytoMaterial(newValue);
0133 }
0134
0135 if (command == fMaterNuclCmd) {
0136 fDetector->SetNuclMaterial(newValue);
0137 }
0138
0139 if (command == fNuclRadiusCmd) {
0140 fDetector->SetNuclRadius(fNuclRadiusCmd->GetNewDoubleValue(newValue));
0141 }
0142
0143 if (command == fCytoThicknessCmd) {
0144 fDetector->SetCytoThickness(fCytoThicknessCmd->GetNewDoubleValue(newValue));
0145 }
0146
0147 if (command == fTrackingCutCmd) {
0148 fDetector->SetTrackingCut(fTrackingCutCmd->GetNewDoubleValue(newValue));
0149 }
0150 }