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