63 Init(1, 0, 0.5, 0.5, 0.4);
73 Init(npoints, 0, 0.5, 0.5, 0.4);
93 Init(npoints, 0, 0.5, 0.5, 0.4);
108 Init(npoints, 0, 0.5, 0.5, 0.4);
126 Init(np, 0, 0.5, 0.5, 0.4);
128 for (i=first; i<=last; ++i) fPieSlices[i-first]->SetValue(h->
GetBinContent(i));
130 for (i=first; i<=last; ++i) fPieSlices[i-first]->SetTitle(axis->
GetBinLabel(i));
132 SetLabelFormat(
"%val");
146 for (
Int_t i=0;i<fNvals;++i) {
233 if ( ((ang>=phimin && ang <= phimax) || (phimax>
TMath::TwoPi() &&
244 if (dist<.95 && dist>.65) {
253 if (lang/range<.25 || rang/range<.25) {
278 if (soption.
Length()==0) soption =
"l";
281 if (!
gPad->IsEditable())
gROOT->MakeDefCanvas();
284 gPad->Range(0.,0.,1.,1.);
320 Double_t dphi = (maxphi-minphi)/ndiv;
322 if (dphi>.15) ndiv = (
Int_t) ((maxphi-minphi)/.15);
323 dphi = (maxphi-minphi)/ndiv;
326 for (
Int_t j=0;j<ndiv;++j) {
330 gPad->XtoAbsPixel(x0+
gRadius*TMath::Cos(phi+dphi)),
336 gPad->XtoAbsPixel(x0),
gPad->YtoAbsPixel(y0) );
339 gPad->YtoAbsPixel(y0),
340 gPad->XtoAbsPixel(x0),
341 gPad->YtoAbsPixel(y0+fHeight));
369 Double_t dphi = (maxphi-minphi)/ndiv;
371 if (dphi>.15) ndiv = (
Int_t) ((maxphi-minphi)/.15);
372 dphi = (maxphi-minphi)/ndiv;
375 for (
Int_t j=0;j<ndiv;++j) {
379 gPad->XtoAbsPixel(x0+
gRadius*TMath::Cos(phi+dphi)),
385 gPad->XtoAbsPixel(x0),
gPad->YtoAbsPixel(y0) );
404 static bool isMovingPie(
kFALSE);
405 static bool isMovingSlice(
kFALSE);
406 static bool isResizing(
kFALSE);
407 static bool isRotating(
kFALSE);
408 static bool onBorder(
kFALSE);
410 static Int_t prev_event(-1);
411 static Int_t oldpx, oldpy;
455 && !isMovingPie && !isMovingSlice && !isResizing) {
479 }
else if (gCurrent_rad<=fRadius*.6 && gCurrent_rad>=
fRadius*.3) {
485 if (isMovingPie || isMovingSlice)
gPad->SetCursor(
kMove);
490 if (!isMovingSlice || !isMovingPie || !isResizing || !isRotating) {
495 isMovingSlice =
kTRUE;
498 }
else if (gCurrent_rad<fRadius*.6 && gCurrent_rad>
fRadius*.3) {
507 mdx =
gPad->PixeltoX(dx);
508 mdy =
gPad->PixeltoY(dy);
510 if (isMovingPie || isMovingSlice) {
530 }
else if (isResizing) {
541 }
else if (isRotating) {
561 if ( ((isMovingPie || isMovingSlice || isRotating) &&
gPad->OpaqueMoving()) ||
562 (isResizing &&
gPad->OpaqueResizing()) ) {
574 if (
gROOT->IsEscaped()) {
587 if (isRedrawing && (isMovingPie || isMovingSlice))
gPad->SetCursor(
kMove);
589 if (isMovingPie) isMovingPie =
kFALSE;
590 if (isMovingSlice) isMovingSlice =
kFALSE;
591 if (isResizing) isResizing =
kFALSE;
614 event =
gVirtualX->RequestLocator(1, 1, px, py);
824 if ( (idx=soption.
Index(
"same"))>=0 ) {
829 if ( (idx=soption.
Index(
"nol"))>=0 ) {
834 if ( (idx=soption.
Index(
"sc"))>=0 ) {
835 optionSameColor =
kTRUE;
840 if ( (idx=soption.
Index(
"3d"))>=0 ) {
848 if ( (idx=soption.
Index(
"t"))>=0 ) {
854 if ( (idx=soption.
Index(
"r"))>=0 ) {
860 if ( (idx=soption.
Index(
">"))>=0 ) {
866 if ( (idx=soption.
Index(
"<"))>=0 ) {
877 Warning(
"Paint",
"No valid arrays of values");
910 if (optionLine==
kTRUE) {
928 if (optionLine==
kTRUE) {
950 if (optionLine==
kTRUE) {
1015 }
else if (lblor==2) {
1032 if (aphi<0) ly -=
h;
1036 if (rphi < 0 && fIs3D && label_off>=0.)
1049 if (optionSame)
return;
1054 if ((obj =
gPad->GetListOfPrimitives()->FindObject(
"title"))) {
1060 if (title)
delete title;
1068 if (ht<=0) ht = 0.05;
1090 if (talh < 1) talh = 1;
if (talh > 3) talh = 3;
1092 if (talv < 1) talv = 1;
if (talv > 3) talv = 3;
1096 if (talh == 2) xpos = xpos-wt/2.;
1097 if (talh == 3) xpos = xpos-wt;
1098 if (talv == 2) ypos = ypos+ht/2.;
1099 if (talv == 1) ypos = ypos+ht;
1101 title =
new TPaveText(xpos,ypos-ht,xpos+wt,ypos,
"blNDC");
1124 out <<
" " << std::endl;
1131 <<
"\", " <<
fNvals <<
");" << std::endl;
1132 out <<
" " <<
GetName() <<
"->SetCircle(" <<
fX <<
", " <<
fY <<
", "
1133 <<
fRadius <<
");" << std::endl;
1135 <<
"\");" << std::endl;
1137 <<
"\");" << std::endl;
1139 <<
"\");" << std::endl;
1141 <<
");" << std::endl;
1143 <<
");" << std::endl;
1152 out <<
" " <<
GetName() <<
"->GetSlice(" << i <<
")->SetTitle(\""
1154 out <<
" " <<
GetName() <<
"->GetSlice(" << i <<
")->SetValue("
1156 out <<
" " <<
GetName() <<
"->GetSlice(" << i <<
")->SetRadiusOffset("
1158 out <<
" " <<
GetName() <<
"->GetSlice(" << i <<
")->SetFillColor("
1160 out <<
" " <<
GetName() <<
"->GetSlice(" << i <<
")->SetFillStyle("
1162 out <<
" " <<
GetName() <<
"->GetSlice(" << i <<
")->SetLineColor("
1164 out <<
" " <<
GetName() <<
"->GetSlice(" << i <<
")->SetLineStyle("
1166 out <<
" " <<
GetName() <<
"->GetSlice(" << i <<
")->SetLineWidth("
1170 out <<
" " <<
GetName() <<
"->Draw(\"" << option <<
"\");" << std::endl;
1179 while (val>360.) val -= 360.;
1180 while (val<0) val += 360.;
1181 if (val>=90 && val<180) val = 180-val;
1182 else if (val>=180 && val<=360) val = 360-val;
1287 if (!colors)
return;
1372 "It's not possible set the radius to a negative value");
1407 if (
fSlices && !force)
return;
1414 "Negative values in TPie, absolute value will be used");
1420 if (
fSum<=.0)
return;
1464 if (merge_threshold>0) {
1483 delete merged_slice;
1489 new_array[0] = merged_slice;
1490 for (
Int_t i=0;i<old_fNvals;++i) {
1507 delete merged_slice;
1513 new_array[
fNvals-1] = merged_slice;
1514 for (
Int_t i=old_fNvals-1;i>=0;--i) {
virtual void Clear(Option_t *option="")
Clear all entries in this legend, including the header.
Int_t GetFirst() const
Return first bin on the axis i.e.
virtual const char * GetTitle() const
Returns title of object.
const char * GetLabelFormat()
Int_t GetEntryFillColor(Int_t)
Return the color of the slice number "i".
virtual Style_t GetLineStyle() const
virtual Style_t GetFillStyle() const
virtual void SetLineWidth(Width_t lwidth)
double dist(Rotation3D const &r1, Rotation3D const &r2)
void SetPercentFormat(const char *)
Set the numeric format for the percent value of a slice, default: %3.1f.
void MakeSlices(Bool_t force=kFALSE)
Make the slices.
virtual void SetName(const char *name="")
virtual Color_t GetLabelColor() const
virtual void PaintEllipse(Double_t x1, Double_t y1, Double_t r1, Double_t r2, Double_t phimin, Double_t phimax, Double_t theta, Option_t *option="")
Draw this ellipse with new coordinates.
virtual Float_t GetTextAngle() const
virtual void Draw(Option_t *option="")
Draw this pavetext with its current attributes.
Float_t GetTitleW() const
void DrawGhost()
This method is for internal use.
virtual Double_t GetBinContent(Int_t bin) const
Return content of bin number bin.
This class displays a legend box (TPaveText) containing several legend entries.
virtual Font_t GetTextFont() const
Float_t * fSlices
Sum for the slice values.
const char * GetBinLabel(Int_t bin) const
Return label for bin.
virtual void SetX2NDC(Double_t x2)
TString & ReplaceAll(const TString &s1, const TString &s2)
static Int_t GetColorDark(Int_t color)
Static function: Returns the dark color number corresponding to n If the TColor object does not exist...
R__EXTERN TStyle * gStyle
virtual void Draw(Option_t *option="")
Draw this legend with its current attributes.
Color_t GetTitleFillColor() const
void SavePrimitive(std::ostream &out, Option_t *opts="")
Save primitive as a C++ statement(s) on output stream out.
const char * GetValueFormat()
Int_t GetEntryLineColor(Int_t)
Return the line color used to outline thi "i" slice.
virtual TText * AddText(Double_t x1, Double_t y1, const char *label)
Add a new Text line to this pavetext at given coordinates.
virtual Float_t GetTextSize() const
Double_t GetX1NDC() const
void SetAngularOffset(Double_t)
Set the global angular offset for slices in degree [0,360].
TLegend * fLegend
Subdivisions of the slices.
Float_t GetTitleX() const
Float_t GetTitleFontSize() const
Short_t Min(Short_t a, Short_t b)
void ToLower()
Change string to lower-case.
TPieSlice * GetSlice(Int_t i)
Return the reference to the slice of index 'id'.
virtual void SetFillStyle(Style_t fstyle)
void SetEntryFillStyle(Int_t, Int_t)
Set the fill style for the "i" slice.
void SetBit(UInt_t f, Bool_t set)
Set or unset the user status bits as specified in f.
Width_t GetTitleBorderSize() const
virtual void AppendPad(Option_t *option="")
Append graphics object to current pad.
void SetAngle3D(Float_t val=30.)
Set the value of for the pseudo 3D view angle, in degree.
const char * Data() const
void SetEntryVal(Int_t, Double_t)
Set the value of a slice.
virtual void SetTextFont(Font_t tfont=62)
Int_t GetEntryLineStyle(Int_t)
Return the style used to outline thi "i" slice.
static const double x2[5]
Double_t GetYsize()
Return size of the formula along Y in pad coordinates.
virtual void Paint(Option_t *)
Paint a Pie chart in a canvas.
Int_t GetEntryFillStyle(Int_t)
Return the style use to fill the slice number "i".
virtual void Paint(Option_t *option="")
Paint this pavetext with its current attributes.
Color_t GetTitleTextColor() const
The TNamed class is the base class for all named ROOT classes.
Double_t GetEntryRadiusOffset(Int_t)
Return the radial offset's value for the slice number "i".
To draw Mathematical Formula.
virtual Color_t GetTextColor() const
void Init(TClassEdit::TInterpreterLookupHelper *helper)
void SetEntryRadiusOffset(Int_t, Double_t)
Set the distance, in the direction of the radius of the slice.
void SetHeight(Double_t val=.08)
Set the height, in pixel, for the piechart if is drawn using the pseudo-3d mode.
A slice of a piechart, see the TPie class.
Base class for several text objects.
const char * GetEntryLabel(Int_t)
Returns the label of the entry number "i".
Double_t ATan2(Double_t, Double_t)
void SetRadiusOffset(Double_t)
Set the radial offset of this slice.
Double_t GetAngularOffset()
virtual void PaintLatex(Double_t x, Double_t y, Double_t angle, Double_t size, const char *text)
Main drawing function.
Double_t GetEntryVal(Int_t)
Return the value associated with the slice number "i".
Int_t DistancetoSlice(Int_t, Int_t)
Returns the slice number at the pixel position (px,py).
void SetX(Double_t)
Set X value.
virtual void PaintLine(Double_t x1, Double_t y1, Double_t x2, Double_t y2)
Draw this line with new coordinates.
Int_t GetOptTitle() const
void SetFractionFormat(const char *)
Set numeric format in the label, is used if the label format there is the modifier frac...
virtual void SetLineColor(Color_t lcolor)
virtual TText * GetLine(Int_t number) const
Get Pointer to line number in this pavetext.
virtual Int_t DistancetoPrimitive(Int_t px, Int_t py)
Evaluate the distance to the chart in gPad.
Double_t GetXsize()
Return size of the formula along X in pad coordinates.
Class to manage histogram axis.
TPaveLabel title(3, 27.1, 15, 28.7,"ROOT Environment and Tools")
virtual void SetFillColor(Color_t fcolor)
void SetLabels(const char *[])
Set the labels for all the slices.
void SetY(Double_t)
Set Y value.
virtual Color_t GetFillColor() const
char * Form(const char *fmt,...)
void SortSlices(Bool_t amode=kTRUE, Float_t merge_thresold=.0)
This method, mainly intended for internal use, ordered the slices according their values...
virtual const char * GetName() const
Returns name of object.
Style_t GetTitleStyle() const
virtual Color_t GetLineColor() const
void SetValue(Double_t)
Set the value for this slice.
void SetFillColors(Int_t *)
Set the fill colors for all the TPie's slices.
void SetCircle(Double_t x=.5, Double_t y=.5, Double_t rad=.4)
Set the coordinates of the circle that describe the pie:
Int_t GetColorPalette(Int_t i) const
Return color number i in current palette.
virtual void ExecuteEvent(Int_t, Int_t, Int_t)
Execute the mouse events.
TString & Remove(Ssiz_t pos)
static const double x1[5]
A Pave (see TPave) with text, lines or/and boxes inside.
void SetRadius(Double_t)
Set the pie chart's radius' value.
TLegendEntry * AddEntry(const TObject *obj, const char *label="", Option_t *option="lpf")
Add a new entry to this legend.
TPie()
Default constructor.
virtual Style_t GetLabelFont() const
Double_t GetValue()
Return the value of this slice.
TLegend * MakeLegend(Double_t x1=.65, Double_t y1=.65, Double_t x2=.95, Double_t y2=.95, const char *leg_header="")
This method create a legend that explains the contents of the slice for this pie-chart.
void SetLabelsOffset(Float_t)
Set the distance between the label end the external line of the TPie.
Double_t fHeight
true if the pseudo-3d is enabled
virtual void SetLineStyle(Style_t lstyle)
Double_t fX
Legend for this piechart.
Int_t GetLast() const
Return last bin on the axis i.e.
void SetLabelFormat(const char *)
This method is used to customize the label format.
void SetEntryFillColor(Int_t, Int_t)
Set the color for the slice "i".
Mother of all ROOT objects.
void SetEntryLineStyle(Int_t, Int_t)
Set the style for the slice's outline. "i" is the slice number.
virtual Float_t GetLabelSize() const
THashList * GetLabels() const
Double_t GetRadiusOffset()
return the value of the offset in radial direction for this slice.
Float_t GetTitleY() const
Short_t Max(Short_t a, Short_t b)
Bool_t Contains(const char *pat, ECaseCompare cmp=kExact) const
TLegend * GetLegend()
If created before by Paint option or by MakeLegend method return the pointer to the legend...
Float_t GetLabelOffset(Option_t *axis="X") const
Return label offset.
Float_t GetLabelsOffset()
void SetEntryLineColor(Int_t, Int_t)
Set the color for the slice's outline. "i" is the slice number.
const char * GetPercentFormat()
Int_t GetEntryLineWidth(Int_t)
Return the line width used to outline thi "i" slice.
virtual void SetTextColor(Color_t tcolor=1)
void Init(Int_t np, Double_t ao, Double_t x, Double_t y, Double_t r)
Common initialization for all constructors.
Style_t GetTitleFont(Option_t *axis="X") const
Return title font.
Double_t Sqrt(Double_t x)
virtual void SetTextSize(Float_t tsize=1)
void SetIsActive(Bool_t is)
Ssiz_t Index(const char *pat, Ssiz_t i=0, ECaseCompare cmp=kExact) const
void SetEntryLineWidth(Int_t, Int_t)
Set the width of the slice's outline. "i" is the slice number.
virtual void Draw(Option_t *option="l")
Draw the pie chart.
virtual Width_t GetLineWidth() const
virtual void SetTitle(const char *title="")
Change (i.e. set) the title of the TNamed.
void SetEntryLabel(Int_t, const char *text="Slice")
Set slice number "i" label.
virtual void SetBorderSize(Int_t bordersize=4)
Float_t GetTitleH() const
void SetValueFormat(const char *)
Set the numeric format the slices' values.
virtual void Warning(const char *method, const char *msgfmt,...) const
Issue warning message.