Geant4 Cross Reference |
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 // 27 // 28 // 28 // 29 // Created: Mar. 31, 2009 Akinori Kimura 29 // Created: Mar. 31, 2009 Akinori Kimura 30 // 30 // 31 31 32 32 33 #define __G_ANSI_C__ 33 #define __G_ANSI_C__ 34 #define G4GMocrenFile_STRUCTURE_PRIORITY 1. 34 #define G4GMocrenFile_STRUCTURE_PRIORITY 1. 35 35 36 #include "G4ios.hh" 36 #include "G4ios.hh" 37 #include <cstdio> 37 #include <cstdio> 38 #include <cstring> 38 #include <cstring> 39 #include <cassert> 39 #include <cassert> 40 40 41 #include "G4VisManager.hh" 41 #include "G4VisManager.hh" 42 #include "G4Scene.hh" 42 #include "G4Scene.hh" 43 #include "G4Vector3D.hh" 43 #include "G4Vector3D.hh" 44 #include "G4VisExtent.hh" 44 #include "G4VisExtent.hh" 45 #include "G4LogicalVolume.hh" 45 #include "G4LogicalVolume.hh" 46 #include "G4VSolid.hh" 46 #include "G4VSolid.hh" 47 47 48 #include "G4GMocrenFile.hh" 48 #include "G4GMocrenFile.hh" 49 #include "G4GMocrenFileSceneHandler.hh" 49 #include "G4GMocrenFileSceneHandler.hh" 50 #include "G4GMocrenFileViewer.hh" 50 #include "G4GMocrenFileViewer.hh" 51 #include "G4GMocrenMessenger.hh" 51 #include "G4GMocrenMessenger.hh" 52 52 53 53 54 //----- constants 54 //----- constants 55 55 56 //-- for a debugging 56 //-- for a debugging 57 const G4bool GFDEBUG = false; 57 const G4bool GFDEBUG = false; 58 58 59 //----- G4GMocrenFileViewer, constructor 59 //----- G4GMocrenFileViewer, constructor 60 G4GMocrenFileViewer::G4GMocrenFileViewer (G4GM 60 G4GMocrenFileViewer::G4GMocrenFileViewer (G4GMocrenFileSceneHandler& sceneHandler, 61 G4GMocrenMessenger &, 61 G4GMocrenMessenger &, 62 const G4String& name) 62 const G4String& name) 63 : G4VViewer (sceneHandler, sceneHandler.Incr 63 : G4VViewer (sceneHandler, sceneHandler.IncrementViewCount (), name), 64 kSceneHandler (sceneHandler) 64 kSceneHandler (sceneHandler) 65 { 65 { 66 // Set a g4.gdd-file viewer 66 // Set a g4.gdd-file viewer 67 std::strncpy( kG4GddViewer, "gMocren", 8); 67 std::strncpy( kG4GddViewer, "gMocren", 8); 68 if( std::getenv( "G4GMocrenFile_VIEWER" ) != 68 if( std::getenv( "G4GMocrenFile_VIEWER" ) != NULL ) { 69 char * env = std::getenv( "G4GMocrenFile_V 69 char * env = std::getenv( "G4GMocrenFile_VIEWER" ); 70 G4int len = (G4int)std::strlen(env); << 70 G4int len = std::strlen(env); 71 if(len >= 32) { 71 if(len >= 32) { 72 G4Exception("G4GMocrenFileViewer::G4GMoc 72 G4Exception("G4GMocrenFileViewer::G4GMocrenFileViewer(*)", 73 "gMocren1000", FatalExceptio 73 "gMocren1000", FatalException, 74 "Invalid length of string se 74 "Invalid length of string set in G4GMocrenFile_VIEWER"); 75 } 75 } 76 std::strncpy( kG4GddViewer, env, sizeof(kG 76 std::strncpy( kG4GddViewer, env, sizeof(kG4GddViewer) - 1); 77 kG4GddViewer[sizeof(kG4GddViewer) - 1] = ' 77 kG4GddViewer[sizeof(kG4GddViewer) - 1] = '\0'; 78 //std::strcpy( kG4GddViewer, getenv( "G4GM 78 //std::strcpy( kG4GddViewer, getenv( "G4GMocrenFile_VIEWER" ) ) ; 79 } 79 } 80 80 81 // string for viewer invocation 81 // string for viewer invocation 82 if ( !std::strcmp( kG4GddViewer, "NONE" ) ) 82 if ( !std::strcmp( kG4GddViewer, "NONE" ) ) { 83 83 84 //std::strcpy( kG4GddViewerInvocation, "" 84 //std::strcpy( kG4GddViewerInvocation, "" ); 85 kG4GddViewerInvocation[0] = '\0'; 85 kG4GddViewerInvocation[0] = '\0'; 86 } else { 86 } else { 87 87 88 std::strncpy( kG4GddViewerInvocation, kG4G 88 std::strncpy( kG4GddViewerInvocation, kG4GddViewer, 89 sizeof(kG4GddViewerInvocation 89 sizeof(kG4GddViewerInvocation) - 1); 90 kG4GddViewerInvocation[sizeof(kG4GddViewer 90 kG4GddViewerInvocation[sizeof(kG4GddViewerInvocation) - 1] = '\0'; 91 G4int n = sizeof(kG4GddViewerInvocation) 91 G4int n = sizeof(kG4GddViewerInvocation) 92 - (G4int)std::strlen(kG4GddViewerI << 92 - std::strlen(kG4GddViewerInvocation) - 1; 93 std::strncat( kG4GddViewerInvocation, " ", 93 std::strncat( kG4GddViewerInvocation, " ", n); 94 const char * gddfname = kSceneHandler.GetG 94 const char * gddfname = kSceneHandler.GetGddFileName(); 95 G4int len = (G4int)std::strlen(gddfname); << 95 G4int len = std::strlen(gddfname); 96 if(len >= 64) { 96 if(len >= 64) { 97 G4Exception("G4GMocrenFileViewer::G4GMoc 97 G4Exception("G4GMocrenFileViewer::G4GMocrenFileViewer(*)", 98 "gMocren1001", FatalExceptio 98 "gMocren1001", FatalException, 99 "Invalid length of the GDD f 99 "Invalid length of the GDD file name"); 100 } 100 } 101 n = sizeof(kG4GddViewerInvocation) 101 n = sizeof(kG4GddViewerInvocation) 102 - (G4int)std::strlen(kG4GddViewerInvocat << 102 - std::strlen(kG4GddViewerInvocation) - 1; 103 std::strncat( kG4GddViewerInvocation, gddf 103 std::strncat( kG4GddViewerInvocation, gddfname, n); 104 } 104 } 105 105 106 } 106 } 107 107 108 //----- G4GMocrenFileViewer, destructor 108 //----- G4GMocrenFileViewer, destructor 109 G4GMocrenFileViewer::~G4GMocrenFileViewer () 109 G4GMocrenFileViewer::~G4GMocrenFileViewer () 110 {} 110 {} 111 111 112 //----- G4GMocrenFileViewer::SetView () 112 //----- G4GMocrenFileViewer::SetView () 113 void G4GMocrenFileViewer::SetView () 113 void G4GMocrenFileViewer::SetView () 114 { 114 { 115 if(GFDEBUG) 115 if(GFDEBUG) 116 if (G4VisManager::GetVerbosity() >= G4VisM 116 if (G4VisManager::GetVerbosity() >= G4VisManager::errors) 117 G4cout << "***** G4GMocrenFileViewer::Se 117 G4cout << "***** G4GMocrenFileViewer::SetView(): No effects" << G4endl; 118 118 119 // Do nothing, since DAWN is running as a di 119 // Do nothing, since DAWN is running as a different process. 120 // SendViewParameters () will do this job in 120 // SendViewParameters () will do this job instead. 121 } 121 } 122 122 123 123 124 //----- G4GMocrenFileViewer::ClearView() 124 //----- G4GMocrenFileViewer::ClearView() 125 void 125 void 126 G4GMocrenFileViewer::ClearView( void ) 126 G4GMocrenFileViewer::ClearView( void ) 127 { 127 { 128 if(GFDEBUG) { << 128 if(GFDEBUG) 129 if (G4VisManager::GetVerbosity() >= G4VisM << 129 if (G4VisManager::GetVerbosity() >= G4VisManager::errors) 130 G4cout << "***** G4GMocrenFileViewer::Cl 130 G4cout << "***** G4GMocrenFileViewer::ClearView (): No effects " << G4endl; 131 } << 131 132 } << 133 //if(kSceneHandler.kGddDest) { 132 //if(kSceneHandler.kGddDest) { 134 //kSceneHandler.kGddDest.close(); 133 //kSceneHandler.kGddDest.close(); 135 // Re-open with same filename... 134 // Re-open with same filename... 136 //kSceneHandler.kGddDest.open(kSceneHandle 135 //kSceneHandler.kGddDest.open(kSceneHandler.kGddFileName); 137 kSceneHandler.kFlagInModeling = false; 136 kSceneHandler.kFlagInModeling = false; 138 kSceneHandler.GFBeginModeling(); 137 kSceneHandler.GFBeginModeling(); 139 //} 138 //} 140 } 139 } 141 140 142 141 143 //----- G4GMocrenFileViewer::DrawView () 142 //----- G4GMocrenFileViewer::DrawView () 144 void G4GMocrenFileViewer::DrawView () 143 void G4GMocrenFileViewer::DrawView () 145 { 144 { 146 if(GFDEBUG) 145 if(GFDEBUG) 147 if (G4VisManager::GetVerbosity() >= G4VisM 146 if (G4VisManager::GetVerbosity() >= G4VisManager::errors) 148 G4cout << "***** G4GMocrenFileViewer::Dr 147 G4cout << "***** G4GMocrenFileViewer::DrawView () " << G4endl; 149 148 150 //----- 149 //----- 151 kSceneHandler.GFBeginModeling() ; 150 kSceneHandler.GFBeginModeling() ; 152 151 153 //----- Always visit G4 kernel 152 //----- Always visit G4 kernel 154 NeedKernelVisit (); 153 NeedKernelVisit (); 155 154 156 //----- Draw 155 //----- Draw 157 G4VViewer::ProcessView () ; 156 G4VViewer::ProcessView () ; 158 157 159 } // G4GMocrenFileViewer::DrawView () 158 } // G4GMocrenFileViewer::DrawView () 160 159 161 160 162 161 163 //----- G4GMocrenFileViewer::ShowView() 162 //----- G4GMocrenFileViewer::ShowView() 164 void G4GMocrenFileViewer::ShowView( void ) 163 void G4GMocrenFileViewer::ShowView( void ) 165 { 164 { 166 if(GFDEBUG) 165 if(GFDEBUG) 167 if (G4VisManager::GetVerbosity() >= G4VisM 166 if (G4VisManager::GetVerbosity() >= G4VisManager::errors) 168 G4cout << "***** G4GMocrenFileViewer::Sh 167 G4cout << "***** G4GMocrenFileViewer::ShowView () " << G4endl; 169 168 170 if( kSceneHandler.GFIsInModeling() ) 169 if( kSceneHandler.GFIsInModeling() ) 171 { 170 { 172 //----- End of modeling 171 //----- End of modeling 173 // !EndModeling, !DrawAll, !CloseDevice, 172 // !EndModeling, !DrawAll, !CloseDevice, 174 // close g4.gdd 173 // close g4.gdd 175 kSceneHandler.GFEndModeling(); 174 kSceneHandler.GFEndModeling(); 176 175 177 //----- Output DAWN GUI file 176 //----- Output DAWN GUI file 178 //SendViewParameters(); 177 //SendViewParameters(); 179 178 180 //----- string for viewer invocation 179 //----- string for viewer invocation 181 if ( !strcmp( kG4GddViewer, "NONE" ) ) { 180 if ( !strcmp( kG4GddViewer, "NONE" ) ) { 182 181 183 kG4GddViewerInvocation[0] = '\0'; 182 kG4GddViewerInvocation[0] = '\0'; 184 //std::strcpy( kG4GddViewerInvocation, "" ); 183 //std::strcpy( kG4GddViewerInvocation, "" ); 185 } else { 184 } else { 186 185 187 std::strncpy( kG4GddViewerInvocation, 186 std::strncpy( kG4GddViewerInvocation, kG4GddViewer, 188 sizeof(kG4GddViewerInvoca 187 sizeof(kG4GddViewerInvocation) - 1); 189 kG4GddViewerInvocation[sizeof(kG4GddVi 188 kG4GddViewerInvocation[sizeof(kG4GddViewerInvocation) - 1] = '\0'; 190 G4int n = sizeof(kG4GddViewerInvocatio 189 G4int n = sizeof(kG4GddViewerInvocation) 191 - (G4int)std::strlen(kG4GddVie << 190 - std::strlen(kG4GddViewerInvocation) - 1; 192 std::strncat( kG4GddViewerInvocation, 191 std::strncat( kG4GddViewerInvocation, " ", n); 193 const char * gddfname = kSceneHandler. 192 const char * gddfname = kSceneHandler.GetGddFileName(); 194 G4int len = (G4int)std::strlen(gddfnam << 193 G4int len = std::strlen(gddfname); 195 if(len >= 64) { 194 if(len >= 64) { 196 G4Exception("G4GMocrenFileViewer::Sh 195 G4Exception("G4GMocrenFileViewer::ShowView()", 197 "gMocren1002", FatalExce 196 "gMocren1002", FatalException, 198 "Invalid length of the G 197 "Invalid length of the GDD file name"); 199 } 198 } 200 n = sizeof(kG4GddViewerInvocation) 199 n = sizeof(kG4GddViewerInvocation) 201 - (G4int)std::strlen(kG4GddViewerInv << 200 - std::strlen(kG4GddViewerInvocation) - 1; 202 std::strncat( kG4GddViewerInvocation, 201 std::strncat( kG4GddViewerInvocation, gddfname, n); 203 } 202 } 204 203 205 } 204 } 206 205 207 } // G4GMocrenFileViewer::ShowView() 206 } // G4GMocrenFileViewer::ShowView() 208 207 209 208