Logo ROOT   6.12/07
Reference Guide
arrow_standalone.C
Go to the documentation of this file.
1 /// \file
2 /// \ingroup tutorial_eve
3 /// How to use EVE without the standard window.
4 /// Type
5 /// `gEve->GetBrowser()->MapWindow()`
6 /// to bring it up for object interaction, debugging, etc.
7 ///
8 /// \image html eve_arrow_standalone.png
9 /// \macro_code
10 ///
11 /// \author Matevz Tadel
12 
13 void arrow_standalone()
14 {
16 
17  // ----------------------------------------------------------------------
18 
19  TGMainFrame* mf = new TGMainFrame(gClient->GetRoot(), 800, 400,
21  mf->SetWindowName("Arrow Foo");
22 
23  // ----------------------------------------------------------------------
24 
25  TGCompositeFrame* evf = new TGCompositeFrame(mf, 400, 400);
26  mf->AddFrame(evf, new TGLayoutHints(kLHintsNormal |
28 
29  TGLEmbeddedViewer* ev = new TGLEmbeddedViewer(evf);
30  evf->AddFrame(ev->GetFrame(),
33 
34  TEveViewer* eve_v = new TEveViewer("YourViewer");
35  eve_v->SetGLViewer(ev, ev->GetFrame());
36  eve_v->IncDenyDestroy();
37  eve_v->AddScene(gEve->GetEventScene());
38  gEve->GetViewers()->AddElement(eve_v);
39 
40  // ----------------------------------------------------------------------
41 
42  // To create embedded canvas ... no menus on top.
43 
44  // TRootEmbeddedCanvas* ec =
45  // new TRootEmbeddedCanvas("EmbeddedCanvas", mf, 400, 400);
46  // mf->AddFrame(ec, new TGLayoutHints(kLHintsNormal |
47  // kLHintsExpandX | kLHintsExpandY));
48 
49  // --------------------------------
50 
51  // This one is tricky - must be after embedded canvas but before std canvas!
52  mf->MapSubwindows();
53 
54  // --------------------------------
55 
56  // To create full canvas with menus.
57 
58  mf->SetEditable();
59  TCanvas* c = new TCanvas("Foo", "Bar", 400, 400);
60  mf->SetEditable(kFALSE);
61 
62  // ----------------------------------------------------------------------
63 
64  mf->Layout();
65  mf->MapWindow();
66 
67  // ----------------------------------------------------------------------
68 
69  // Populate the viewer ... here we just call the arrow.C.
70 
71  TEveUtil::Macro("arrow.C");
72 }
TGCompositeFrame * GetFrame() const
void SetWindowName(const char *name=0)
Set window name. This is typically done via the window manager.
Definition: TGFrame.cxx:1746
void IncDenyDestroy()
Increases the deny-destroy count of the element.
#define gClient
Definition: TGClient.h:166
virtual void Layout()
Layout the elements of the composite frame.
Definition: TGFrame.cxx:1239
Minimal GL-viewer that can be embedded in a standard ROOT frames.
void SetGLViewer(TGLViewer *viewer, TGFrame *frame)
Set TGLViewer that is represented by this object.
Definition: TEveViewer.cxx:143
TEveViewerList * GetViewers() const
Definition: TEveManager.h:145
static TEveManager * Create(Bool_t map_window=kTRUE, Option_t *opt="FIV")
If global TEveManager* gEve is not set initialize it.
R__EXTERN TEveManager * gEve
Definition: TEveManager.h:243
const Bool_t kFALSE
Definition: RtypesCore.h:88
The Canvas class.
Definition: TCanvas.h:31
TEveScene * GetEventScene() const
Definition: TEveManager.h:148
static void Macro(const char *mac)
Execute macro 'mac'. Do not reload the macro.
Definition: TEveUtil.cxx:168
virtual void AddFrame(TGFrame *f, TGLayoutHints *l=0)
Add frame to the composite frame using the specified layout hints.
Definition: TGFrame.cxx:1099
virtual void MapSubwindows()
Map all sub windows that are part of the composite frame.
Definition: TGFrame.cxx:1146
virtual void MapWindow()
Definition: TGFrame.h:251
virtual void AddElement(TEveElement *el)
Call base-class implementation.
Definition: TEveViewer.cxx:358
virtual void SetEditable(Bool_t on=kTRUE)
Switch ON/OFF edit mode.
Definition: TGFrame.cxx:930
Eve representation of TGLViewer.
Definition: TEveViewer.h:30
virtual void AddScene(TEveScene *scene)
Add 'scene' to the list of scenes.
Definition: TEveViewer.cxx:261