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 // Jeff Kallenbach 01 Aug 1996 29 // Jeff Kallenbach 01 Aug 1996 30 // OpenInventor graphics system factory. 30 // OpenInventor graphics system factory. 31 // Frederick Jones and TJR October 2012 31 // Frederick Jones and TJR October 2012 32 // Extended driver based on G4OpenInventorXt.h 32 // Extended driver based on G4OpenInventorXt.hh 33 // Uses G4OpenInventorXtExaminerViewer. 33 // Uses G4OpenInventorXtExaminerViewer. 34 34 >> 35 #ifdef G4VIS_BUILD_OIX_DRIVER >> 36 35 // this : 37 // this : 36 #include "G4OpenInventorXtExtended.hh" 38 #include "G4OpenInventorXtExtended.hh" 37 39 38 #include <Inventor/Xt/SoXt.h> 40 #include <Inventor/Xt/SoXt.h> 39 41 40 #include "G4Xt.hh" 42 #include "G4Xt.hh" 41 #include "G4OpenInventorSceneHandler.hh" 43 #include "G4OpenInventorSceneHandler.hh" 42 #include "G4OpenInventorXtExtendedViewer.hh" 44 #include "G4OpenInventorXtExtendedViewer.hh" 43 #include "G4OpenInventorXtExaminerViewerMessen 45 #include "G4OpenInventorXtExaminerViewerMessenger.hh" 44 46 45 // Work around for gcc8 Coverity cast warning 47 // Work around for gcc8 Coverity cast warning 46 inline bool soxt_dispatch_event(void* a_event) 48 inline bool soxt_dispatch_event(void* a_event) { 47 return SoXt::dispatchEvent((XEvent*)a_event 49 return SoXt::dispatchEvent((XEvent*)a_event); 48 } 50 } 49 51 50 G4OpenInventorXtExtended::G4OpenInventorXtExte 52 G4OpenInventorXtExtended::G4OpenInventorXtExtended () 51 :G4OpenInventor("OpenInventorXtExtended","OIXE 53 :G4OpenInventor("OpenInventorXtExtended","OIXE",G4VGraphicsSystem::threeD) 52 ,fInited(false) 54 ,fInited(false) 53 { 55 { 54 G4OpenInventorXtExaminerViewerMessenger::Ge 56 G4OpenInventorXtExaminerViewerMessenger::GetInstance(); 55 } 57 } 56 58 57 void G4OpenInventorXtExtended::Initialize() 59 void G4OpenInventorXtExtended::Initialize() 58 { 60 { 59 // G4cout << "DEBUG G4OpenInventorXtExtended 61 // G4cout << "DEBUG G4OpenInventorXtExtended::Initialize() CALLED" << G4endl; 60 if(fInited) return; //Done 62 if(fInited) return; //Done 61 63 62 SetInteractorManager (G4Xt::getInstance ()); 64 SetInteractorManager (G4Xt::getInstance ()); 63 GetInteractorManager () -> 65 GetInteractorManager () -> 64 RemoveDispatcher(G4Xt::xt_dispatch_event) 66 RemoveDispatcher(G4Xt::xt_dispatch_event); 65 // Coverity gcc8 cast warning 67 // Coverity gcc8 cast warning 66 // RemoveDispatcher((G4DispatchFunction)X 68 // RemoveDispatcher((G4DispatchFunction)XtDispatchEvent); 67 GetInteractorManager () -> 69 GetInteractorManager () -> 68 AddDispatcher(soxt_dispatch_event); 70 AddDispatcher(soxt_dispatch_event); 69 // Coverity gcc8 cast warning 71 // Coverity gcc8 cast warning 70 // AddDispatcher ((G4DispatchFunction)S 72 // AddDispatcher ((G4DispatchFunction)SoXt::dispatchEvent); 71 73 72 Widget top = (Widget)GetInteractorManager()- 74 Widget top = (Widget)GetInteractorManager()->GetMainInteractor(); 73 G4cout << "TOP LEVEL WIDGET FOR SoXt::init() 75 G4cout << "TOP LEVEL WIDGET FOR SoXt::init() = " << top << G4endl; 74 76 75 if(std::getenv("XENVIRONMENT")==NULL) { 77 if(std::getenv("XENVIRONMENT")==NULL) { 76 XrmDatabase database = XrmGetDatabase(XtDi 78 XrmDatabase database = XrmGetDatabase(XtDisplay(top)); 77 if(database!=NULL) { 79 if(database!=NULL) { 78 XrmPutLineResource(&database,"*topShadow 80 XrmPutLineResource(&database,"*topShadowColor:white"); 79 XrmPutLineResource(&database,"*bottomSha 81 XrmPutLineResource(&database,"*bottomShadowColor:black"); 80 XrmPutLineResource(&database,"*foregroun 82 XrmPutLineResource(&database,"*foreground:black"); 81 XrmPutLineResource(&database,"*backgroun 83 XrmPutLineResource(&database,"*background:lightgrey"); 82 XrmPutLineResource(&database,"*borderCol 84 XrmPutLineResource(&database,"*borderColor:lightgrey"); 83 XrmPutLineResource(&database,"*fontList: 85 XrmPutLineResource(&database,"*fontList:-*-helvetica-bold-r-*-*-*-120-*-*-*-*-iso8859-1"); 84 XrmPutLineResource(&database,"*help_popu 86 XrmPutLineResource(&database,"*help_popup.title:Help"); 85 XrmPutLineResource(&database,"*helpCance 87 XrmPutLineResource(&database,"*helpCancel.labelString:Cancel"); 86 XrmPutLineResource(&database,"*helpText. 88 XrmPutLineResource(&database,"*helpText.editMode:multi_line_edit"); 87 XrmPutLineResource(&database,"*helpText. 89 XrmPutLineResource(&database,"*helpText.columns:60"); 88 XrmPutLineResource(&database,"*helpText. 90 XrmPutLineResource(&database,"*helpText.rows:20"); 89 XrmPutLineResource(&database,"*helpText. 91 XrmPutLineResource(&database,"*helpText.background:white"); 90 XrmPutLineResource(&database,"*helpText. 92 XrmPutLineResource(&database,"*helpText.fontList:*courier*-r-*--14-*"); 91 XrmPutLineResource(&database,"*helpText. 93 XrmPutLineResource(&database,"*helpText.maxLength:8000"); 92 } 94 } 93 } 95 } 94 96 95 if(!SoXt::getTopLevelWidget()) SoXt::init(to 97 if(!SoXt::getTopLevelWidget()) SoXt::init(top); 96 98 97 InitNodes(); 99 InitNodes(); 98 100 99 fInited = true; 101 fInited = true; 100 } 102 } 101 103 102 G4OpenInventorXtExtended::~G4OpenInventorXtExt 104 G4OpenInventorXtExtended::~G4OpenInventorXtExtended () {} 103 105 104 G4VViewer* G4OpenInventorXtExtended::CreateVie 106 G4VViewer* G4OpenInventorXtExtended::CreateViewer (G4VSceneHandler& scene, const G4String& name) 105 { 107 { 106 // FWJ 108 // FWJ 107 // Initialize(); 109 // Initialize(); 108 G4OpenInventorSceneHandler* pScene = (G4Open 110 G4OpenInventorSceneHandler* pScene = (G4OpenInventorSceneHandler*)&scene; 109 return new G4OpenInventorXtExtendedViewer (* 111 return new G4OpenInventorXtExtendedViewer (*pScene, name); 110 } 112 } >> 113 >> 114 >> 115 #endif 111 116