56e3e66b1555be91d64123638a5418953a79a71e
[u/mrichter/AliRoot.git] / EVE / Reve / RGValuators.cxx
1 // $Header$
2
3 #include "RGValuators.h"
4
5 #include <TGLabel.h>
6 #include <TGSlider.h>
7 #include <TGDoubleSlider.h>
8
9 using namespace Reve;
10
11 /**************************************************************************/
12 // RGValuatorBase
13 /**************************************************************************/
14
15 ClassImp(RGValuatorBase)
16
17 RGValuatorBase::RGValuatorBase(const TGWindow *p, const char* name,
18                                UInt_t w, UInt_t h) :
19   TGCompositeFrame(p, w, h),
20
21   fLabelWidth (0),
22   fAlignRight (kFALSE),
23   fShowSlider (kTRUE),
24
25   fNELength (5),
26   fNEHeight (20),
27
28   fLabel (0)
29 {
30    SetName(name);
31 }
32
33 /**************************************************************************/
34 // RGValuator
35 /**************************************************************************/
36
37 ClassImp(RGValuator)
38
39 RGValuator::RGValuator(const TGWindow *p, const char* title,
40                        UInt_t w, UInt_t h) :
41   RGValuatorBase(p, title, w, h),
42
43   fValue (0),
44   fMin   (0),
45   fMax   (0),
46
47   fSliderNewLine (kFALSE),
48   fSliderSteps   (-1),
49   fEntry  (0),
50   fSlider (0)
51 {}
52
53 void RGValuator::Build()
54 {
55   TGCompositeFrame *hf1, *hfs;
56   if(fShowSlider && fSliderNewLine) {
57     SetLayoutManager(new TGVerticalLayout(this));
58     hf1 = new TGHorizontalFrame(this);
59     hf1->SetLayoutManager(new TGHorizontalLayout(hf1));
60     AddFrame(hf1, new TGLayoutHints(kLHintsTop, 0,0,0,0));
61     hfs = new TGHorizontalFrame(this);
62     hfs->SetLayoutManager(new TGHorizontalLayout(hfs));
63     AddFrame(hfs, new TGLayoutHints(kLHintsTop, 0,0,0,0));
64   } else {
65     hf1 = this;
66     hfs = this;
67     SetLayoutManager(new TGHorizontalLayout(this));
68   }
69
70   // label
71   TGLayoutHints* lh;
72   if(fAlignRight)
73     lh = new TGLayoutHints(kLHintsRight | kLHintsBottom, 0,0,0,0);
74   else
75     lh = new TGLayoutHints(kLHintsLeft  | kLHintsBottom, 0,0,0,0);
76   
77   if (fLabelWidth > 0) {
78     // printf("fLabelWidth > 0 \n");
79     TGCompositeFrame *lf = new TGHorizontalFrame(hf1, fLabelWidth, fNEHeight, kFixedSize);
80     fLabel = new TGLabel(lf, GetName());
81     lf->AddFrame(fLabel, lh); 
82     // add label frame to top horizontal frame
83     TGLayoutHints* lfh = new TGLayoutHints(kLHintsLeft, 0,0,0,0);
84     hf1->AddFrame(lf, lfh);
85   } else {
86     fLabel = new TGLabel(hf1, GetName());
87     hf1->AddFrame(fLabel, lh);  
88   }
89
90   // entry
91   TGLayoutHints*  elh =  new TGLayoutHints(kLHintsLeft, 1,0,0,0);
92   fEntry = new TGNumberEntry(hf1, 0, fNELength);
93   fEntry->SetHeight(fNEHeight);
94   fEntry->GetNumberEntry()->SetToolTipText("Enter Slider Value");
95   hf1->AddFrame(fEntry, elh);
96
97   fEntry->Associate(this);   
98   fEntry->Connect("ValueSet(Long_t)",
99                   "Reve::RGValuator", this, "EntryCallback()");
100   
101   
102   // slider
103   if(fShowSlider) {
104     fSlider = new TGHSlider(hfs, GetWidth(), kSlider1 | kScaleBoth);
105     hfs->AddFrame(fSlider, new TGLayoutHints(kLHintsLeft, 1,1,0,0));
106    
107     fSlider->Associate(this);
108     fSlider->Connect("PositionChanged(Int_t)",
109                      "Reve::RGValuator", this, "SliderCallback()");
110   }
111 }
112
113 void RGValuator::SetLimits(Float_t min, Float_t max, Int_t ndiv,
114                            TGNumberFormat::EStyle nef) 
115 {
116   fMin = Float_t(min);
117   fMax = Float_t(max);
118   fSliderSteps = ndiv;
119   fEntry->SetFormat(nef);
120   fEntry->SetLimits(TGNumberFormat::kNELLimitMinMax, min, max);
121 }
122
123 void RGValuator::SetLimits(Int_t min, Int_t max) 
124 {
125   fMin = Float_t(min);
126   fMax = Float_t(max);
127   fEntry->SetFormat(TGNumberFormat::kNESInteger);
128   fEntry->SetLimits(TGNumberFormat::kNELLimitMinMax, min, max);
129
130   if(fSlider){
131     fSlider->SetRange(min, max);
132     fSliderSteps = max - min;
133   }
134 }
135
136 void RGValuator::EntryCallback()
137 {
138   fValue = fEntry->GetNumber();
139   if(fSlider) {
140     Int_t pos;
141     if (fSliderSteps != -1) {
142       pos = Int_t( fSliderSteps*(fValue - fMin)/(fMax - fMin));
143     } else {
144       pos = Int_t(fValue - fMin);
145     }
146     pos += Int_t(fMin);
147     fSlider->SetPosition(pos);
148     // printf( "RGValuator::EntryCallback() slider pos %d n", pos);
149   }
150   ValueSet(fValue);
151 }
152
153 void RGValuator::SliderCallback()
154 {
155   Double_t val;
156   if(fSliderSteps != -1)
157     val = fMin + fSlider->GetPosition()*Double_t((fMax-fMin))/fSliderSteps;
158   else 
159     val = Double_t(fSlider->GetPosition());
160   
161   fValue = val;
162   fEntry->SetNumber(fValue);
163   ValueSet(fValue);
164 }
165
166
167 void RGValuator::ValueSet(Double_t val)
168 {
169   Emit("ValueSet(Double_t)", val);
170 }
171
172 void RGValuator::SetValue(Float_t val, Bool_t emit)
173 {
174   fValue = val;
175   fEntry->SetNumber(fValue);
176
177   if(fSlider){
178     fSlider->SetPosition(Int_t((val-fMin)*fSliderSteps/(fMax-fMin)));
179     // printf("RGValuator::ValueSet slider pos %d\n",fSlider->GetPosition() );
180   }
181   if(emit)
182     ValueSet(val);
183 }
184
185 void RGValuator::SetToolTip(const Text_t* tip)
186 {
187   fEntry->GetNumberEntry()->SetToolTipText(tip);
188 }
189
190 /**************************************************************************/
191 // RGDoubleValuator
192 /**************************************************************************/
193
194 ClassImp(RGDoubleValuator)
195
196 RGDoubleValuator::RGDoubleValuator(const TGWindow *p, const char* title,
197                                    UInt_t w, UInt_t h) :
198   RGValuatorBase(p, title, w, h),
199
200   fMinEntry(0),
201   fMaxEntry(0),
202   fSlider(0)
203 {}
204
205 void RGDoubleValuator::Build()
206 {
207   TGCompositeFrame *hf1, *hfs;
208   if(fShowSlider) {
209     SetLayoutManager(new TGVerticalLayout(this));
210     hf1 = new TGHorizontalFrame(this);
211     hf1->SetLayoutManager(new TGHorizontalLayout(hf1));
212     AddFrame(hf1, new TGLayoutHints(kLHintsTop, 0,0,0,0));
213     hfs = new TGHorizontalFrame(this);
214     hfs->SetLayoutManager(new TGHorizontalLayout(hfs));
215     AddFrame(hfs, new TGLayoutHints(kLHintsTop, 0,0,0,0));
216   } else {
217     hf1 = this;
218     hfs = this;
219     SetLayoutManager(new TGHorizontalLayout(this));
220   }
221
222   // label
223   TGLayoutHints* lh;
224   if(fAlignRight)
225     lh = new TGLayoutHints(kLHintsRight | kLHintsBottom, 0,2,0,0);
226   else
227     lh = new TGLayoutHints(kLHintsLeft  | kLHintsBottom, 0,2,0,0);
228   
229   if(fLabelWidth > 0) {
230     TGCompositeFrame *lf = new TGHorizontalFrame(hf1, fLabelWidth, fNEHeight, kFixedSize);
231     fLabel = new TGLabel(lf, GetName());
232     lf->AddFrame(fLabel, lh); 
233     // add label frame to top horizontal frame
234     TGLayoutHints* lfh = new TGLayoutHints(kLHintsLeft, 0,0,0,0);
235     hf1->AddFrame(lf, lfh);
236   } else {
237     fLabel = new TGLabel(hf1, GetName());
238     hf1->AddFrame(fLabel);  
239   }
240
241   // entries
242   fMinEntry = new TGNumberEntry(this, 0, fNELength);
243   fMinEntry->SetHeight(fNEHeight);
244   fMinEntry->GetNumberEntry()->SetToolTipText("Enter Slider Min Value");
245   hf1->AddFrame(fMinEntry, new TGLayoutHints(kLHintsLeft, 1,0,0,0));
246   fMinEntry->Connect("ValueSet(Long_t)",
247                      "Reve::RGDoubleValuator", this, "MinEntryCallback()");
248   fMinEntry->Associate(this);   
249    
250   fMaxEntry = new TGNumberEntry(this, 0, fNELength);
251   fMaxEntry->SetHeight(fNEHeight);
252   fMaxEntry->GetNumberEntry()->SetToolTipText("Enter Slider Max Value");
253   hf1->AddFrame(fMaxEntry,  new TGLayoutHints(kLHintsLeft, 2,0,0,0));
254   fMaxEntry->Connect("ValueSet(Long_t)",
255                      "Reve::RGDoubleValuator", this, "MaxEntryCallback()");
256   fMaxEntry->Associate(this);   
257   
258   // slider
259   if(fShowSlider) {
260     fSlider = new TGDoubleHSlider(hfs, GetWidth(), kDoubleScaleBoth);
261     hfs->AddFrame(fSlider, new TGLayoutHints(kLHintsTop|kLHintsLeft, 0,0,1,0));
262     fSlider->Associate(this);
263     fSlider->Connect("PositionChanged()",
264                      "Reve::RGDoubleValuator", this, "SliderCallback()");
265   }
266 }
267
268 void RGDoubleValuator::SetLimits(Float_t min, Float_t max,
269                                  TGNumberFormat::EStyle nef) 
270 {
271   //  printf("RGDoubleValuator::SetLimits(Float_t min, Float_t max, Int_ \n");
272   fMinEntry->SetLimits(TGNumberFormat::kNELLimitMinMax, min, max);
273   fMinEntry->SetFormat(nef);
274   fMaxEntry->SetLimits(TGNumberFormat::kNELLimitMinMax, min, max);
275   fMaxEntry->SetFormat(nef);
276   
277   if(fSlider) fSlider->SetRange(min, max);
278 }
279
280 void RGDoubleValuator::MinEntryCallback()
281 {
282   if(GetMin() > GetMax())
283     fMaxEntry->SetNumber(GetMin());
284   if(fSlider) fSlider->SetPosition(GetMin(), GetMax());
285   ValueSet();
286 }
287
288 void RGDoubleValuator::MaxEntryCallback()
289 {
290   if(GetMax() < GetMin())
291     fMinEntry->SetNumber(GetMax());
292   if(fSlider) fSlider->SetPosition(GetMin(), GetMax());
293   ValueSet();
294 }
295
296 void RGDoubleValuator::SliderCallback()
297 {
298   Float_t minp, maxp;
299   fSlider->GetPosition(minp, maxp);
300   //printf("RGDoubleValuator::SliderCallback %f %f\n", minp, maxp);
301   fMinEntry->SetNumber(minp);
302   fMaxEntry->SetNumber(maxp); 
303   ValueSet();
304 }
305
306 void RGDoubleValuator::SetValues(Float_t min, Float_t max, Bool_t emit)
307 {
308   fMinEntry->SetNumber(min);
309   fMaxEntry->SetNumber(max);
310
311   if(fSlider) fSlider->SetPosition(min, max);
312   if(emit)    ValueSet();
313 }
314
315 void RGDoubleValuator::ValueSet()
316 {
317   Emit("ValueSet()");
318 }