Geant4 11.1.1
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// this :
33#include "G4OpenInventorXt.hh"
34
35#include <Inventor/Xt/SoXt.h>
36
37#include "G4Xt.hh"
40
41// Work around for gcc8 Coverity cast warning
42inline bool soxt_dispatch_event(void* a_event) {
43 return SoXt::dispatchEvent((XEvent*)a_event);
44}
45
47:G4OpenInventor("OpenInventorXt","OIX",G4VGraphicsSystem::threeD)
48,fInited(false)
49{
50}
51
52void G4OpenInventorXt::Initialize()
53{
54 if(fInited) return; //Done
55
58 RemoveDispatcher(G4Xt::xt_dispatch_event);
59 // Coverity gcc8 cast warning
60 // RemoveDispatcher((G4DispatchFunction)XtDispatchEvent);
62 AddDispatcher(soxt_dispatch_event);
63 // Coverity gcc8 cast warning
64 // AddDispatcher ((G4DispatchFunction)SoXt::dispatchEvent);
65
66 Widget top = (Widget)GetInteractorManager()->GetMainInteractor();
67
68 if(std::getenv("XENVIRONMENT")==NULL) {
69 XrmDatabase database = XrmGetDatabase(XtDisplay(top));
70 if(database!=NULL) {
71 XrmPutLineResource(&database,"*topShadowColor:white");
72 XrmPutLineResource(&database,"*bottomShadowColor:black");
73 XrmPutLineResource(&database,"*foreground:black");
74 XrmPutLineResource(&database,"*background:lightgrey");
75 XrmPutLineResource(&database,"*borderColor:lightgrey");
76 XrmPutLineResource(&database,"*fontList:-*-helvetica-bold-r-*-*-*-120-*-*-*-*-iso8859-1");
77 XrmPutLineResource(&database,"*help_popup.title:Help");
78 XrmPutLineResource(&database,"*helpCancel.labelString:Cancel");
79 XrmPutLineResource(&database,"*helpText.editMode:multi_line_edit");
80 XrmPutLineResource(&database,"*helpText.columns:60");
81 XrmPutLineResource(&database,"*helpText.rows:20");
82 XrmPutLineResource(&database,"*helpText.background:white");
83 XrmPutLineResource(&database,"*helpText.fontList:*courier*-r-*--14-*");
84 XrmPutLineResource(&database,"*helpText.maxLength:8000");
85 }
86 }
87
88 if(!SoXt::getTopLevelWidget()) SoXt::init(top);
89
90 InitNodes();
91
92 fInited = true;
93}
94
97{
98 Initialize();
100 return new G4OpenInventorXtViewer (*pScene, name);
101}
bool soxt_dispatch_event(void *a_event)
virtual ~G4OpenInventorXt()
G4VViewer * CreateViewer(G4VSceneHandler &, const G4String &name="")
void SetInteractorManager(G4VInteractorManager *)
G4VInteractorManager * GetInteractorManager()
G4Interactor GetMainInteractor()
static G4Xt * getInstance()
Definition: G4Xt.cc:55
static bool xt_dispatch_event(void *a_event)
Definition: G4Xt.hh:58