334 gROOT->GetListOfCleanups()->Add(
this);
517 gROOT->GetListOfCleanups()->Remove(
this);
535 fAddB->
Connect(
"Toggled(Bool_t)",
"TH1Editor",
this,
"DoAddB(Bool_t)");
536 fAddBar->
Connect(
"Toggled(Bool_t)",
"TH1Editor",
this,
"DoAddBar(Bool_t)");
537 fTitle->
Connect(
"TextChanged(const char *)",
"TH1Editor",
this,
"DoTitle(const char *)");
541 fAddCombo->
Connect(
"Selected(Int_t)",
"TH1Editor",
this,
"DoHistChanges()");
542 fAddMarker->
Connect(
"Toggled(Bool_t)",
"TH1Editor",
this,
"DoAddMarker(Bool_t)");
543 fAddSimple->
Connect(
"Toggled(Bool_t)",
"TH1Editor",
this,
"DoAddSimple(Bool_t)");
559 fBinSlider->
Connect(
"PositionChanged(Int_t)",
"TH1Editor",
this,
"DoBinMoved(Int_t)");
565 fApply->
Connect(
"Clicked()",
"TH1Editor",
this,
"DoApply()");
577 fSlider->
Connect(
"PositionChanged()",
"TH1Editor",
this,
"DoSliderMoved()");
578 fSlider->
Connect(
"Pressed()",
"TH1Editor",
this,
"DoSliderPressed()");
579 fSlider->
Connect(
"Released()",
"TH1Editor",
this,
"DoSliderReleased()");
580 fSldMin->
Connect(
"ReturnPressed()",
"TH1Editor",
this,
"DoAxisRange()");
581 fSldMax->
Connect(
"ReturnPressed()",
"TH1Editor",
this,
"DoAxisRange()");
591 ((
TH1*)obj)->GetDimension()!=1 ||
592 ((
TH1*)obj)->GetEntries() == 0
634 if (str.
IsNull() || str==
"" ) {
818 Int_t nxbinmin =
fHist -> GetXaxis() -> GetFirst();
819 Int_t nxbinmax =
fHist -> GetXaxis() -> GetLast();
849 if (div[0]-1 <= 1) up = 2;
856 while ( div[i] != nx) i ++;
925 if (str.
Contains(
"POL")) str = dum +
"POL";
926 if (str.
Contains(
"SPH")) str = dum +
"SPH";
927 if (str.
Contains(
"PSR")) str = dum +
"PSR";
929 if ((str==
"HIST") || (str==
"") ||
976 !(str==
"" || str==
"HIST" ||
1084 fAddMarker->
Connect(
"Toggled(Bool_t)",
"TH1Editor",
this,
"DoAddMarker(Bool_t)");
1119 fAddMarker->
Connect(
"Toggled(Bool_t)",
"TH1Editor",
this,
"DoAddMarker(Bool_t)");
1209 fAddCombo->
Connect(
"Selected(Int_t)",
"TH1Editor",
this,
"DoHistChanges()");
1321 fAddCombo->
Connect(
"Selected(Int_t)",
"TH1Editor",
this,
"DoHistChanges()");
1441 case (
kPER_0) :{ str +=
"BAR";
break;}
1442 case (
kPER_10):{ str +=
"BAR1";
break;}
1443 case (
kPER_20):{ str +=
"BAR2";
break;}
1444 case (
kPER_30):{ str +=
"BAR3";
break;}
1445 case (
kPER_40):{ str +=
"BAR4";
break;}
1488 static Int_t px1,py1,px2,py2;
1517 static Float_t p1[3], p2[3], p3[3], p4[3], p5[3], p6[3], p7[3], p8[3];
1524 p1[0] = p4[0] = p5[0] = p8[0] =
1526 p2[0] = p3[0] = p6[0] = p7[0] =
1528 p1[1] = p2[1] = p3[1] = p4[1] = rmin[1];
1529 p5[1] = p6[1] = p7[1] = p8[1] = rmax[1];
1530 p1[2] = p2[2] = p5[2] = p6[2] = rmin[2];
1531 p3[2] = p4[2] = p7[2] = p8[2] = rmax[2];
1538 for (
Int_t i = 0; i<3; i++){
1762 if (maxx==1) maxx=2;
1803 "TH1 Editor",
"It is not possible to rebin the histogram",
1820 if (number==5)
return;
1822 Int_t binNumber = 0;
1825 if (number > 5) fact = number - 4;
1826 else fact = number - 6;
1828 if (!player)
return;
1841 if (fact > 0) binNumber = fact*nx;
1842 if (fact < 0) binNumber = (
Int_t) ((-1)*nx/fact+0.5);
1843 if (binNumber < 1) binNumber = 1;
1844 if (binNumber > 10000) binNumber= 10000;
1848 min-oldOffset+newOffset,
1849 max-oldOffset+newOffset);
1861 xaxis->
FindBin(rmax-binWidth/2));
1886 Int_t binNumber = 0;
1887 if (number >= 5) fact = number - 4;
1888 else fact = number - 6;
1889 if (fact > 0) binNumber = fact*
n;
1890 if (fact < 0) binNumber = (
Int_t) ((-1)*
n/fact+0.5);
1891 if (binNumber < 1) binNumber = 1;
1892 if (binNumber > 10000) binNumber= 10000;
1911 for (
Int_t i = 2; i <= div[0]; i++) {
1937 if (!player)
return;
1950 Int_t binNumber = (
Int_t) ((max-min)/(rmax - rmin)*num + 0.5);
1951 if (binNumber < 1) binNumber = 1;
1952 if (binNumber > 10000) binNumber = 10000;
1956 min-oldOffset+offset,
1957 max-oldOffset+offset);
1969 xaxis->
FindBin(rmax-binWidth/2));
2002 Double_t offset = 1.*num/100*binWidth;
2006 if (!player)
return;
2018 min+offset-oldOffset,
2019 max+offset-oldOffset);
2027 xaxis->
FindBin(rmax+offset-oldOffset-binWidth/2));
2048 Double_t offset = 1.*num/100*binWidth;
2053 if (!player)
return;
2065 min+offset-oldOffset,
2066 max+offset-oldOffset);
2074 xaxis->
FindBin(rmax+offset-oldOffset-binWidth/2));
2097 if (!player)
return;
2109 min+offset-oldOffset,
2110 max+offset-oldOffset);
2118 xaxis->
FindBin(rmax+offset-oldOffset-binWidth/2));
2132 "TH1 Editor",
"Replace origin histogram with rebinned one?",
2142 if (div[0]-1 <= 1) up = 2;
2192 case (-1) : {s =
"LEGO";
break;}
2216 case (-1) : {s =
"POL";
break;}
2236 case (-1) : {s =
"";
break;}
2256 case (-1) : {s =
"" ;
break;}
2268 case (
kPER_0) : { s +=
"BAR" ;
break;}
2269 case (
kPER_10): { s +=
"BAR1";
break;}
2270 case (
kPER_20): { s +=
"BAR2";
break;}
2271 case (
kPER_30): { s +=
"BAR3";
break;}
2272 case (
kPER_40): { s +=
"BAR4";
break;}
2423 }
else if (
n == 1) {
2432 for (
Int_t i=2; i <=
n/2; i++) {
ULong_t Pixel_t
Pixel value.
include TDocParser_001 C image html pict1_TDocParser_001 png width
virtual void SetLineWidth(Width_t lwidth)
Set the line width.
virtual void SetLineColor(Color_t lcolor)
Set the line color.
Class to manage histogram axis.
virtual Int_t FindBin(Double_t x)
Find bin number corresponding to abscissa x.
virtual Double_t GetBinLowEdge(Int_t bin) const
Return low edge of bin.
Int_t GetLast() const
Return last bin on the axis i.e.
virtual void SetRangeUser(Double_t ufirst, Double_t ulast)
Set the viewing range for the axis from ufirst to ulast (in user coordinates, that is,...
virtual void SetRange(Int_t first=0, Int_t last=0)
Set the viewing range for the axis using bin numbers.
virtual Double_t GetBinWidth(Int_t bin) const
Return bin width.
virtual Double_t GetBinUpEdge(Int_t bin) const
Return up edge of bin.
Int_t GetFirst() const
Return first bin on the axis i.e.
void FeedbackMode(Bool_t set)
Turn rubberband feedback mode on or off.
const TGWindow * GetDefaultRoot() const
Returns the root (i.e.
void NeedRedraw(TGWindow *w, Bool_t force=kFALSE)
Set redraw flags.
A combobox (also known as a drop down listbox) allows the selection of one item out of a list of item...
virtual Int_t GetSelected() const
virtual void AddEntry(TGString *s, Int_t id)
virtual void RemoveEntries(Int_t from_ID, Int_t to_ID)
virtual void RemoveEntry(Int_t id=-1)
Remove entry. If id == -1, the currently selected entry is removed.
virtual TGListBox * GetListBox() const
virtual void Select(Int_t id, Bool_t emit=kTRUE)
Make the selected item visible in the combo box window and emit signals according to the second param...
The base class for composite widgets (menu bars, list boxes, etc.).
virtual void AddFrame(TGFrame *f, TGLayoutHints *l=0)
Add frame to the composite frame using the specified layout hints.
virtual void Layout()
Layout the elements of the composite frame.
virtual void ChangeOptions(UInt_t options)
Change composite frame options. Options is an OR of the EFrameTypes.
virtual void ShowFrame(TGFrame *f)
Show sub frame.
virtual void HideFrame(TGFrame *f)
Hide sub frame.
Dragging the slider will generate the event:
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)
A subclasses of TGWindow, and is used as base class for some simple widgets (buttons,...
virtual UInt_t GetDefaultHeight() const
virtual void Resize(UInt_t w=0, UInt_t h=0)
Resize the frame.
Bool_t Contains(Int_t x, Int_t y) const
Concrete class for horizontal slider.
virtual void Resize(UInt_t w, UInt_t h)
Resize the frame.
A horizontal 3D line is a line that typically separates a toolbar from the menubar.
A Composite frame that contains a list of TGLBEnties.
This class handles GUI labels.
This class describes layout hints used by the layout classes.
A listbox is a box, possibly with scrollbar, containing entries.
virtual void Resize(UInt_t w, UInt_t h)
Resize the listbox widget.
Defines top level windows that interact with the system Window Manager.
virtual void SetNumber(Double_t val, Bool_t emit=kTRUE)
Set the numeric value (floating point representation).
virtual Double_t GetNumber() const
Get the numeric value (floating point representation).
virtual void SetIntNumber(Long_t val, Bool_t emit=kTRUE)
Set the numeric value (integer representation).
virtual void SetLimits(ELimit limits=kNELNoLimits, Double_t min=0, Double_t max=1)
Set the numerical limits.
TGNumberEntry is a number entry input widget with up/down buttons.
TGNumberEntryField * GetNumberEntry() const
virtual Double_t GetNumber() const
virtual void SetNumber(Double_t val, Bool_t emit=kTRUE)
TGClient * fClient
Connection to display server.
virtual Int_t GetMaxPosition() const
virtual Int_t GetPosition() const
virtual void SetPosition(Int_t pos)
virtual void SetRange(Int_t min, Int_t max)
virtual void SetScale(Int_t scale)
virtual void SetEnabled(Int_t tabIndex, Bool_t on=kTRUE)
Enable or disable tab.
A text buffer is used in several widgets, like TGTextEntry, TGFileDialog, etc.
Yield an action as soon as it is clicked.
A TGTextEntry is a one line text input widget.
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.
ROOT GUI Window base class.
virtual const TGWindow * GetMainFrame() const
Returns top level main frame.
virtual TVirtualPad * GetPad() const
Base frame for implementing GUI - a service class.
virtual Option_t * GetDrawOption() const
Get draw options of the selected object.
TGedEditor * fGedEditor
manager of this frame
virtual TGVerticalFrame * CreateEditorTabSubFrame(const char *name)
Create a vertical frame to be used by 'owner' in extra tab 'name'.
virtual void SetDrawOption(Option_t *option="")
Set drawing option for object.
Bool_t fInit
init flag for setting signals/slots
virtual void MakeTitle(const char *title)
Create attribute frame title.
virtual void Refresh(TObject *model)
Refresh the GUI info about the object attributes.
virtual void Update()
Update the current pad when an attribute is changed via GUI.
Bool_t fAvoidSignal
flag for executing slots
Editor for changing TH1 histogram attributes, rebinning & fitting.
static TGComboBox * BuildHistAddComboBox(TGFrame *parent, Int_t id)
Create Line/Bar combo box.
TGNumberEntryField * fSldMin
Contains the minimum value of the x-Axis.
virtual void DoHistChanges()
Slot connected to the histogram type, the coordinate type, the error type and the Add combo box.
virtual void DoBinReleased1()
Slot connected to the BinNumber Slider in case of a ntuple histogram (does the Rebinning of the histo...
TGTextButton * fApply
Apply-Button to accept the rebinned histogram.
TGHSlider * fBinOffsetSld
Add an offset to the origin of the histogram.
TGNumberEntryField * fBinNumberEntry
Label which shows the rebinned bin number.
TGCompositeFrame * fBinCont
Contains the Rebin Widgets for case 1.
TGCheckButton * fAddSimple
Draw a simple histogram (==HIST draw option)
TH1 * fHist
histogram object
TGCheckButton * fAddMarker
Draw a Marker on top of each bin.
TString GetHistTypeLabel()
Returns the selected histogram type (HIST, LEGO1-2, SURF1-5).
virtual void DoOffsetMoved(Int_t num)
Slot connected to the OffSetSlider.
void ChangeErrorCombo(Int_t i)
Change the error combo box entry.
TGNumberEntry * fBarWidth
Change the Bar Width.
TGHSlider * fBinSlider1
Slider to set rebinning integer value for ntuple histogram.
TGNumberEntryField * fSldMax
Contains the maximum value of the x-Axis.
TGDoubleHSlider * fSlider
Slider to set x-axis range.
TGCompositeFrame * f11
Contains the Bar Width/Offset NumberEntries.
virtual void DoHBar(Bool_t on)
Slot connected to the Horizontal Bar check button.
virtual void DoBinMoved(Int_t number)
Slot connected to the rebin slider in case of a not ntuple histogram (does the Rebinning of the histo...
static TGComboBox * BuildPercentComboBox(TGFrame *parent, Int_t id)
Create Percentage combo box for bar option.
TGHButtonGroup * fDimGroup
Radiobuttongroup to change 2D <-> 3D-Plot.
TGCheckButton * fAddB
Draw a Bar Chart.
virtual void DoAddMarker(Bool_t on)
Slot connected to the show markers check box.
static TGComboBox * BuildHistErrorComboBox(TGFrame *parent, Int_t id)
Create error type combo box.
TGComboBox * fErrorCombo
Error combo box.
TGCheckButton * fDelaydraw
Delayed drawing of the new axis range.
virtual void DoAxisRange()
Slot connected to the number entry fields containing the Max/Min value of the x-axis.
virtual void DoHistView()
Slot connected to the 'Plot' button group.
TGCheckButton * fMakeHBar
Draw Horizontal Bar Chart.
virtual void ConnectSignals2Slots()
Connect signals to slots.
TGCompositeFrame * f6
Contains the Add-ComboBox (Style)
TGNumberEntryField * fOffsetNumberEntry
Shows the offset to the origin of the histogram.
TGCompositeFrame * fBinCont1
Contains the Rebin Widgets for case 2.
virtual void SetModel(TObject *obj)
Pick up current values of histogram attributes.
TGRadioButton * fDim0
3D-Plot RadioButton
TGCompositeFrame * f12
Contains fPercentCombo, fMakeHBar.
virtual void DoApply()
Slot connected to the Apply button of the Binning tab.
Int_t * Dividers(Int_t n)
Return an array of dividers of n (without the trivial divider n).
virtual ~TH1Editor()
Destructor of TH1 editor.
TGComboBox * fPercentCombo
Percentage of the Bar which is drawn in a different color.
TGTextButton * fCancel
Cancel-Button to reprobate the rebinned histogram.
virtual void DoCancel()
Slot connected to the Cancel button of the Binning tab.
TGHSlider * fBinSlider
Slider to set rebinning integer value.
TGRadioButton * fDim
2D-Plot RadioButton
Int_t fTitlePrec
font precision level
TGCheckButton * fAddBar
Bar Option.
virtual void DoHistComplex()
Slot connected to the 3D radio button.
virtual void DoSliderReleased()
Slot connected to the x-axis Range slider for finalizing the values of the slider movement.
Bool_t fSameOpt
flag for option "same"
virtual void DoAddB(Bool_t)
Slot connected to the bar Add check box.
TGCompositeFrame * f3
Contains Histogram Type.
virtual void DoHistSimple()
Slot connected to the 2D radio button.
virtual void DoBinReleased()
Slot connected to the rebin slider in case of a not ntuple histogram Updates some other widgets which...
TH1Editor(const TGWindow *p=0, Int_t width=140, Int_t height=30, UInt_t options=kChildFrame, Pixel_t back=GetDefaultFrameBackground())
Constructor of histogram attribute GUI.
TGComboBox * fTypeCombo
histogram type combo box
TGComboBox * fCoordsCombo
Coordinate System combo box.
TGTextEntry * fTitle
histogram title input field
TString GetHistAddLabel()
Return the selected shape of the histogram (C, L, LF2).
TGLayoutHints * fDim0lh
layout hints for 3D-Plot RadioButton
virtual void DoBinPressed()
Slot connected to the rebin slider in case of a not ntuple histogram.
virtual void DoAddSimple(Bool_t on)
Slot connected to fAddSimple check box for drawing a simple histogram without errors (== HIST draw op...
virtual void DoPercent()
Slot connected to the bar percentage settings.
virtual void DoBarOffset()
Slot connected to the Bar Offset of the Bar Charts.
void CreateBinTab()
Create binning tab.
virtual void DoBarWidth()
Slot connected to the Bar Width of the Bar Charts.
virtual void DoAddBar(Bool_t)
Slot connected to the bar Add check box.
TGNumberEntryField * fBinNumberEntry1
Label which shows the rebinned bin number for ntuple histogram.
virtual void PaintBox3D(Float_t *p1, Float_t *p2, Float_t *p3, Float_t *p4)
Paint a 3D box.
TString GetHistErrorLabel()
Return the selected error type (E,E1-5).
virtual void DoBinLabel()
Slot connected to the Bin number entry of the Rebinning tab.
TGLayoutHints * fDimlh
layout hints for 2D-Plot RadioButton
TGCompositeFrame * f15
Contains outer line CheckBox.
static TGComboBox * BuildHistCoordsComboBox(TGFrame *parent, Int_t id)
Create coordinate system type combo box.
TGNumberEntry * fBarOffset
Change the Bar Offset.
virtual void RecursiveRemove(TObject *obj)
If the contained histogram obj is deleted we must set its pointer to zero.
TGCompositeFrame * f9
Contains the Bar Option CheckBox.
virtual void DoOffsetReleased()
Slot connected to the OffSetSlider.
static TGComboBox * BuildHistTypeComboBox(TGFrame *parent, Int_t id)
Create histogram type combo box.
virtual Bool_t AcceptModel(TObject *model)
Check if object is able to configure with this editor.
TGCompositeFrame * f7
Contains the Marker OnOff CheckBox.
TGCompositeFrame * f8
Contains the Bar Chart CheckBox.
TGCompositeFrame * fBin
Contains the Binning Widgets.
virtual void DoBinLabel1()
Slot connected to the Bin number entry of the Rebinning tab.
TGComboBox * fAddCombo
Add Lines, Bars, Fill.
TGCompositeFrame * f10
Contains the Bar Option Title.
virtual void DoSliderMoved()
Slot connected to the x-Slider for redrawing of the histogram according to the new Slider range.
virtual void DoBinOffset()
Slot connected to the OffSetNumberEntry which is related to the OffSetSlider changes the origin of th...
virtual void DoOffsetPressed()
Slot connected to the OffSetSlider that saves the OldBinOffset (nessesary for delay draw mode).
virtual void DoTitle(const char *text)
Slot connected to the histogram title setting.
TString GetHistCoordsLabel()
Return the selected coordinate system of the histogram (POL,CYL,SPH,PSR).
virtual void DoBinMoved1()
Slot connected to the rebin slider in case of an ntuple histogram.
virtual void DoSliderPressed()
Slot connected to the x-axis Range slider for initialising the values of the slider movement.
TH1 is the base class of all histogram classes in ROOT.
virtual void SetDirectory(TDirectory *dir)
By default, when a histogram is created, it is added to the list of histogram objects in the current ...
virtual void SetTitle(const char *title)
See GetStatOverflows for more information.
virtual void SetBarOffset(Float_t offset=0.25)
Set the bar offset as fraction of the bin width for drawing mode "B".
@ kNoAxis
NOTE: Must always be 0 !!!
virtual Float_t GetBarWidth() const
virtual Float_t GetBarOffset() const
virtual void Reset(Option_t *option="")
Reset this histogram: contents, errors, etc.
TAxis * GetXaxis()
Get the behaviour adopted by the object about the statoverflows. See EStatOverflows for more informat...
TObject * Clone(const char *newname=0) const
Make a complete copy of the underlying object.
virtual Bool_t Add(TF1 *h1, Double_t c1=1, Option_t *option="")
Performs the operation: this = this + c1*f1 if errors are defined (see TH1::Sumw2),...
virtual Double_t GetEntries() const
Return the current number of entries.
virtual UInt_t SetCanExtend(UInt_t extendBitMask)
Make the histogram axes extendable / not extendable according to the bit mask returns the previous bi...
virtual void SetBins(Int_t nx, Double_t xmin, Double_t xmax)
Redefine x axis parameters.
virtual void SetBarWidth(Float_t width=0.5)
Set the width of bars as fraction of the bin width for drawing mode "B".
virtual TH1 * Rebin(Int_t ngroup=2, const char *newname="", const Double_t *xbins=0)
Rebin this histogram.
virtual const char * GetTitle() const
Returns title of object.
Mother of all ROOT objects.
virtual Bool_t InheritsFrom(const char *classname) const
Returns kTRUE if object inherits from class "classname".
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.
Bool_t Disconnect(const char *signal=0, void *receiver=0, const char *slot=0)
Disconnects signal of this object from slot of receiver.
A specialized TSelector for TTree::Draw.
virtual void TakeAction()
Execute action for object obj fNfill times.
TString & Insert(Ssiz_t pos, const char *s)
Ssiz_t First(char c) const
Find first occurrence of a character c.
const char * Data() const
void ToUpper()
Change string to upper case.
TString & Remove(Ssiz_t pos)
Bool_t Contains(const char *pat, ECaseCompare cmp=kExact) const
Implement some of the functionality of the class TTree requiring access to extra libraries (Histogram...
virtual TSelector * GetSelector() const
TH1 * GetHistogram() const
virtual Int_t GetNfill() const
virtual Double_t * GetRmax()=0
virtual Double_t * GetRmin()=0
virtual Int_t YtoAbsPixel(Double_t y) const =0
virtual Double_t GetUymax() const =0
virtual void PaintLine3D(Float_t *p1, Float_t *p2)=0
virtual TVirtualPad * cd(Int_t subpadnumber=0)=0
virtual Int_t XtoAbsPixel(Double_t x) const =0
virtual Double_t GetUymin() const =0
virtual TView * GetView() const =0
virtual TCanvas * GetCanvas() const =0
static TVirtualTreePlayer * GetCurrentPlayer()
Static function: return the current player (if any)
leg AddEntry(h1,"Histogram filled with random numbers","f")