Logo ROOT  
Reference Guide
TPie Class Reference

Draw a Pie Chart,.

Example:

void piechart()
{
Float_t vals[] = {.2,1.1,.6,.9,2.3};
Int_t colors[] = {2,3,4,5,6};
Int_t nvals = sizeof(vals)/sizeof(vals[0]);
TCanvas *cpie = new TCanvas("cpie","TPie test",700,700);
cpie->Divide(2,2);
TPie *pie1 = new TPie("pie1",
"Pie with offset and no colors",nvals,vals);
TPie *pie2 = new TPie("pie2",
"Pie with radial labels",nvals,vals,colors);
TPie *pie3 = new TPie("pie3",
"Pie with tangential labels",nvals,vals,colors);
TPie *pie4 = new TPie("pie4",
"Pie with verbose labels",nvals,vals,colors);
cpie->cd(1);
pie1->SetAngularOffset(30.);
pie1->SetEntryRadiusOffset( 4, 0.1);
pie1->SetRadius(.35);
pie1->Draw("3d");
cpie->cd(2);
pie2->SetEntryRadiusOffset(2,.05);
pie2->SetEntryLineColor(2,2);
pie2->SetEntryLineWidth(2,5);
pie2->SetEntryLineStyle(2,2);
pie2->SetEntryFillStyle(1,3030);
pie2->SetCircle(.5,.45,.3);
pie2->Draw("rsc");
cpie->cd(3);
pie3->SetY(.32);
pie3->GetSlice(0)->SetValue(.8);
pie3->GetSlice(1)->SetFillStyle(3031);
pie3->SetLabelsOffset(-.1);
pie3->Draw("3d t nol");
TLegend *pieleg = pie3->MakeLegend();
pieleg->SetY1(.56); pieleg->SetY2(.86);
cpie->cd(4);
pie4->SetRadius(.2);
pie4->SetLabelsOffset(.01);
pie4->SetLabelFormat("#splitline{%val (%perc)}{%txt}");
pie4->Draw("nol <");
}
int Int_t
Definition: RtypesCore.h:41
float Float_t
Definition: RtypesCore.h:53
Color * colors
Definition: X3DBuffer.c:21
virtual void SetFillStyle(Style_t fstyle)
Set the fill area style.
Definition: TAttFill.h:39
The Canvas class.
Definition: TCanvas.h:31
TVirtualPad * cd(Int_t subpadnumber=0)
Set current canvas & pad.
Definition: TCanvas.cxx:696
This class displays a legend box (TPaveText) containing several legend entries.
Definition: TLegend.h:23
virtual void Divide(Int_t nx=1, Int_t ny=1, Float_t xmargin=0.01, Float_t ymargin=0.01, Int_t color=0)
Automatic pad generation by division.
Definition: TPad.cxx:1163
virtual void SetY2(Double_t y2)
Set the Y2 value.
Definition: TPave.cxx:686
virtual void SetY1(Double_t y1)
Set the Y1 value.
Definition: TPave.cxx:673
void SetValue(Double_t)
Set the value for this slice.
Definition: TPieSlice.cxx:108
Draw a Pie Chart,.
Definition: TPie.h:23
TPieSlice * GetSlice(Int_t i)
Return the reference to the slice of index 'id'.
Definition: TPie.cxx:712
void SetAngularOffset(Double_t)
Set the global angular offset for slices in degree [0,360].
Definition: TPie.cxx:1191
void SetEntryFillStyle(Int_t, Int_t)
Set the fill style for the "i" slice.
Definition: TPie.cxx:1260
TPie()
Default constructor.
Definition: TPie.cxx:61
void SetY(Double_t)
Set Y value.
Definition: TPie.cxx:1397
void SetLabelsOffset(Float_t)
Set the distance between the label end the external line of the TPie.
Definition: TPie.cxx:1351
virtual void Draw(Option_t *option="l")
Draw the pie chart.
Definition: TPie.cxx:274
void SetEntryRadiusOffset(Int_t, Double_t)
Set the distance, in the direction of the radius of the slice.
Definition: TPie.cxx:1268
void SetLabelFormat(const char *)
This method is used to customize the label format.
Definition: TPie.cxx:1314
void SetEntryLineStyle(Int_t, Int_t)
Set the style for the slice's outline. "i" is the slice number.
Definition: TPie.cxx:1236
void SetEntryLineWidth(Int_t, Int_t)
Set the width of the slice's outline. "i" is the slice number.
Definition: TPie.cxx:1244
void SetCircle(Double_t x=.5, Double_t y=.5, Double_t rad=.4)
Set the coordinates of the circle that describe the pie:
Definition: TPie.cxx:1208
void SetRadius(Double_t)
Set the pie chart's radius' value.
Definition: TPie.cxx:1367
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.
Definition: TPie.cxx:768
void SetEntryLineColor(Int_t, Int_t)
Set the color for the slice's outline. "i" is the slice number.
Definition: TPie.cxx:1228

Definition at line 23 of file TPie.h.

