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* GetDrawOptionString();
84 const char* GetCustomDrawString() const {return fComboCustomDraw->GetTextEntry()?fComboCustomDraw->GetTextEntry()->GetText():"";}
85 void GetCutString(TString &cutStr);
86 TChain* GetChain() const {return fTree;}
91 void DoCustomCutsDraw();
92 void DoParLimitChange();
93 void DoNewSelection(); // decides whether to redraw if user makes another selection
94 void DoChangeSelectionList() {Reload(0);}
95 void HandleButtonsDrawSel(Int_t id = -1);
96 void MouseMove(Int_t event, Int_t x, Int_t y, TObject */*selected*/);
97 void DoNewSelectionAliases();
100 void UpdateAliasList();
103 TFile* fFile; //file that keeps the tree
104 TChain* fTree; //internal tree
105 AliTPCCalibViewerGUI *fCalibViewerGUI; //calib viewer gui used to display verbose information for one run
106 TGTabElement *fCalibViewerGUItab; //tab the calib view gui redies in
107 TH1* fCurrentHist; //histogram currently drawn in main canvas
108 TGraph* fCurrentGraph; //current graph
109 Int_t fCurrentRunDetails; //run number for wich details are currently shown
110 TString fOutputCacheDir; //output cache diretory for AliTPCCalibViewerGUI trees, created on the fly
111 TString fDrawString; //current draw string
112 TString fConfigFile; //configuration file keeping active branches and branch descriptions
113 AliTPCConfigParser *fConfigParser; //configuration parser
114 Bool_t fIsCustomDraw; //if custom draw string is selected
115 TVectorD fRunNumbers; //run numbers of current selection
116 TVectorD fTimeStamps; //timr stamps of current selection
117 TVectorD fValuesX; //values of current selection
118 TVectorD fValuesY; //values of current selection
120 Bool_t fNoGraph; //Whether to create a graph
121 Long64_t fGraphLimitEntries; //limit in number of entries in the chain for producing a graph
123 TMap *fMapRefTrees; //map of reference trees for the CalibViewer
125 //main canvas Top part, bottom part
126 TGCompositeFrame *fContTopBottom; // container for all GUI elements, vertical divided
127 //top left, centre, right
128 TGCompositeFrame *fContLCR; // container for all GUI elements, horizontal divided
130 TGCompositeFrame *fContLeft; // container for GUI elements on left side
131 TGGroupFrame *fContDrawOpt; // Subgroup for draw selection
132 TGCheckButton *fChkDrawOptSame; // draw option 'same'
133 TGComboBox *fComboAddDrawOpt; // additional draw options combo box
134 TGGroupFrame *fContDrawSel; // Subgroup for draw selection
135 TGCompositeFrame *fContDrawSelSubRunTime; //Radio button subframe
136 TGRadioButton *fRadioXhist; // Radio button x-variable: show only 1D distribution
137 TGRadioButton *fRadioXrun; // Radio button x-variable: run
138 TGRadioButton *fRadioXtime; // Radio button x-variable: time
139 TGListBox *fListVariables; // listbox with possible variables
140 TGComboBox *fComboRunType; // run type selection box
141 TGLabel *fLblRunType; // run type label
142 TGNumberEntry *fNmbPar; // parameter number
143 TGLabel *fLblPar; // parameter name
144 TGListBox *fListCalibType; // calibration type selection box
145 TGGroupFrame *fContCalibType; // calibration type label
147 TGCompositeFrame *fContCenter; // container for GUI elements at the center
148 TRootEmbeddedCanvas *fCanvMain; // main drawing canvas
150 TGCompositeFrame *fContRight; // container for GUI elements on right side
151 TGGroupFrame *fContValues; // container to keep data point information
152 TGLabel *fLblRunNumber; // run number label
153 TGLabel *fLblRunTime; // time stamp label
154 TGLabel *fLblValueX; // value label
155 TGLabel *fLblValueY; // value label
156 TGLabel *fLblRunNumberVal; // run number of the data point hoovered
157 TGLabel *fLblRunTimeVal; // time stamp of the data point hoovered
158 TGLabel *fLblValueXVal; // value of the data point hoovered
159 TGLabel *fLblValueYVal; // value of the data point hoovered
160 TGTextButton *fBtnDumpRuns; // draw button
161 TGGroupFrame *fContAliases; // container to keep data point information
162 TGListBox *fListAliases; // list of aliases
164 TGCompositeFrame *fContCustom; // container for custom draw command GUI elements
165 TGCompositeFrame *fContCustomCuts; // container for custom cut options GUI elements
166 TGLabel *fLblCustomDraw; // label for custom draw string
167 TGLabel *fLblCustomCuts; // label for custom cuts string
168 TGComboBox *fComboCustomDraw; // combo box custom draw string
169 TGComboBox *fComboCustomCuts; // combo box custom cuts string
171 TObjArray *fTrashBox; //graphics objects to be deleted (histograms, graphs,...)
173 enum { kRadioXhist=10, kRadioXrun=11, kRadioXtime=12 };
174 enum { kBranchOnOff=0, kBranchTitle=1, kCalibType=2, kParamNames=3 };
176 void UpdateParLimits();
177 void UpdateParName();
178 void SetGuiTree(Int_t run);
180 void FillCalibTypes();
181 void SetInitialValues();
182 void CheckDrawGraph();
184 void UpdateValueArrays(Bool_t withGraph);
185 const char* SubstituteUnderscores(const char* in);
186 void GetHistogramTitle(TString &title);
189 AliTPCCalibViewerGUItime(const AliTPCCalibViewerGUItime &v);
190 AliTPCCalibViewerGUItime &operator = (const AliTPCCalibViewerGUItime &v); // assignment operator
192 ClassDef(AliTPCCalibViewerGUItime, 0)
196 ////////////////////////////////////////////////////////////////////////
200 ////////////////////////////////////////////////////////////////////////
202 class AliTPCCalibViewerGUItimeAddAliasFrame : public TObject {
204 AliTPCCalibViewerGUItimeAddAliasFrame(const TGWindow *p, const TGWindow *main, UInt_t w, UInt_t h,
205 UInt_t options, AliTPCCalibViewerGUItime *gui, TString strAlias="");
206 virtual ~AliTPCCalibViewerGUItimeAddAliasFrame();
214 TGTransientFrame *fMain; //Main frame
215 TGTextEntry *fTxt1, *fTxt2; //text input
217 AliTPCCalibViewerGUItime *fGUI; //pointer to mother process
219 AliTPCCalibViewerGUItimeAddAliasFrame(const AliTPCCalibViewerGUItimeAddAliasFrame &r);
220 AliTPCCalibViewerGUItimeAddAliasFrame &operator = (const AliTPCCalibViewerGUItimeAddAliasFrame &r);
222 ClassDef(AliTPCCalibViewerGUItimeAddAliasFrame,0)