1 #ifndef AliTPCCalibViewerGUItime_H
2 #define AliTPCCalibViewerGUItime_H
4 /* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
5 * See cxx source for full Copyright notice */
7 /* $Id: AliTPCCalibViewerGUI.h,v */
9 ///////////////////////////////////////////////////////////////////////////////
11 // GUI for displaying calibration entires over time //
12 // Calibration Trees are created using the macro TPC/CalibMacros/CalibEnv.C //
13 // used for the calibration monitor //
15 ///////////////////////////////////////////////////////////////////////////////
25 // #include <TGButton.h>
26 // #include <TGListBox.h>
27 // #include <TGComboBox.h>
28 // #include <TGNumberEntry.h>
29 // #include <TRootEmbeddedCanvas.h>
30 // #include <TGSplitter.h>
31 // #include <TGButtonGroup.h>
32 // #include <TGLabel.h>
37 class TGCompositeFrame;
38 class TRootEmbeddedCanvas;
55 class AliTPCCalibViewerGUI;
56 class AliTPCConfigParser;
60 class AliTPCCalibViewerGUItime : public TGCompositeFrame {
62 AliTPCCalibViewerGUItime(const TGWindow *p, UInt_t w, UInt_t h);
63 virtual ~AliTPCCalibViewerGUItime();
65 static TObjArray* ShowGUI(const char* fileName = 0, const char* treeName="dcs"); // initialize and show GUI standalone
66 static TObjArray* ShowGUI(TChain* chain); // initialize and show GUI standalone
68 void DrawGUI(const TGWindow */*p*/, UInt_t w, UInt_t h);
70 void UseFile(const char* fileName, const char* treeName);
71 void UseChain(TChain *chain);
72 void UseConfigFile(const char* file="");
73 void Reload(Int_t first=1);
74 void AddReferenceTree(const char* treeFileName, const char* refName="R");
77 void SetCalibViewerGUI(AliTPCCalibViewerGUI *gui) {fCalibViewerGUI=gui;}
78 void SetCalibViewerGUItab(TGTabElement *tab) {fCalibViewerGUItab=tab;}
79 void SetCacheDir(const char* cachedir) {fOutputCacheDir=cachedir;}
80 void SetConfigFileName(const char* file) {fConfigFile=file;}
82 const char* GetDrawString();
83 const char* GetDrawOption();
84 void GetCutString(TString &cutStr);
85 TChain* GetChain() const {return fTree;}
90 void DoCustomCutsDraw();
91 void DoParLimitChange();
92 void DoNewSelection(); // decides whether to redraw if user makes another selection
93 void DoChangeSelectionList() {Reload(0);}
94 void HandleButtonsDrawSel(Int_t id = -1);
95 void MouseMove(Int_t event, Int_t x, Int_t y, TObject */*selected*/);
98 TFile* fFile; //file that keeps the tree
99 TChain* fTree; //internal tree
100 AliTPCCalibViewerGUI *fCalibViewerGUI; //calib viewer gui used to display verbose information for one run
101 TGTabElement *fCalibViewerGUItab; //tab the calib view gui redies in
102 TH1* fCurrentHist; //histogram currently drawn in main canvas
103 TGraph* fCurrentGraph; //current graph
104 Int_t fCurrentRunDetails; //run number for wich details are currently shown
105 TString fOutputCacheDir; //output cache diretory for AliTPCCalibViewerGUI trees, created on the fly
106 TString fDrawString; //current draw string
107 TString fConfigFile; //configuration file keeping active branches and branch descriptions
108 AliTPCConfigParser *fConfigParser; //configuration parser
109 Bool_t fIsCustomDraw; //if custom draw string is selected
110 TVectorD fRunNumbers; //run numbers of current selection
111 TVectorD fTimeStamps; //timr stamps of current selection
112 TVectorD fValuesX; //values of current selection
113 TVectorD fValuesY; //values of current selection
115 Bool_t fNoGraph; //Whether to create a graph
116 Long64_t fGraphLimitEntries; //limit in number of entries in the chain for producing a graph
118 TMap *fMapRefTrees; //map of reference trees for the CalibViewer
120 //main canvas Top part, bottom part
121 TGCompositeFrame *fContTopBottom; // container for all GUI elements, vertical divided
122 //top left, centre, right
123 TGCompositeFrame *fContLCR; // container for all GUI elements, horizontal divided
125 TGCompositeFrame *fContLeft; // container for GUI elements on left side
126 TGGroupFrame *fContDrawOpt; // Subgroup for draw selection
127 TGCheckButton *fChkDrawOptSame; // draw option 'same'
128 TGComboBox *fComboAddDrawOpt; // additional draw options combo box
129 TGGroupFrame *fContDrawSel; // Subgroup for draw selection
130 TGCompositeFrame *fContDrawSelSubRunTime; //Radio button subframe
131 TGRadioButton *fRadioXhist; // Radio button x-variable: show only 1D distribution
132 TGRadioButton *fRadioXrun; // Radio button x-variable: run
133 TGRadioButton *fRadioXtime; // Radio button x-variable: time
134 TGListBox *fListVariables; // listbox with possible variables
135 TGComboBox *fComboRunType; // run type selection box
136 TGLabel *fLblRunType; // run type label
137 TGNumberEntry *fNmbPar; // parameter number
138 TGLabel *fLblPar; // parameter name
139 TGListBox *fListCalibType; // calibration type selection box
140 TGGroupFrame *fContCalibType; // calibration type label
142 TGCompositeFrame *fContCenter; // container for GUI elements at the center
143 TRootEmbeddedCanvas *fCanvMain; // main drawing canvas
145 TGCompositeFrame *fContRight; // container for GUI elements on right side
146 TGGroupFrame *fContValues; // container to keep data point information
147 TGLabel *fLblRunNumber; // run number label
148 TGLabel *fLblRunTime; // time stamp label
149 TGLabel *fLblValueX; // value label
150 TGLabel *fLblValueY; // value label
151 TGLabel *fLblRunNumberVal; // run number of the data point hoovered
152 TGLabel *fLblRunTimeVal; // time stamp of the data point hoovered
153 TGLabel *fLblValueXVal; // value of the data point hoovered
154 TGLabel *fLblValueYVal; // value of the data point hoovered
155 TGTextButton *fBtnDumpRuns; // draw button
157 TGCompositeFrame *fContCustom; // container for custom draw command GUI elements
158 TGCompositeFrame *fContCustomCuts; // container for custom cut options GUI elements
159 TGLabel *fLblCustomDraw; // label for custom draw string
160 TGLabel *fLblCustomCuts; // label for custom cuts string
161 TGComboBox *fComboCustomDraw; // combo box custom draw string
162 TGComboBox *fComboCustomCuts; // combo box custom cuts string
164 TObjArray *fTrashBox; //graphics objects to be deleted (histograms, graphs,...)
166 enum { kRadioXhist=10, kRadioXrun=11, kRadioXtime=12 };
167 enum { kBranchOnOff=0, kBranchTitle=1, kCalibType=2, kParamNames=3 };
169 void UpdateParLimits();
170 void UpdateParName();
171 void SetGuiTree(Int_t run);
173 void FillCalibTypes();
174 void SetInitialValues();
175 void CheckDrawGraph();
177 void UpdateValueArrays(Bool_t withGraph);
178 const char* SubstituteUnderscores(const char* in);
179 void GetHistogramTitle(TString &title);
182 AliTPCCalibViewerGUItime(const AliTPCCalibViewerGUItime &v);
183 AliTPCCalibViewerGUItime &operator = (const AliTPCCalibViewerGUItime &v); // assignment operator
185 ClassDef(AliTPCCalibViewerGUItime, 0)