Public Member Functions

 TPie ()
 Default constructor. More...
 
 TPie (const char *, const char *, Int_t)
 This constructor creates a pie chart when only the number of the slices is known. More...
 
 TPie (const char *, const char *, Int_t, Double_t *, Int_t *cols=0, const char *lbls[]=0)
 Normal constructor. More...
 
 TPie (const char *, const char *, Int_t, Float_t *, Int_t *cols=0, const char *lbls[]=0)
 Normal constructor (Float_t). More...
 
 TPie (const TH1 *h)
 Constructor from a TH1. More...
 
 TPie (const TPie &)
 Copy constructor. More...
 
 ~TPie ()
 Destructor. More...
 
virtual Int_t DistancetoPrimitive (Int_t px, Int_t py)
 Evaluate the distance to the chart in gPad. More...
 
Int_t DistancetoSlice (Int_t, Int_t)
 Returns the slice number at the pixel position (px,py). More...
 
virtual void Draw (Option_t *option="l")
 Draw the pie chart. More...
 
virtual void ExecuteEvent (Int_t, Int_t, Int_t)
 Execute the mouse events. More...
 
Float_t GetAngle3D ()
 
Double_t GetAngularOffset ()
 
Int_t GetEntries ()
 
Int_t GetEntryFillColor (Int_t)
 Return the color of the slice number "i". More...
 
Int_t GetEntryFillStyle (Int_t)
 Return the style use to fill the slice number "i". More...
 
const char * GetEntryLabel (Int_t)
 Returns the label of the entry number "i". More...
 
Int_t GetEntryLineColor (Int_t)
 Return the line color used to outline thi "i" slice. More...
 
Int_t GetEntryLineStyle (Int_t)
 Return the style used to outline thi "i" slice. More...
 
Int_t GetEntryLineWidth (Int_t)
 Return the line width used to outline thi "i" slice. More...
 
Double_t GetEntryRadiusOffset (Int_t)
 Return the radial offset's value for the slice number "i". More...
 
Double_t GetEntryVal (Int_t)
 Return the value associated with the slice number "i". More...
 
const char * GetFractionFormat ()
 
Double_t GetHeight ()
 
const char * GetLabelFormat ()
 
Float_t GetLabelsOffset ()
 
TLegendGetLegend ()
 If created before by Paint option or by MakeLegend method return the pointer to the legend, otherwise return 0;. More...
 
const char * GetPercentFormat ()
 
Double_t GetRadius ()
 
TPieSliceGetSlice (Int_t i)
 Return the reference to the slice of index 'id'. More...
 
const char * GetValueFormat ()
 
Double_t GetX ()
 
Double_t GetY ()
 
