Logo ROOT   6.10/09
Reference Guide
ntupleTableTest.C
Go to the documentation of this file.
1 /// \file
2 /// \ingroup tutorial_gui
3 /// This TableTest class is a simple example of how to use a TGTable with a TTreeTableInterface.
4 /// TableTest inherits from TGMainFrame to create a top level frame to embed the TGTable in.
5 /// First, the hsimple.root file is opened to obtain an ntuple. Then a TTreeTableInterface is created using this ntuple.
6 /// A table is then created using the interface.
7 /// In the end, the table is added to the TGMainFrame that is the TableTest and the necessary calls to correctly draw the window are made.
8 /// For more information about the use of TTreeTableInterface and TGTable, see their documentation.
9 ///
10 /// \macro_code
11 ///
12 /// \author Roel Aaij 13/07/2007
13 
14 #include <iostream>
15 #include <TApplication.h>
16 #include <TGClient.h>
17 #include <TGButton.h>
18 #include <TGFrame.h>
19 #include <TGWindow.h>
20 #include <TString.h>
21 #include <TGTable.h>
22 #include <TTreeTableInterface.h>
23 #include <TFile.h>
24 #include <TNtuple.h>
25 #include <TSelectorDraw.h>
26 
27 
28 // A little class to automatically handle the generation of unique
29 // widget ids.
30 class IDList {
31 private:
32  Int_t nID ; // Generates unique widget IDs.
33 public:
34  IDList() : nID(0) {}
35  ~IDList() {}
36  Int_t GetUnID(void) { return ++nID ; }
37 } ;
38 
39 class TableTest : public TGMainFrame {
40 
41 private:
42  IDList fIDs ; // Generator for unique widget IDs.
43  UInt_t fNTableRows;
44  UInt_t fNTableColumns;
45  TGTable *fTable;
46  TFile *fFile;
47 
48  TTreeTableInterface *fInterface;
49 
50 public:
51  TableTest(const TGWindow *p, UInt_t ntrows, UInt_t ntcols,
52  UInt_t w = 100, UInt_t h = 100) ;
53  virtual ~TableTest() ;
54 
55  void DoExit() ;
56 
57  TGTable *GetTable() { return fTable; }
58  TTreeTableInterface *GetInterface() { return fInterface; }
59 
60  ClassDef(TableTest, 0)
61 };
62 
63 TableTest::TableTest(const TGWindow *p, UInt_t ntrows, UInt_t ntcols,
64  UInt_t w, UInt_t h)
65  : TGMainFrame(p, w, h), fNTableRows(ntrows), fNTableColumns(ntcols),
66  fTable(0)
67 {
68  SetCleanup(kDeepCleanup) ;
69  Connect("CloseWindow()", "TableTest", this, "DoExit()") ;
70  DontCallClose() ;
71 
72  // Open root file for the tree
73  fFile = new TFile("$ROOTSYS/tutorials/hsimple.root");
74 
75  if (!fFile || fFile->IsZombie()) {
76  printf("Please run <ROOT location>/tutorials/hsimple.C first.");
77  return;
78  }
79 
80  // Get the ntuple from the file.
81  TNtuple *ntuple = (TNtuple *)fFile->Get("ntuple");
82 
83  // Setup the expressions for the columns and the selection of the
84  // interface.
85  TString varexp = "px:py:pz:random:sin(px):log(px/py):log(pz)";
86  TString select = "";
87  TString options = "";
88 
89  // Create the interface.
90  fInterface = new TTreeTableInterface(ntuple, varexp.Data(), select.Data(),
91  options.Data());
92 
93  // Create the table and add it to the TableTest that is a TGMainFrame.
94  fTable = new TGTable(this, fIDs.GetUnID(), fInterface, fNTableRows,
95  fNTableColumns);
96  AddFrame(fTable, new TGLayoutHints(kLHintsExpandX | kLHintsExpandY));
97 
98  // Calls to layout and draw the TableTest that is a TGMainFrame.
99  SetWindowName("Tree Table Test") ;
100  MapSubwindows() ;
101  Layout();
102  Resize(GetDefaultWidth()+20, 600) ;
103  MapWindow() ;
104 
105 } ;
106 
107 TableTest::~TableTest()
108 {
109  // Destructor
110  delete fInterface;
111  fFile->Close();
112  Cleanup() ;
113 }
114 
115  void TableTest::DoExit()
116 {
117  // Exit this application via the Exit button or Window Manager.
118  // Use one of the both lines according to your needs.
119  // Please note to re-run this macro in the same ROOT session,
120  // you have to compile it to get signals/slots 'on place'.
121 
122  DeleteWindow(); // to stay in the ROOT session
123  // gApplication->Terminate(); // to exit and close the ROOT session
124 }
125 
126 TGTable *ntupleTableTest(UInt_t ntrows = 50, UInt_t ntcols = 10) {
127  TableTest *test = new TableTest(0, ntrows, ntcols, 500, 200);
128  return test->GetTable();
129 }
TH1 * h
Definition: legend2.C:5
A ROOT file is a suite of consecutive data records (TKey instances) with a well defined format...
Definition: TFile.h:46
Definition: test.py:1
Basic string class.
Definition: TString.h:129
int Int_t
Definition: RtypesCore.h:41
#define ClassDef(name, id)
Definition: Rtypes.h:297
A simple TTree restricted to a list of float variables only.
Definition: TNtuple.h:28
unsigned int UInt_t
Definition: RtypesCore.h:42
RooCmdArg Layout(Double_t xmin, Double_t xmax=0.99, Double_t ymin=0.95)
TTreeTableInterface is used to interface to data that is stored in a TTree.
const char * Data() const
Definition: TString.h:347