Geant4 10.7.0
Toolkit for the simulation of the passage of particles through matter
Loading...
Searching...
No Matches
G4OpenInventorXt.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//
28//
29// Jeff Kallenbach 01 Aug 1996
30// OpenInventor graphics system factory.
31
32#ifdef G4VIS_BUILD_OIX_DRIVER
33
34// this :
35#include "G4OpenInventorXt.hh"
36
37#include <Inventor/Xt/SoXt.h>
38
39#include "G4Xt.hh"
42
43// Work around for gcc8 Coverity cast warning
44inline bool soxt_dispatch_event(void* a_event) {
45 return SoXt::dispatchEvent((XEvent*)a_event);
46}
47
49:G4OpenInventor("OpenInventorXt","OIX",G4VGraphicsSystem::threeD)
50,fInited(false)
51{
52}
53
54void G4OpenInventorXt::Initialize()
55{
56 if(fInited) return; //Done
57
58 SetInteractorManager (G4Xt::getInstance ());
60 RemoveDispatcher(G4Xt::xt_dispatch_event);
61 // Coverity gcc8 cast warning
62 // RemoveDispatcher((G4DispatchFunction)XtDispatchEvent);
64 AddDispatcher(soxt_dispatch_event);
65 // Coverity gcc8 cast warning
66 // AddDispatcher ((G4DispatchFunction)SoXt::dispatchEvent);
67
68 Widget top = (Widget)GetInteractorManager()->GetMainInteractor();
69
70 if(std::getenv("XENVIRONMENT")==NULL) {
71 XrmDatabase database = XrmGetDatabase(XtDisplay(top));
72 if(database!=NULL) {
73 XrmPutLineResource(&database,"*topShadowColor:white");
74 XrmPutLineResource(&database,"*bottomShadowColor:black");
75 XrmPutLineResource(&database,"*foreground:black");
76 XrmPutLineResource(&database,"*background:lightgrey");
77 XrmPutLineResource(&database,"*borderColor:lightgrey");
78 XrmPutLineResource(&database,"*fontList:-*-helvetica-bold-r-*-*-*-120-*-*-*-*-iso8859-1");
79 XrmPutLineResource(&database,"*help_popup.title:Help");
80 XrmPutLineResource(&database,"*helpCancel.labelString:Cancel");
81 XrmPutLineResource(&database,"*helpText.editMode:multi_line_edit");
82 XrmPutLineResource(&database,"*helpText.columns:60");
83 XrmPutLineResource(&database,"*helpText.rows:20");
84 XrmPutLineResource(&database,"*helpText.background:white");
85 XrmPutLineResource(&database,"*helpText.fontList:*courier*-r-*--14-*");
86 XrmPutLineResource(&database,"*helpText.maxLength:8000");
87 }
88 }
89
90 if(!SoXt::getTopLevelWidget()) SoXt::init(top);
91
92 InitNodes();
93
94 fInited = true;
95}
96
99{
100 Initialize();
101 G4OpenInventorSceneHandler* pScene = (G4OpenInventorSceneHandler*)&scene;
102 return new G4OpenInventorXtViewer (*pScene, name);
103}
104
105
106#endif
virtual ~G4OpenInventorXt()
G4VViewer * CreateViewer(G4VSceneHandler &, const G4String &name="")
void SetInteractorManager(G4VInteractorManager *)
G4VInteractorManager * GetInteractorManager()
G4Interactor GetMainInteractor()