Logo ROOT  
Reference Guide
 
Loading...
Searching...
No Matches
splitterVertical.C
Go to the documentation of this file.
1/// \file
2/// \ingroup tutorial_gui
3/// This macro gives an example of how to create a vertical splitter.
4/// To run it do either:
5/// ~~~
6/// .x splitterVertical.C
7/// .x splitterVertical.C++
8/// ~~~
9///
10/// \macro_code
11///
12/// \author Ilka Antcheva 1/12/2006
13
14
15#include <TGClient.h>
16#include <TGButton.h>
17#include <TGLabel.h>
18#include <TGFrame.h>
19#include <TGLayout.h>
20#include <TGSplitter.h>
21
22
23class MyMainFrame : public TGMainFrame {
24
25public:
26 MyMainFrame(const TGWindow *p, UInt_t w, UInt_t h);
27 ~MyMainFrame() override;
28 void DoSave();
29 void CloseWindow() override;
30
31 ClassDefOverride(MyMainFrame, 0)
32};
33
34//______________________________________________________________________________
35void MyMainFrame::DoSave()
36{
37 Printf("Save in progress...");
38 SaveSource("","");
39}
40
41//______________________________________________________________________________
42MyMainFrame::MyMainFrame(const TGWindow *p, UInt_t w, UInt_t h) :
43 TGMainFrame(p, w, h)
44{
45 // Create vertical splitter
46
47 TGHorizontalFrame *fHf = new TGHorizontalFrame(this, 50, 50);
48
49 TGVerticalFrame *fV1 = new TGVerticalFrame(fHf, 10, 10, kFixedWidth);
50 TGVerticalFrame *fV2 = new TGVerticalFrame(fHf, 10, 10);
51 TGCompositeFrame *fFleft = new TGCompositeFrame(fV1, 10, 10, kSunkenFrame);
52 TGCompositeFrame *fFright = new TGCompositeFrame(fV2, 10, 10, kSunkenFrame);
53
54 TGLabel *fLleft = new TGLabel(fFleft, "Left Frame");
55 TGLabel *fLright = new TGLabel(fFright, "Right Frame");
56
58 3, 0, 0, 0));
59 fFright->AddFrame(fLright, new TGLayoutHints(kLHintsLeft | kLHintsCenterY,
60 3, 0, 0, 0));
61
63 0, 0, 5, 10));
65 0, 0, 5, 10));
66
67 fV1->Resize(fFleft->GetDefaultWidth()+20, fV1->GetDefaultHeight());
68 fV2->Resize(fFright->GetDefaultWidth(), fV1->GetDefaultHeight());
70
71 TGVSplitter *splitter = new TGVSplitter(fHf,2,2);
72 splitter->SetFrame(fV1, kTRUE);
73 fHf->AddFrame(splitter, new TGLayoutHints(kLHintsLeft | kLHintsExpandY));
74
77 AddFrame(fHf, new TGLayoutHints(kLHintsRight | kLHintsExpandX |
79
80 // button frame
81 TGVerticalFrame *vframe = new TGVerticalFrame(this, 10, 10);
82 TGCompositeFrame *cframe2 = new TGCompositeFrame(vframe, 170, 20,
84 TGTextButton *save = new TGTextButton(cframe2, "&Save");
86 3, 2, 2, 2));
87 save->Connect("Clicked()", "MyMainFrame", this, "DoSave()");
88 save->SetToolTipText("Click on the button to save the application as C++ macro");
89
90 TGTextButton *exit = new TGTextButton(cframe2, "&Exit ","gApplication->Terminate(0)");
92 2, 0, 2, 2));
93 vframe->AddFrame(cframe2, new TGLayoutHints(kLHintsExpandX, 2, 2, 5, 1));
94 AddFrame(vframe, new TGLayoutHints(kLHintsExpandX, 2, 2, 5, 1));
95
96 // What to clean up in destructor
97 SetCleanup(kDeepCleanup);
98
99 // Set a name to the main frame
100 SetWindowName("Vertical Splitter");
101 SetWMSizeHints(350, 200, 600, 400, 0, 0);
103 Resize(GetDefaultSize());
104 MapWindow();
105}
106
107
108//______________________________________________________________________________
109MyMainFrame::~MyMainFrame()
110{
111 // Clean up all widgets, frames and layouthints that were used
112 Cleanup();
113}
114
115//______________________________________________________________________________
116void MyMainFrame::CloseWindow()
117{
118 // Called when window is closed via the window manager.
119
120 delete this;
121}
122
123void splitterVertical()
124{
125 // Popup the GUI...
126 new MyMainFrame(gClient->GetRoot(), 350, 200);
127}
@ kSunkenFrame
Definition GuiTypes.h:383
@ kFixedWidth
Definition GuiTypes.h:387
@ kHorizontalFrame
Definition GuiTypes.h:382
#define h(i)
Definition RSha256.hxx:106
unsigned int UInt_t
Definition RtypesCore.h:46
constexpr Bool_t kTRUE
Definition RtypesCore.h:100
#define ClassDefOverride(name, id)
Definition Rtypes.h:341
#define gClient
Definition TGClient.h:156
@ kDeepCleanup
Definition TGFrame.h:42
@ kLHintsRight
Definition TGLayout.h:26
@ kLHintsExpandY
Definition TGLayout.h:31
@ kLHintsLeft
Definition TGLayout.h:24
@ kLHintsCenterY
Definition TGLayout.h:28
@ kLHintsTop
Definition TGLayout.h:27
@ kLHintsExpandX
Definition TGLayout.h:30
winID h TVirtualViewer3D TVirtualGLPainter p
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize MapSubwindows
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void char Point_t Rectangle_t SetWMSizeHints
void Printf(const char *fmt,...)
Formats a string in a circular formatting buffer and prints the string.
Definition TString.cxx:2503
virtual void SetToolTipText(const char *text, Long_t delayms=400)
Set tool tip text associated with this button.
Definition TGButton.cxx:445
The base class for composite widgets (menu bars, list boxes, etc.).
Definition TGFrame.h:287
virtual void AddFrame(TGFrame *f, TGLayoutHints *l=nullptr)
Add frame to the composite frame using the specified layout hints.
Definition TGFrame.cxx:1117
UInt_t GetDefaultWidth() const override
Definition TGFrame.h:312
UInt_t GetDefaultHeight() const override
Definition TGFrame.h:314
void Resize(UInt_t w=0, UInt_t h=0) override
Resize the frame.
Definition TGFrame.cxx:605
A composite frame that layout their children in horizontal way.
Definition TGFrame.h:385
This class handles GUI labels.
Definition TGLabel.h:24
This class describes layout hints used by the layout classes.
Definition TGLayout.h:50
Defines top level windows that interact with the system Window Manager.
Definition TGFrame.h:397
virtual void CloseWindow()
Close and delete main frame.
Definition TGFrame.cxx:1770
Yield an action as soon as it is clicked.
Definition TGButton.h:142
void SetFrame(TGFrame *frame, Bool_t left) override
Set frame to be resized.
A composite frame that layout their children in vertical way.
Definition TGFrame.h:374
ROOT GUI Window base class.
Definition TGWindow.h:23
Bool_t Connect(const char *signal, const char *receiver_class, void *receiver, const char *slot)
Non-static method is used to connect from the signal of this object to the receiver slot.
Definition TQObject.cxx:869