Logo ROOT  
Reference Guide
 
Loading...
Searching...
No Matches
TF1Editor.cxx
Go to the documentation of this file.
1// @(#)root/ged:$Id$
2// Author: Ilka Antcheva 21/03/06
3
4/*************************************************************************
5 * Copyright (C) 1995-2004, Rene Brun and Fons Rademakers. *
6 * All rights reserved. *
7 * *
8 * For the licensing terms see $ROOTSYS/LICENSE. *
9 * For the list of contributors see $ROOTSYS/README/CREDITS. *
10 *************************************************************************/
11
12//////////////////////////////////////////////////////////////////////////
13// //
14// TF1Editor //
15// //
16// GUI for TF1 attributes and parameters. //
17// //
18//////////////////////////////////////////////////////////////////////////
19
20#include "TF1Editor.h"
21#include "TGedEditor.h"
22#include "TH1.h"
23#include "TF1.h"
24#include "TGTextEntry.h"
25#include "TGLabel.h"
26#include "TGDoubleSlider.h"
27#include "TString.h"
28#include "TGNumberEntry.h"
29#include "TG3DLine.h"
31#include "TVirtualPad.h"
32
33
35
36enum ETF1Wid {
40};
41
43 UInt_t options, Pixel_t back)
44 : TGedFrame(p, width, height, options | kVerticalFrame, back)
45{
46 // Constructor of TF1 editor.
47
48 MakeTitle("Function");
49
50 fTitle = new TGTextEntry(this, new TGTextBuffer(50), kTF1_TIT);
53 fTitle->SetToolTipText(Form("Function expression or predefined name"));
54 AddFrame(fTitle, new TGLayoutHints(kLHintsLeft,3, 2, 2, 3));
55
56 TGCompositeFrame *f3a = new TGCompositeFrame(this, 137, 20, kHorizontalFrame);
57 AddFrame(f3a, new TGLayoutHints(kLHintsTop, 0, 1, 3, 0));
58 fDrawMode = new TGCheckButton(f3a, "Update", kTF1_DRW);
59 fDrawMode->SetToolTipText("Immediate function redrawing");
61 fParLabel = new TGLabel(f3a, "");
63
65 fSetPars = new TGTextButton(f3, "Set Parameters...", kTF1_PAR);
67 0, 1, 5, 0));
68 fSetPars->SetToolTipText("Open a dialog for parameter(s) settings");
69 AddFrame(f3, new TGLayoutHints(kLHintsTop | kLHintsLeft, 3, 2, 2, 3));
70
71 MakeTitle("X-Range");
72
73 TGCompositeFrame *f4 = new TGCompositeFrame(this, 80, 20, kHorizontalFrame);
75 TGLabel *fNpxLabel = new TGLabel(f4a, "Points: ");
76 f4a->AddFrame(fNpxLabel, new TGLayoutHints(kLHintsLeft | kLHintsCenterY, 3, 0, 5, 1));
77 f4->AddFrame(f4a, new TGLayoutHints(kLHintsTop | kLHintsLeft, 0, 1, 0, 0));
78
79 TGCompositeFrame *f4b = new TGCompositeFrame(f4, 40, 20, kVerticalFrame);
80 fNXpoints = new TGNumberEntry(f4b, 100, 7, kTF1_NPX,
84 fNXpoints->GetNumberEntry()->SetToolTipText("Points along x-axis (4-100 000)");
85 f4b->AddFrame(fNXpoints, new TGLayoutHints(kLHintsLeft, 0, 0, 1, 0));
86 f4->AddFrame(f4b, new TGLayoutHints(kLHintsTop | kLHintsRight, 0, 1, 0, 0));
87 AddFrame(f4, new TGLayoutHints(kLHintsTop | kLHintsLeft, 0, 1, 0, 0));
88
89 TGCompositeFrame *f5 = new TGCompositeFrame(this, 80, 20, kHorizontalFrame);
90 fSliderX = new TGDoubleHSlider(f5, 1, 2);
91 fSliderX->Resize(137,20);
93 AddFrame(f5, new TGLayoutHints(kLHintsTop, 3, 7, 4, 1));
94
95 TGCompositeFrame *f6 = new TGCompositeFrame(this, 80, 20, kHorizontalFrame);
99 ((TGTextEntry*)fSldMinX)->SetToolTipText("Lower bound along x-axis");
100 fSldMinX->Resize(65,20);
106 ((TGTextEntry*)fSldMaxX)->SetToolTipText("Upper bound along x-axis");
108 fSldMaxX->Resize(65,20);
109 f6->AddFrame(fSldMaxX, new TGLayoutHints(kLHintsLeft, 4, 0, 0, 0));
110 AddFrame(f6, new TGLayoutHints(kLHintsTop, 3, 3, 5, 0));
111}
112
113////////////////////////////////////////////////////////////////////////////////
114/// Destructor of TF1 editor.
115
117{
118}
119
120////////////////////////////////////////////////////////////////////////////////
121/// Connect signals to slots.
122
124{
125 fNXpoints->Connect("ValueSet(Long_t)", "TF1Editor", this, "DoXPoints()");
126 (fNXpoints->GetNumberEntry())->Connect("ReturnPressed()", "TF1Editor",
127 this, "DoXPoints()");
128 fSetPars->Connect("Clicked()", "TF1Editor", this, "DoParameterSettings()");
129 fSliderX->Connect("Pressed()","TF1Editor", this,"DoSliderXPressed()");
130 fSliderX->Connect("Released()","TF1Editor", this,"DoSliderXReleased()");
131 fSliderX->Connect("PositionChanged()","TF1Editor", this,"DoSliderXMoved()");
132
133 fInit = kFALSE;
134}
135
136////////////////////////////////////////////////////////////////////////////////
137/// Pick up the function parameters and options.
138
140{
141 if (obj == 0 || !obj->InheritsFrom(TF1::Class())) {
142 return;
143 }
144
145 fF1 = (TF1*)obj;
147
148 const char *text = fF1->GetTitle();
150
151 fNP = fF1->GetNpar();
152 fParLabel->SetText(Form("Npar: %d", fNP));
154
156
157 if (!fNP)
159 else
161
163 Int_t nx = x->GetNbins();
164 Int_t nxbinmin = x->GetFirst();
165 Int_t nxbinmax = x->GetLast();
166 fSliderX->SetRange(1,nx);
167 fSliderX->SetPosition((Double_t)nxbinmin,(Double_t)nxbinmax);
168 fSldMinX->SetNumber(x->GetBinLowEdge(nxbinmin));
169 fSldMaxX->SetNumber(x->GetBinUpEdge(nxbinmax));
170
173}
174
175////////////////////////////////////////////////////////////////////////////////
176/// Slot connected to the function parameter(s) settings.
177
179{
181 Double_t rmin = fSldMinX->GetNumber();
182 Double_t rmax = fSldMaxX->GetNumber();
183 new TFunctionParametersDialog(gClient->GetDefaultRoot(), main,
184 fF1, fGedEditor->GetPad(), rmin, rmax);
185
186}
187
188////////////////////////////////////////////////////////////////////////////////
189/// Slot connected to the number of points setting.
190
192{
193 if (fAvoidSignal) return;
194 Double_t rmin, rmax;
195 fF1->GetRange(rmin, rmax);
201 Update();
202 fF1->SetRange(rmin, rmax);
203}
204
205////////////////////////////////////////////////////////////////////////////////
206/// Slot connected to the x-Slider range for function redrawing.
207
209{
210 if (fAvoidSignal) return;
211
212 TVirtualPad *save = 0;
213 save = gPad;
215 fGedEditor->GetPad()->cd();
216
219
220 if (fDrawMode->GetState() == kButtonDown) {
221 TString opt = fF1->GetDrawOption();
222 opt.ToUpper();
223 if (!opt.Contains("SAME"))
224 opt += "SAME";
225 fF1->Draw(opt);
226
227 x->SetRange((Int_t)((fSliderX->GetMinPosition())+0.5),
228 (Int_t)((fSliderX->GetMaxPosition())+0.5));
229 fSldMinX->SetNumber(x->GetBinLowEdge(x->GetFirst()));
230 fSldMaxX->SetNumber(x->GetBinUpEdge(x->GetLast()));
234 Update();
235
236 } else {
237 x->SetRange((Int_t)((fSliderX->GetMinPosition())+0.5),
238 (Int_t)((fSliderX->GetMaxPosition())+0.5));
239 fSldMinX->SetNumber(x->GetBinLowEdge(x->GetFirst()));
240 fSldMaxX->SetNumber(x->GetBinUpEdge(x->GetLast()));
244 }
245 if(save) gPad = save;
246}
247
248////////////////////////////////////////////////////////////////////////////////
249/// Slot connected to the x-Slider.
250
252{
253 if (fAvoidSignal || (fDrawMode->GetState() == kButtonDown)) return;
254
255 TVirtualPad *save = 0;
256 save = gPad;
258 fGedEditor->GetPad()->cd();
259
262 TString opt = fF1->GetDrawOption();
263 opt.ToUpper();
264 if (!opt.Contains("SAME"))
265 opt += "SAME";
266 fF1->Draw(opt);
267
268 x->SetRange((Int_t)((fSliderX->GetMinPosition())+0.5),
269 (Int_t)((fSliderX->GetMaxPosition())+0.5));
270 fSldMinX->SetNumber(x->GetBinLowEdge(x->GetFirst()));
271 fSldMaxX->SetNumber(x->GetBinUpEdge(x->GetLast()));
275 Update();
276
277 if(save) gPad = save;
278
279}
280
281////////////////////////////////////////////////////////////////////////////////
282/// Slot connected to the x-Slider.
283
285{
286 if (fAvoidSignal || (fDrawMode->GetState() == kButtonDown)) return;
287
288 TVirtualPad *save = 0;
289 save = gPad;
291 fGedEditor->GetPad()->cd();
292
295 TString opt = fF1->GetDrawOption();
296 opt.ToUpper();
297 if (!opt.Contains("SAME"))
298 opt += "SAME";
299 fF1->Draw(opt);
300
301 x->SetRange((Int_t)((fSliderX->GetMinPosition())+0.5),
302 (Int_t)((fSliderX->GetMaxPosition())+0.5));
303 fSldMinX->SetNumber(x->GetBinLowEdge(x->GetFirst()));
304 fSldMaxX->SetNumber(x->GetBinUpEdge(x->GetLast()));
308 Update();
309
310 if(save) gPad = save;
311}
312
313
314////////////////////////////////////////////////////////////////////////////////
315/// Slot connected to min/max settings of the slider range.
316
318{
319 if (fAvoidSignal) return;
321 Int_t nx = x->GetNbins();
322 Double_t width = x->GetBinWidth(1);
323 Double_t lowLimit = x->GetBinLowEdge(1);
324 Double_t upLimit = x->GetBinUpEdge(nx);
325 if ((fSldMinX->GetNumber()+width/2) < (lowLimit))
326 fSldMinX->SetNumber(lowLimit);
327 if ((fSldMaxX->GetNumber()-width/2) > (upLimit))
328 fSldMaxX->SetNumber(upLimit);
329 x->SetRangeUser(fSldMinX->GetNumber()+width/2,
331 Int_t nxbinmin = x->GetFirst();
332 Int_t nxbinmax = x->GetLast();
333 fSliderX->SetPosition((Double_t)(nxbinmin),(Double_t)(nxbinmax));
334 Update();
335}
336
337////////////////////////////////////////////////////////////////////////////////
338/// Exclude TAttFillEditor from this interface.
339
341{
342 fGedEditor->ExcludeClassEditor(TAttFill::Class());
344}
345
@ kVerticalFrame
Definition GuiTypes.h:381
@ kFixedWidth
Definition GuiTypes.h:387
@ kHorizontalFrame
Definition GuiTypes.h:382
ULong_t Pixel_t
Pixel value.
Definition GuiTypes.h:40
const Bool_t kFALSE
Definition RtypesCore.h:92
double Double_t
Definition RtypesCore.h:59
const Bool_t kTRUE
Definition RtypesCore.h:91
#define ClassImp(name)
Definition Rtypes.h:364
include TDocParser_001 C image html pict1_TDocParser_001 png width
ETF1Wid
Definition TF1Editor.cxx:36
@ kTF1_DRW
Definition TF1Editor.cxx:39
@ kTF1_TIT
Definition TF1Editor.cxx:37
@ kTF1_XMAX
Definition TF1Editor.cxx:38
@ kTF1_XSLD
Definition TF1Editor.cxx:38
@ kTF1_NPX
Definition TF1Editor.cxx:37
@ kTF1_PAR
Definition TF1Editor.cxx:39
@ kTF1_XMIN
Definition TF1Editor.cxx:38
@ kButtonDown
Definition TGButton.h:54
@ kButtonDisabled
Definition TGButton.h:56
@ kButtonUp
Definition TGButton.h:53
#define gClient
Definition TGClient.h:166
@ kLHintsRight
Definition TGLayout.h:33
@ kLHintsLeft
Definition TGLayout.h:31
@ kLHintsCenterY
Definition TGLayout.h:35
@ kLHintsBottom
Definition TGLayout.h:36
@ kLHintsTop
Definition TGLayout.h:34
@ kLHintsExpandX
Definition TGLayout.h:37
char * Form(const char *fmt,...)
#define gPad
Class to manage histogram axis.
Definition TAxis.h:30
virtual void Set(Int_t nbins, Double_t xmin, Double_t xmax)
Initialize axis with fix bins.
Definition TAxis.cxx:731
TClass instances represent classes, structs and namespaces in the ROOT type system.
Definition TClass.h:80
TGCheckButton * fDrawMode
Definition TF1Editor.h:41
virtual void ActivateBaseClassEditors(TClass *cl)
Exclude TAttFillEditor from this interface.
virtual void DoXRange()
Slot connected to min/max settings of the slider range.
virtual void DoParameterSettings()
Slot connected to the function parameter(s) settings.
virtual void DoSliderXReleased()
Slot connected to the x-Slider.
virtual void DoXPoints()
Slot connected to the number of points setting.
virtual void DoSliderXMoved()
Slot connected to the x-Slider range for function redrawing.
virtual ~TF1Editor()
Destructor of TF1 editor.
TGLabel * fParLabel
Definition TF1Editor.h:40
virtual void DoSliderXPressed()
Slot connected to the x-Slider.
Int_t fNP
Definition TF1Editor.h:39
TGNumberEntryField * fSldMinX
Definition TF1Editor.h:45
TGDoubleHSlider * fSliderX
Definition TF1Editor.h:44
TGNumberEntry * fNXpoints
Definition TF1Editor.h:43
TF1 * fF1
Definition TF1Editor.h:37
TGNumberEntryField * fSldMaxX
Definition TF1Editor.h:46
virtual void SetModel(TObject *obj)
Pick up the function parameters and options.
TF1Editor(const TGWindow *p=0, Int_t width=140, Int_t height=30, UInt_t options=kChildFrame, Pixel_t back=GetDefaultFrameBackground())
Definition TF1Editor.cxx:42
TGTextButton * fSetPars
Definition TF1Editor.h:42
TGTextEntry * fTitle
Definition TF1Editor.h:38
virtual void ConnectSignals2Slots()
Connect signals to slots.
1-Dim function class
Definition TF1.h:213
virtual TH1 * GetHistogram() const
Return a pointer to the histogram used to visualise the function Note that this histogram is managed ...
Definition TF1.cxx:1574
virtual void SetRange(Double_t xmin, Double_t xmax)
Initialize the upper and lower bounds to draw the function.
Definition TF1.cxx:3532
virtual Int_t GetNpar() const
Definition TF1.h:481
virtual void SetNpx(Int_t npx=100)
Set the number of points used to draw the function.
Definition TF1.cxx:3446
virtual void GetRange(Double_t *xmin, Double_t *xmax) const
Return range of a generic N-D function.
Definition TF1.cxx:2269
virtual void Draw(Option_t *option="")
Draw this function with its current attributes.
Definition TF1.cxx:1322
virtual Int_t GetNpx() const
Definition TF1.h:490
virtual void SetToolTipText(const char *text, Long_t delayms=400)
Set tool tip text associated with this button.
Definition TGButton.cxx:398
virtual EButtonState GetState() const
Definition TGButton.h:112
virtual void SetState(EButtonState state, Bool_t emit=kFALSE)
Set button state.
Definition TGButton.cxx:188
void NeedRedraw(TGWindow *w, Bool_t force=kFALSE)
Set redraw flags.
Definition TGClient.cxx:371
virtual void AddFrame(TGFrame *f, TGLayoutHints *l=0)
Add frame to the composite frame using the specified layout hints.
Definition TGFrame.cxx:1102
virtual Float_t GetMaxPosition() const
virtual Float_t GetMinPosition() const
virtual void SetRange(Float_t min, Float_t max)
virtual void SetPosition(Float_t min, Float_t max)
virtual UInt_t GetDefaultHeight() const
Definition TGFrame.h:215
virtual void Resize(UInt_t w=0, UInt_t h=0)
Resize the frame.
Definition TGFrame.cxx:590
virtual void SetText(TGString *newText)
Set new text in label.
Definition TGLabel.cxx:179
virtual Double_t GetNumber() const
Get the numeric value (floating point representation).
virtual void SetState(Bool_t state)
Set the active state.
virtual void SetNumber(Double_t val)
Set the numeric value (floating point representation).
virtual void SetNumber(Double_t val)
TGNumberEntryField * GetNumberEntry() const
virtual Double_t GetNumber() const
TGClient * fClient
Definition TGObject.h:37
void SetEnabled(Bool_t flag=kTRUE)
virtual void SetToolTipText(const char *text, Long_t delayms=500)
Set tool tip text associated with this text entry.
virtual void SetText(const char *text, Bool_t emit=kTRUE)
Sets text entry to text, clears the selection and moves the cursor to the end of the line.
virtual const TGWindow * GetMainFrame() const
Returns top level main frame.
Definition TGWindow.cxx:151
virtual TVirtualPad * GetPad() const
Definition TGedEditor.h:88
void ExcludeClassEditor(TClass *cl, Bool_t recurse=kFALSE)
Exclude editor for class cl from current construction.
virtual void ActivateBaseClassEditors(TClass *cl)
Provide list of editors for base-classes.
TGedEditor * fGedEditor
Definition TGedFrame.h:55
Bool_t fInit
Definition TGedFrame.h:54
virtual void MakeTitle(const char *title)
Create attribute frame title.
Definition TGedFrame.cxx:96
virtual void Update()
Update the current pad when an attribute is changed via GUI.
Definition TGedFrame.cxx:73
Bool_t fAvoidSignal
Definition TGedFrame.h:57
TAxis * GetXaxis()
Get the behaviour adopted by the object about the statoverflows. See EStatOverflows for more informat...
Definition TH1.h:320
virtual const char * GetTitle() const
Returns title of object.
Definition TNamed.h:48
Mother of all ROOT objects.
Definition TObject.h:37
virtual Option_t * GetDrawOption() const
Get option used by the graphics system to draw this object.
Definition TObject.cxx:343
virtual Bool_t InheritsFrom(const char *classname) const
Returns kTRUE if object inherits from class "classname".
Definition TObject.cxx:445
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:866
Basic string class.
Definition TString.h:136
void ToUpper()
Change string to upper case.
Definition TString.cxx:1158
Bool_t Contains(const char *pat, ECaseCompare cmp=kExact) const
Definition TString.h:624
TVirtualPad is an abstract base class for the Pad and Canvas classes.
Definition TVirtualPad.h:51
virtual TVirtualPad * cd(Int_t subpadnumber=0)=0
TText * text
int main()
Double_t x[n]
Definition legend1.C:17