TLegendMakeLegend (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. More...
 
void MakeSlices (Bool_t force=kFALSE)
 Make the slices. More...
 
virtual void Paint (Option_t *)
 Paint a Pie chart in a canvas. More...
 
void SavePrimitive (std::ostream &out, Option_t *opts="")
 Save primitive as a C++ statement(s) on output stream out. More...
 
void SetAngle3D (Float_t val=30.)
 Set the value of for the pseudo 3D view angle, in degree. More...
 
void SetAngularOffset (Double_t)
 Set the global angular offset for slices in degree [0,360]. More...
 
void SetCircle (Double_t x=.5, Double_t y=.5, Double_t rad=.4)
 Set the coordinates of the circle that describe the pie: More...
 
void SetEntryFillColor (Int_t, Int_t)
 Set the color for the slice "i". More...
 
void SetEntryFillStyle (Int_t, Int_t)
 Set the fill style for the "i" slice. More...
 
void SetEntryLabel (Int_t, const char *text="Slice")
 Set slice number "i" label. More...
 
void SetEntryLineColor (Int_t, Int_t)
 Set the color for the slice's outline. "i" is the slice number. More...
 
void SetEntryLineStyle (Int_t, Int_t)
 Set the style for the slice's outline. "i" is the slice number. More...
 
void SetEntryLineWidth (Int_t, Int_t)
 Set the width of the slice's outline. "i" is the slice number. More...
 
void SetEntryRadiusOffset (Int_t, Double_t)
 Set the distance, in the direction of the radius of the slice. More...
 
void SetEntryVal (Int_t, Double_t)
 Set the value of a slice. More...
 
void SetFillColors (Int_t *)
 Set the fill colors for all the TPie's slices. More...
 
void SetFractionFormat (const char *)
 Set numeric format in the label, is used if the label format there is the modifier frac, in this case the value is printed using this format. More...
 
void SetHeight (Double_t val=.08)
 Set the height, in pixel, for the piechart if is drawn using the pseudo-3d mode. More...
 
void SetLabelFormat (const char *)
 This method is used to customize the label format. More...
 
void SetLabels (const char *[])
 Set the labels for all the slices. More...
 
void SetLabelsOffset (Float_t)
 Set the distance between the label end the external line of the TPie. More...
 
void SetPercentFormat (const char *)
 Set the numeric format for the percent value of a slice, default: %3.1f. More...
 
void SetRadius (Double_t)
 Set the pie chart's radius' value. More...
 
void SetValueFormat (const char *)
 Set the numeric format the slices' values. More...
 
void SetX (Double_t)
 Set X value. More...
 
void SetY (Double_t)
 Set Y value. More...
 
void SortSlices (Bool_t amode=kTRUE, Float_t merge_thresold=.0)
 This method, mainly intended for internal use, ordered the slices according their values. More...
 
- Public Member Functions inherited from TNamed
 TNamed ()
 
 TNamed (const char *name, const char *title)
 
 TNamed (const TNamed &named)
 TNamed copy ctor. More...
 
 TNamed (const TString &name, const TString &title)
 
virtual ~TNamed ()
 TNamed destructor. More...
 
virtual void Clear (Option_t *option="")
 Set name and title to empty strings (""). More...
 
virtual TObjectClone (const char *newname="") const
 Make a clone of an object using the Streamer facility. More...
 
virtual Int_t Compare (const TObject *obj) const
 Compare two TNamed objects. More...
 
virtual void Copy (TObject &named) const
 Copy this to obj. More...
 
virtual void FillBuffer (char *&buffer)
 Encode TNamed into output buffer. More...
 
virtual const char * GetName () const
 Returns name of object. More...
 
virtual const char * GetTitle () const
 Returns title of object. More...
 
virtual ULong_t Hash () const
 Return hash value for this object. More...
 
virtual Bool_t IsSortable () const
 
virtual void ls (Option_t *option="") const
 List TNamed name and title. More...
 
TNamedoperator= (const TNamed &rhs)
 TNamed assignment operator. More...
 
virtual void Print (Option_t *option="") const
 Print TNamed name and title. More...
 
virtual void SetName (const char *name)
 Set the name of the TNamed. More...
 
virtual void SetNameTitle (const char *name, const char *title)
 Set all the TNamed parameters (name and title). More...
 
virtual void SetTitle (const char *title="")
 Set the title of the TNamed. More...
 
virtual Int_t Sizeof () const
 Return size of the TNamed part of the TObject. More...
 
- Public Member Functions inherited from TObject
 TObject ()
 TObject constructor. More...
 
 TObject (const TObject &object)
 TObject copy ctor. More...
 
virtual ~TObject ()
 TObject destructor. More...
 
void AbstractMethod (const char *method) const
 Use this method to implement an "abstract" method that you don't want to leave purely abstract. More...
 
virtual void AppendPad (Option_t *option="")
 Append graphics object to current pad. More...
 
virtual void Browse (TBrowser *b)
 Browse object. May be overridden for another default action. More...
 
ULong_t CheckedHash ()
 Check and record whether this class has a consistent Hash/RecursiveRemove setup (*) and then return the regular Hash value for this object. More...
 
virtual const char * ClassName () const
 Returns name of class to which the object belongs. More...
 
virtual void Clear (Option_t *="")
 
virtual TObjectClone (const char *newname="") const
 Make a clone of an object using the Streamer facility. More...
 
virtual Int_t Compare (const TObject *obj) const
 Compare abstract method. More...
 
virtual void Copy (TObject &object) const
 Copy this to obj. More...
 
virtual void Delete (Option_t *option="")
 Delete this object. More...
 
virtual Int_t DistancetoPrimitive (Int_t px, Int_t py)
 Computes distance from point (px,py) to the object. More...
 
virtual void Draw (Option_t *option="")
 Default Draw method for all objects. More...
 
virtual void DrawClass () const
 Draw class inheritance tree of the class to which this object belongs. More...
 
virtual TObjectDrawClone (Option_t *option="") const
 Draw a clone of this object in the current selected pad for instance with: gROOT->SetSelectedPad(gPad). More...
 
virtual void Dump () const
 Dump contents of object on stdout. More...
 
virtual void Error (const char *method, const char *msgfmt,...) const
 Issue error message. More...
 
virtual void Execute (const char *method, const char *params, Int_t *error=0)
 Execute method on this object with the given parameter string, e.g. More...
 
virtual void Execute (TMethod *method, TObjArray *params, Int_t *error=0)
 Execute method on this object with parameters stored in the TObjArray. More...
 
virtual void ExecuteEvent (Int_t event, Int_t px, Int_t py)
 Execute action corresponding to an event at (px,py). More...
 
virtual void Fatal (const char *method, const char *msgfmt,...) const
 Issue fatal error message. More...
 
virtual TObjectFindObject (const char *name) const
 Must be redefined in derived classes. More...
 
virtual TObjectFindObject (const TObject *obj) const
 Must be redefined in derived classes. More...
 
virtual Option_tGetDrawOption () const
 Get option used by the graphics system to draw this object. More...
 
virtual const char * GetIconName () const
 Returns mime type name of object. More...
 
virtual const char * GetName () const
 Returns name of object. More...
 
virtual char * GetObjectInfo (Int_t px, Int_t py) const
 Returns string containing info about the object at position (px,py). More...
 
virtual Option_tGetOption () const
 
virtual const char * GetTitle () const
 Returns title of object. More...
 
virtual UInt_t GetUniqueID () const
 Return the unique object id. More...
 
virtual Bool_t HandleTimer (TTimer *timer)
 Execute action in response of a timer timing out. More...
 
virtual ULong_t Hash () const
 Return hash value for this object. More...
 
Bool_t HasInconsistentHash () const
 Return true is the type of this object is known to have an inconsistent setup for Hash and RecursiveRemove (i.e. More...
 
virtual void Info (const char *method, const char *msgfmt,...) const
 Issue info message. More...
 
virtual Bool_t InheritsFrom (const char *classname) const
 Returns kTRUE if object inherits from class "classname". More...
 
virtual Bool_t InheritsFrom (const TClass *cl) const
 Returns kTRUE if object inherits from TClass cl. More...
 
virtual void Inspect () const
 Dump contents of this object in a graphics canvas. More...
 
void InvertBit (UInt_t f)
 
virtual Bool_t IsEqual (const TObject *obj) const
 Default equal comparison (objects are equal if they have the same address in memory). More...
 
virtual Bool_t IsFolder () const
 Returns kTRUE in case object contains browsable objects (like containers or lists of other objects). More...
 
R__ALWAYS_INLINE Bool_t IsOnHeap () const
 
virtual Bool_t IsSortable () const
 
R__ALWAYS_INLINE Bool_t IsZombie () const
 
virtual void ls (Option_t *option="") const
 The ls function lists the contents of a class on stdout. More...
 
void MayNotUse (const char *method) const
 Use this method to signal that a method (defined in a base class) may not be called in a derived class (in principle against good design since a child class should not provide less functionality than its parent, however, sometimes it is necessary). More...
 
virtual Bool_t Notify ()
 This method must be overridden to handle object notification. More...
 
void Obsolete (const char *method, const char *asOfVers, const char *removedFromVers) const
 Use this method to declare a method obsolete. More...
 
void operator delete (void *ptr)
 Operator delete. More...
 
void operator delete[] (void *ptr)
 Operator delete []. More...
 
voidoperator new (size_t sz)
 
voidoperator new (size_t sz, void *vp)
 
voidoperator new[] (size_t sz)
 
voidoperator new[] (size_t sz, void *vp)
 
TObjectoperator= (const TObject &rhs)
 TObject assignment operator. More...
 
virtual void Paint (Option_t *option="")
 This method must be overridden if a class wants to paint itself. More...
 
virtual void Pop ()
 Pop on object drawn in a pad to the top of the display list. More...
 
virtual void Print (Option_t *option="") const
 This method must be overridden when a class wants to print itself. More...
 
virtual Int_t Read (const char *name)
 Read contents of object with specified name from the current directory. More...
 
virtual void RecursiveRemove (TObject *obj)
 Recursively remove this object from a list. More...
 
void ResetBit (UInt_t f)
 
virtual void SaveAs (const char *filename="", Option_t *option="") const
 Save this object in the file specified by filename. More...
 
virtual void SavePrimitive (std::ostream &out, Option_t *option="")
 Save a primitive as a C++ statement(s) on output stream "out". More...
 
void SetBit (UInt_t f)
 
void SetBit (UInt_t f, Bool_t set)
 Set or unset the user status bits as specified in f. More...
 
virtual void SetDrawOption (Option_t *option="")
 Set drawing option for object. More...
 
virtual void SetUniqueID (UInt_t uid)
 Set the unique object id. More...
 
virtual void SysError (const char *method, const char *msgfmt,...) const
 Issue system error message. More...
 
R__ALWAYS_INLINE Bool_t TestBit (UInt_t f) const
 
Int_t TestBits (UInt_t f) const
 
virtual void UseCurrentStyle ()
 Set current style settings in this object This function is called when either TCanvas::UseCurrentStyle or TROOT::ForceStyle have been invoked. More...
 
virtual void Warning (const char *method, const char *msgfmt,...) const
 Issue warning message. More...
 
virtual Int_t Write (const char *name=0, Int_t option=0, Int_t bufsize=0)
 Write this object to the current directory. More...
 
virtual Int_t Write (const char *name=0, Int_t option=0, Int_t bufsize=0) const
 Write this object to the current directory. More...
 
- Public Member Functions inherited from TAttText
 TAttText ()
 AttText default constructor. More...
 
 TAttText (Int_t align, Float_t angle, Color_t color, Style_t font, Float_t tsize)
 AttText normal constructor. More...
 
virtual ~TAttText ()
 AttText destructor. More...
 
void Copy (TAttText &atttext) const
 Copy this text attributes to a new TAttText. More...
 
virtual Short_t GetTextAlign () const
 Return the text alignment. More...
 
virtual Float_t GetTextAngle () const
 Return the text angle. More...
 
virtual Color_t GetTextColor () const
 Return the text color. More...
 
virtual Font_t GetTextFont () const
 Return the text font. More...
 
virtual Float_t GetTextSize () const
 Return the text size. More...
 
virtual void Modify ()
 Change current text attributes if necessary. More...
 
virtual void ResetAttText (Option_t *toption="")
 Reset this text attributes to default values. More...
 
virtual void SaveTextAttributes (std::ostream &out, const char *name, Int_t alidef=12, Float_t angdef=0, Int_t coldef=1, Int_t fondef=61, Float_t sizdef=1)
 Save text attributes as C++ statement(s) on output stream out. More...
 
virtual void SetTextAlign (Short_t align=11)
 Set the text alignment. More...
 
virtual void SetTextAngle (Float_t tangle=0)
 Set the text angle. More...
 
virtual void SetTextAttributes ()
 Invoke the DialogCanvas Text attributes. More...
 
virtual void SetTextColor (Color_t tcolor=1)
 Set the text color. More...
 
virtual void SetTextColorAlpha (Color_t tcolor, Float_t talpha)
 Set a transparent marker color. More...
 
virtual void SetTextFont (Font_t tfont=62)
 Set the text font. More...
 
virtual void SetTextSize (Float_t tsize=1)
 Set the text size. More...
 
virtual void SetTextSizePixels (Int_t npixels)
 Set the text size in pixels. More...
 

Protected Attributes

Float_t fAngle3D
 The angle of the pseudo-3d view. More...
 
Double_t fAngularOffset
 Offset angular offset for the first slice. More...
 
TString fFractionFormat
 Rform numeric format for the fraction of a slice. More...
 
Double_t fHeight
 Height of the slice in pixel. More...
 
Bool_t fIs3D
 ! true if the pseudo-3d is enabled More...
 
TString fLabelFormat
 Format format of the slices' label. More...
 
Float_t fLabelsOffset
 LabelsOffset offset of label. More...
 
Int_t fNvals
 Number of elements. More...
 
TString fPercentFormat
 Pfrom numeric format for the percent of a slice. More...
 
TPieSlice ** fPieSlices
 [fNvals] Slice array of this pie-chart More...
 
Double_t fRadius
 Radius Pie radius. More...
 
TString fValueFormat
 Vform numeric format for the value. More...
 
Double_t fX
 X coordinate of the pie centre. More...
 
Double_t fY
 Y coordinate of the pie centre. More...
 
- Protected Attributes inherited from TNamed
TString fName
 
TString fTitle
 
- Protected Attributes inherited from TAttText
Short_t fTextAlign
 Text alignment. More...
 
Float_t fTextAngle
 Text angle. More...
 
Color_t fTextColor
 Text color. More...
 
Font_t fTextFont
 Text font. More...
 
Float_t fTextSize
 Text size. More...
 

Private Member Functions

void DrawGhost ()
 This method is for internal use. More...
 
void Init (Int_t np, Double_t ao, Double_t x, Double_t y, Double_t r)
 Common initialization for all constructors. More...
 

Private Attributes

TLegendfLegend
 !Legend for this piechart More...
 
Float_tfSlices
 !Subdivisions of the slices More...
 
Float_t fSum
 !Sum for the slice values More...
 

Additional Inherited Members

- Public Types inherited from TObject
enum  {
  kIsOnHeap = 0x01000000 , kNotDeleted = 0x02000000 , kZombie = 0x04000000 , kInconsistent = 0x08000000 ,
  kBitMask = 0x00ffffff
}
 
enum  { kSingleKey = BIT(0) , kOverwrite = BIT(1) , kWriteDelete = BIT(2) }
 
enum  EDeprecatedStatusBits { kObjInCanvas = BIT(3) }
 
enum  EStatusBits {
  kCanDelete = BIT(0) , kMustCleanup = BIT(3) , kIsReferenced = BIT(4) , kHasUUID = BIT(5) ,
  kCannotPick = BIT(6) , kNoContextMenu = BIT(8) , kInvalidObject = BIT(13)
}
 
- Static Public Member Functions inherited from TObject
static Long_t GetDtorOnly ()
 Return destructor only flag. More...
 
static Bool_t GetObjectStat ()
 Get status of object stat flag. More...
 
static void SetDtorOnly (void *obj)
 Set destructor only flag. More...
 
static void SetObjectStat (Bool_t stat)
 Turn on/off tracking of objects in the TObjectTable. More...
 
- Protected Member Functions inherited from TObject
virtual void DoError (int level, const char *location, const char *fmt, va_list va) const
 Interface to ErrorHandler (protected). More...
 
void MakeZombie ()
 

#include <TPie.h>

Inheritance diagram for TPie:
[legend]

Constructor & Destructor Documentation

◆ TPie() [1/6]

TPie::TPie ( )

Default constructor.

Definition at line 61 of file TPie.cxx.

◆ TPie() [2/6]

TPie::TPie ( const char *  name,
const char *  title,
Int_t  npoints 
)

This constructor creates a pie chart when only the number of the slices is known.

The number of slices is fixed.

Definition at line 70 of file TPie.cxx.

◆ TPie() [3/6]

TPie::TPie ( const char *  name,
const char *  title,
Int_t  npoints,
Double_t vals,
Int_t colors = 0,
const char *  lbls[] = 0 
)

Normal constructor.

The 1st and 2nd parameters are the name of the object and its title.

The number of points passed at this point is used to allocate the memory.

Slices values are given as Double_t.

The 4th elements is an array containing, in double precision format, the value of each slice. It is also possible to specify the filled color of each slice. If the color array is not specified the slices are colored using a color sequence in the standard palette.

Definition at line 89 of file TPie.cxx.

◆ TPie() [4/6]

TPie::TPie ( const char *  name,
const char *  title,
Int_t  npoints,
Float_t vals,
Int_t cols = 0,
const char *  lbls[] = 0 
)

Normal constructor (Float_t).

Definition at line 103 of file TPie.cxx.

◆ TPie() [5/6]

TPie::TPie ( const TH1 h)

Constructor from a TH1.

Definition at line 118 of file TPie.cxx.

◆ TPie() [6/6]

TPie::TPie ( const TPie cpy)

Copy constructor.

Definition at line 142 of file TPie.cxx.

◆ ~TPie()

TPie::~TPie ( )

Destructor.

Definition at line 154 of file TPie.cxx.

Member Function Documentation

◆ DistancetoPrimitive()

Int_t TPie::DistancetoPrimitive ( Int_t  px,
Int_t  py 
)
virtual

Evaluate the distance to the chart in gPad.

Reimplemented from TObject.

Definition at line 168 of file TPie.cxx.

◆ DistancetoSlice()

Int_t TPie::DistancetoSlice ( Int_t  px,
Int_t  py 
)

Returns the slice number at the pixel position (px,py).

Returns -1 if no slice is picked.

Used by DistancetoPrimitive.

Definition at line 188 of file TPie.cxx.

◆ Draw()

void TPie::Draw ( Option_t option = "l")
virtual

Draw the pie chart.

The possible options are listed in the TPie::Paint() method.

Reimplemented from TObject.

Definition at line 274 of file TPie.cxx.

◆ DrawGhost()

void TPie::DrawGhost ( )
private

This method is for internal use.

It is used by Execute event to draw the outline of "this" TPie. Used when the opaque movements are not permitted.

Definition at line 297 of file TPie.cxx.

◆ ExecuteEvent()

void TPie::ExecuteEvent ( Int_t  event,
Int_t  px,
Int_t  py 
)
virtual

Execute the mouse events.

Reimplemented from TObject.

Definition at line 393 of file TPie.cxx.

◆ GetAngle3D()

Float_t TPie::GetAngle3D ( )
inline

Definition at line 61 of file TPie.h.

◆ GetAngularOffset()

Double_t TPie::GetAngularOffset ( )
inline

Definition at line 62 of file TPie.h.

◆ GetEntries()

Int_t TPie::GetEntries ( )
inline

Definition at line 76 of file TPie.h.

◆ GetEntryFillColor()

Int_t TPie::GetEntryFillColor ( Int_t  i)

Return the color of the slice number "i".

Definition at line 646 of file TPie.cxx.

◆ GetEntryFillStyle()

Int_t TPie::GetEntryFillStyle ( Int_t  i)

Return the style use to fill the slice number "i".

Definition at line 654 of file TPie.cxx.

◆ GetEntryLabel()

const char * TPie::GetEntryLabel ( Int_t  i)

Returns the label of the entry number "i".

Definition at line 638 of file TPie.cxx.

◆ GetEntryLineColor()

Int_t TPie::GetEntryLineColor ( Int_t  i)

Return the line color used to outline thi "i" slice.

Definition at line 662 of file TPie.cxx.

◆ GetEntryLineStyle()

Int_t TPie::GetEntryLineStyle ( Int_t  i)

Return the style used to outline thi "i" slice.

Definition at line 670 of file TPie.cxx.

◆ GetEntryLineWidth()

Int_t TPie::GetEntryLineWidth ( Int_t  i)

Return the line width used to outline thi "i" slice.

Definition at line 678 of file TPie.cxx.

◆ GetEntryRadiusOffset()

Double_t TPie::GetEntryRadiusOffset ( Int_t  i)

Return the radial offset's value for the slice number "i".

Definition at line 686 of file TPie.cxx.

◆ GetEntryVal()

Double_t TPie::GetEntryVal ( Int_t  i)

Return the value associated with the slice number "i".

Definition at line 694 of file TPie.cxx.

◆ GetFractionFormat()

const char * TPie::GetFractionFormat ( )
inline

Definition at line 71 of file TPie.h.

◆ GetHeight()

Double_t TPie::GetHeight ( )
inline

Definition at line 72 of file TPie.h.

◆ GetLabelFormat()

const char * TPie::GetLabelFormat ( )
inline

Definition at line 73 of file TPie.h.

◆ GetLabelsOffset()

Float_t TPie::GetLabelsOffset ( )
inline

Definition at line 74 of file TPie.h.

◆ GetLegend()

TLegend * TPie::GetLegend ( )

If created before by Paint option or by MakeLegend method return the pointer to the legend, otherwise return 0;.

Definition at line 703 of file TPie.cxx.

◆ GetPercentFormat()

const char * TPie::GetPercentFormat ( )
inline

Definition at line 77 of file TPie.h.

◆ GetRadius()

Double_t TPie::GetRadius ( )
inline

Definition at line 78 of file TPie.h.

◆ GetSlice()

TPieSlice * TPie::GetSlice ( Int_t  id)

Return the reference to the slice of index 'id'.

There are no controls of memory corruption, be carefull.

Definition at line 712 of file TPie.cxx.

◆ GetValueFormat()

const char * TPie::GetValueFormat ( )
inline

Definition at line 80 of file TPie.h.

◆ GetX()

Double_t TPie::GetX ( )
inline

Definition at line 81 of file TPie.h.

◆ GetY()

Double_t TPie::GetY ( )
inline

Definition at line 82 of file TPie.h.

◆ Init()

void TPie::Init ( Int_t  np,
Double_t  ao,
Double_t  x,
Double_t  y,
Double_t  r 
)
private

Common initialization for all constructors.

This is a private function called to allocate the memory.

Definition at line 721 of file TPie.cxx.

◆ MakeLegend()

TLegend * TPie::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.

The parameter passed reppresents the option passed to shown the slices, see TLegend::AddEntry() for further details.

The pointer of the TLegend is returned.

Definition at line 768 of file TPie.cxx.

◆ MakeSlices()

void TPie::MakeSlices ( Bool_t  force = kFALSE)

Make the slices.

If they already exist it does nothing unless force=kTRUE.

Definition at line 1406 of file TPie.cxx.

◆ Paint()

void TPie::Paint ( Option_t option)
virtual

Paint a Pie chart in a canvas.

The possible option are:

  • "R" Print the labels along the central "R"adius of slices.
  • "T" Print the label in a direction "T"angent to circle that describes the TPie.
  • "SC" Paint the the labels with the "S"ame "C"olor as the slices.
  • "3D" Draw the pie-chart with a pseudo 3D effect.
  • "NOL" No OutLine: Don't draw the slices' outlines, any property over the slices' line is ignored.
  • ">" Sort the slices in increasing order.
  • "<" Sort the slices in decreasing order.

After the use of > or < options the internal order of the TPieSlices is changed.

Other options changing the labels' format are described in TPie::SetLabelFormat().

Reimplemented from TObject.

Definition at line 802 of file TPie.cxx.

◆ SavePrimitive()

void TPie::SavePrimitive ( std::ostream &  out,
Option_t opts = "" 
)
virtual

Save primitive as a C++ statement(s) on output stream out.

Reimplemented from TObject.

Definition at line 1123 of file TPie.cxx.

◆ SetAngle3D()

void TPie::SetAngle3D ( Float_t  val = 30.)

Set the value of for the pseudo 3D view angle, in degree.

The range of the permitted values is: [0,90]

Definition at line 1178 of file TPie.cxx.

◆ SetAngularOffset()

void TPie::SetAngularOffset ( Double_t  offset)

Set the global angular offset for slices in degree [0,360].

Definition at line 1191 of file TPie.cxx.

◆ SetCircle()

void TPie::SetCircle ( Double_t  x = .5,
Double_t  y = .5,
Double_t  rad = .4 
)

Set the coordinates of the circle that describe the pie:

  • the 1st and the 2nd arguments are the x and y center's coordinates.
  • the 3rd value is the pie-chart's radius.

All the coordinates are in NDC space.

Definition at line 1208 of file TPie.cxx.

◆ SetEntryFillColor()

void TPie::SetEntryFillColor ( Int_t  i,
Int_t  color 
)

Set the color for the slice "i".

Definition at line 1252 of file TPie.cxx.

◆ SetEntryFillStyle()

void TPie::SetEntryFillStyle ( Int_t  i,
Int_t  style 
)

Set the fill style for the "i" slice.

Definition at line 1260 of file TPie.cxx.

◆ SetEntryLabel()

void TPie::SetEntryLabel ( Int_t  i,
const char *  text = "Slice" 
)

Set slice number "i" label.

The first parameter is the index of the slice, the other is the label text.

Definition at line 1219 of file TPie.cxx.

◆ SetEntryLineColor()

void TPie::SetEntryLineColor ( Int_t  i,
Int_t  color 
)

Set the color for the slice's outline. "i" is the slice number.

Definition at line 1228 of file TPie.cxx.

◆ SetEntryLineStyle()

void TPie::SetEntryLineStyle ( Int_t  i,
Int_t  style 
)

Set the style for the slice's outline. "i" is the slice number.

Definition at line 1236 of file TPie.cxx.

◆ SetEntryLineWidth()

void TPie::SetEntryLineWidth ( Int_t  i,
Int_t  width 
)

Set the width of the slice's outline. "i" is the slice number.

Definition at line 1244 of file TPie.cxx.

◆ SetEntryRadiusOffset()

void TPie::SetEntryRadiusOffset ( Int_t  i,
Double_t  shift 
)

Set the distance, in the direction of the radius of the slice.

Definition at line 1268 of file TPie.cxx.

◆ SetEntryVal()

void TPie::SetEntryVal ( Int_t  i,
Double_t  val 
)

Set the value of a slice.

Definition at line 1276 of file TPie.cxx.

◆ SetFillColors()

void TPie::SetFillColors ( Int_t colors)

Set the fill colors for all the TPie's slices.

Definition at line 1286 of file TPie.cxx.

◆ SetFractionFormat()

void TPie::SetFractionFormat ( const char *  fmt)

Set numeric format in the label, is used if the label format there is the modifier frac, in this case the value is printed using this format.

The numeric format use the standard C modifier used in stdio library: f, %2.1$, e... for further documentation you can use the printf man page ("man 3 printf" on linux)

Example:

mypie->SetLabelFormat("%txt (%frac)");
mypie->SetFractionFormat("2.1f");

Definition at line 1334 of file TPie.cxx.

◆ SetHeight()

void TPie::SetHeight ( Double_t  val = .08)

Set the height, in pixel, for the piechart if is drawn using the pseudo-3d mode.

The default value is 20 pixel.

Definition at line 1298 of file TPie.cxx.

◆ SetLabelFormat()

void TPie::SetLabelFormat ( const char *  fmt)

This method is used to customize the label format.

The format string must contain one of these modifiers:

  • txt : to print the text label associated with the slice
  • val : to print the numeric value of the slice
  • frac : to print the relative fraction of this slice
  • perc : to print the % of this slice

ex. : mypie->SetLabelFormat("%txt (%frac)");

Definition at line 1314 of file TPie.cxx.

◆ SetLabels()

void TPie::SetLabels ( const char *  lbls[])

Set the labels for all the slices.

Definition at line 1342 of file TPie.cxx.

◆ SetLabelsOffset()

void TPie::SetLabelsOffset ( Float_t  labelsoffset)

Set the distance between the label end the external line of the TPie.

Definition at line 1351 of file TPie.cxx.

◆ SetPercentFormat()

void TPie::SetPercentFormat ( const char *  fmt)

Set the numeric format for the percent value of a slice, default: %3.1f.

Definition at line 1359 of file TPie.cxx.

◆ SetRadius()

void TPie::SetRadius ( Double_t  rad)

Set the pie chart's radius' value.

Definition at line 1367 of file TPie.cxx.

◆ SetValueFormat()

void TPie::SetValueFormat ( const char *  fmt)

Set the numeric format the slices' values.

Used by val (see SetLabelFormat()).

Definition at line 1381 of file TPie.cxx.

◆ SetX()

void TPie::SetX ( Double_t  x)

Set X value.

Definition at line 1389 of file TPie.cxx.

◆ SetY()

void TPie::SetY ( Double_t  y)

Set Y value.

Definition at line 1397 of file TPie.cxx.

◆ SortSlices()

void TPie::SortSlices ( Bool_t  amode = kTRUE,
Float_t  merge_threshold = .0 
)

This method, mainly intended for internal use, ordered the slices according their values.

The default (amode=kTRUE) is increasing order, but is also possible in decreasing order (amode=kFALSE).

If the merge_threshold>0 the slice that contains a quantity smaller than merge_threshold are merged together

Definition at line 1441 of file TPie.cxx.

Member Data Documentation

◆ fAngle3D

Float_t TPie::fAngle3D
protected

The angle of the pseudo-3d view.

Definition at line 46 of file TPie.h.

◆ fAngularOffset

Double_t TPie::fAngularOffset
protected

Offset angular offset for the first slice.

Definition at line 36 of file TPie.h.

◆ fFractionFormat

TString TPie::fFractionFormat
protected

Rform numeric format for the fraction of a slice.

Definition at line 40 of file TPie.h.

◆ fHeight

Double_t TPie::fHeight
protected

Height of the slice in pixel.

Definition at line 45 of file TPie.h.

◆ fIs3D

Bool_t TPie::fIs3D
protected

! true if the pseudo-3d is enabled

Definition at line 44 of file TPie.h.

◆ fLabelFormat

TString TPie::fLabelFormat
protected

Format format of the slices' label.

Definition at line 38 of file TPie.h.

◆ fLabelsOffset

Float_t TPie::fLabelsOffset
protected

LabelsOffset offset of label.

Definition at line 37 of file TPie.h.

◆ fLegend

TLegend* TPie::fLegend
private

!Legend for this piechart

Definition at line 30 of file TPie.h.

◆ fNvals

Int_t TPie::fNvals
protected

Number of elements.

Definition at line 42 of file TPie.h.

◆ fPercentFormat

TString TPie::fPercentFormat
protected

Pfrom numeric format for the percent of a slice.

Definition at line 41 of file TPie.h.

◆ fPieSlices

TPieSlice** TPie::fPieSlices
protected

[fNvals] Slice array of this pie-chart

Definition at line 43 of file TPie.h.

◆ fRadius

Double_t TPie::fRadius
protected

Radius Pie radius.

Definition at line 35 of file TPie.h.

◆ fSlices

Float_t* TPie::fSlices
private

!Subdivisions of the slices

Definition at line 29 of file TPie.h.

◆ fSum

Float_t TPie::fSum
private

!Sum for the slice values

Definition at line 28 of file TPie.h.

◆ fValueFormat

TString TPie::fValueFormat
protected

Vform numeric format for the value.

Definition at line 39 of file TPie.h.

◆ fX

Double_t TPie::fX
protected

X coordinate of the pie centre.

Definition at line 33 of file TPie.h.

◆ fY

Double_t TPie::fY
protected

Y coordinate of the pie centre.

Definition at line 34 of file TPie.h.

Libraries for TPie:
[legend]

The documentation for this class was generated from the following files: