TGaxis
class description - source file - inheritance tree
    public:
                          TGaxis()
                          TGaxis(Double_t xmin, Double_t ymin, Double_t xmax, Double_t ymax, Double_t wmin, Double_t wmax, Int_t ndiv = 510, Option_t* chopt, Double_t gridlength = 0)
                          TGaxis(Double_t xmin, Double_t ymin, Double_t xmax, Double_t ymax, const char* funcname, Int_t ndiv = 510, Option_t* chopt, Double_t gridlength = 0)
                          TGaxis(const TGaxis&)
                  virtual ~TGaxis()
             virtual void AdjustBinSize(Double_t A1, Double_t A2, Int_t nold, Double_t& BinLow, Double_t& BinHigh, Int_t& nbins, Double_t& BinWidth)
             virtual void CenterLabels(Bool_t center = kTRUE)
             virtual void CenterTitle(Bool_t center = kTRUE)
           static TClass* Class()
             virtual void DrawAxis(Double_t xmin, Double_t ymin, Double_t xmax, Double_t ymax, Double_t wmin, Double_t wmax, Int_t ndiv = 510, Option_t* chopt, Double_t gridlength = 0)
                     TF1* GetFunction() const
                  Float_t GetGridLength() const
                    Int_t GetLabelColor() const
                    Int_t GetLabelFont() const
                  Float_t GetLabelOffset() const
                  Float_t GetLabelSize() const
             static Int_t GetMaxDigits()
      virtual const char* GetName() const
                    Int_t GetNdiv() const
      virtual const char* GetOption() const
                  Float_t GetTickSize() const
      virtual const char* GetTitle() const
                  Float_t GetTitleOffset() const
                  Float_t GetTitleSize() const
                 Double_t GetWmax() const
                 Double_t GetWmin() const
             virtual void ImportAxisAttributes(TAxis* axis)
          virtual TClass* IsA() const
                     void LabelsLimits(const char* label, Int_t& first, Int_t& last)
             virtual void Paint(Option_t* chopt)
             virtual void PaintAxis(Double_t xmin, Double_t ymin, Double_t xmax, Double_t ymax, Double_t& wmin, Double_t& wmax, Int_t& ndiv, Option_t* chopt, Double_t gridlength = 0, Bool_t drawGridOnly = kFALSE)
             virtual void Rotate(Double_t X, Double_t Y, Double_t CFI, Double_t SFI, Double_t XT, Double_t YT, Double_t& U, Double_t& V)
             virtual void SavePrimitive(ofstream& out, Option_t* option)
                     void SetFunction(const char* funcname)
                     void SetGridLength(Float_t gridlength)
                     void SetLabelColor(Int_t labelcolor)
                     void SetLabelFont(Int_t labelfont)
                     void SetLabelOffset(Float_t labeloffset)
                     void SetLabelSize(Float_t labelsize)
              static void SetMaxDigits(Int_t maxd = 5)
             virtual void SetName(const char* name)
             virtual void SetNoExponent(Bool_t noExponent = kTRUE)
                     void SetOption(Option_t* option)
                     void SetTickSize(Float_t ticksize)
                     void SetTimeFormat(const char* tformat)
                     void SetTimeOffset(Double_t toffset)
             virtual void SetTitle(const char* title)
                     void SetTitleOffset(Float_t titleoffset = 1)
                     void SetTitleSize(Float_t titlesize)
                     void SetWmax(Double_t wmax)
                     void SetWmin(Double_t wmin)
             virtual void ShowMembers(TMemberInspector& insp, char* parent)
             virtual void Streamer(TBuffer& b)
                     void StreamerNVirtual(TBuffer& b)
    protected:
          Double_t fWmin          Lowest value on the axis
          Double_t fWmax          Highest value on the axis
           Float_t fGridLength    Length of the grid in NDC
           Float_t fTickSize      Size of primary tick mark in NDC
           Float_t fLabelOffset   Offset of label wrt axis
           Float_t fLabelSize     Size of labels in NDC
           Float_t fTitleOffset   Offset of title wrt axis
           Float_t fTitleSize     Size of title in NDC
             Int_t fNdiv          Number of divisions
             Int_t fLabelColor    Color for labels
             Int_t fLabelFont     Font for labels
           TString fChopt         Axis options
           TString fName          axis name
           TString fTitle         axis title
           TString fTimeFormat    Time format, ex: 09/12/99 12:34:00
           TString fFunctionName  name of mapping function pointed by fFunction
              TF1* fFunction      !Pointer to function computing axis values
            TAxis* fAxis          !pointer to original TAxis axis (if any)
      static Int_t fgMaxDigits    !Number of digits above which the 10>N notation is used
    public:
      static const enum TGaxis:: kCenterTitle   
      static const enum TGaxis:: kCenterLabels  
      static const enum TGaxis:: kRotateTitle   
      static const enum TGaxis:: kNoExponent    
 Service class for the graphical representation of axis.
 Instances of this class are generated by the histogram classes and TGraph.
 The picture below has been generated by the following macro.
{
  gROOT.Reset();
  c1 = new TCanvas("c1","Examples of Gaxis",10,10,700,500);
  c1->Range(-10,-1,10,1);
  TGaxis *axis1 = new TGaxis(-4.5,-0.2,5.5,-0.2,-6,8,510,"");
  axis1->SetName("axis1");
  axis1->Draw();
  TGaxis *axis2 = new TGaxis(-4.5,0.2,5.5,0.2,0.001,10000,510,"G");
  axis2->SetName("axis2");
  axis2->Draw();
  TGaxis *axis3 = new TGaxis(-9,-0.8,-9,0.8,-8,8,50510,"");
  axis3->SetName("axis3");
  axis3->Draw();
  TGaxis *axis4 = new TGaxis(-7,-0.8,-7,0.8,1,10000,50510,"G");
  axis4->SetName("axis4");
  axis4->Draw();
  TGaxis *axis5 = new TGaxis(-4.5,-0.6,5.5,-0.6,1.2,1.32,80506,"-+");
  axis5->SetName("axis5");
  axis5->SetLabelSize(0.03);
  axis5->SetTextFont(72);
  axis5->SetLabelOffset(0.025);
  axis5->Draw();
  TGaxis *axis6 = new TGaxis(-4.5,0.6,5.5,0.6,100,900,50510,"-");
  axis6->SetName("axis6");
  axis6->Draw();
  TGaxis *axis7 = new TGaxis(8,-0.8,8,0.8,0,9000,50510,"+L");
  axis7->SetName("axis7");
  axis7->SetLabelOffset(0.01);
  axis7->Draw();
  //one can make axis going top->bottom. However because of a long standing
  //problem, the two x values should not be equal
  TGaxis *axis8 = new TGaxis(6.5,0.8,6.499,-0.8,0,90,50510,"-");
  axis8->SetName("axis8");
  axis8->Draw();
}
/*
 */
  See the second TGaxis constructor for examples of TGaxis
  with a mapping function.
*/
  See the second TGaxis constructor for examples of TGaxis
  with a mapping function.
 TGaxis(): TLine(), TAttText(11,0,1,62,0.040)
*-*-*-*-*-*-*-*-*-*-*Gaxis default constructor-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*
*-*                  =========================
 TGaxis(Double_t xmin, Double_t ymin, Double_t xmax, Double_t ymax,
               Double_t wmin, Double_t wmax, Int_t ndiv,   Option_t *chopt,
               Double_t gridlength)
       : TLine(xmin,ymin,xmax,ymax), TAttText(11,0,1,62,0.040)
*-*-*-*-*-*-*-*-*-*-*Gaxis normal constructor-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*
*-*                  =========================
  See explanation of parameters in PaintAxis
 TGaxis(Double_t xmin, Double_t ymin, Double_t xmax, Double_t ymax,
               const char *funcname, Int_t ndiv,   Option_t *chopt,
               Double_t gridlength)
       : TLine(xmin,ymin,xmax,ymax), TAttText(11,0,1,62,0.040)
*-*-*-*-*-*-*-*-*-*-*Gaxis constructor with a TF1 to map axis values-*-*-*
*-*                  ===============================================
  See explanation of parameters in PaintAxis
  Instead of the wmin,wmax arguments of the normal constructor, the
  name of a TF1 function can be specified. This function will be used
  by TGaxis::PaintAxis to map the user coordinates to the axis values
  and ticks.
  Examples:
void gaxis3a()
{
   gStyle->SetOptStat(0);
   TH2F *h2 = new TH2F("h","Axes",100,0,10,100,-2,2);
   h2->Draw();
   TF1 *f1=new TF1("f1","-x",-10,10);
   TGaxis *A1 = new TGaxis(0,2,10,2,"f1",510,"-");
   A1->SetTitle("axis with decreasing values");
   A1->Draw();
   TF1 *f2=new TF1("f2","exp(x)",0,2);
   TGaxis *A2 = new TGaxis(1,1,9,1,"f2");
   A2->SetTitle("exponential axis");
   A2->SetLabelSize(0.03);
   A2->SetTitleSize(0.03);
   A2->SetTitleOffset(1.2);
   A2->Draw();
   TF1 *f3=new TF1("f3","log10(x)",1,1000);
   TGaxis *A3 = new TGaxis(2,-2,2,0,"f3",505,"G");
   A3->SetTitle("logarithmic axis");
   A3->SetLabelSize(0.03);
   A3->SetTitleSize(0.03);
   A3->SetTitleOffset(1.2);
   A3->Draw();
}
/*
 */
*/
 ~TGaxis()
*-*-*-*-*-*-*-*-*-*-*Gaxis default destructor-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*
*-*                  =======================
void CenterLabels(Bool_t center)
   if center = kTRUE axis labels are centered in the center of the bin
   default is to center on the primary tick marks
   This option does not make sense if there are more bins than tick marks.
void CenterTitle(Bool_t center)
   if center = kTRUE axis title will be centered
   default is right adjusted
void DrawAxis(Double_t xmin, Double_t ymin, Double_t xmax, Double_t ymax,
                      Double_t wmin, Double_t wmax, Int_t ndiv,   Option_t *chopt,
                      Double_t gridlength)
*-*-*-*-*-*-*-*-*-*-*Draw this axis with new attributes*-*-*-*-*-*-*-*-*-*
*-*                  ==================================
Int_t GetMaxDigits()
 static function returning fgMaxDigits (See SetMaxDigits)
void ImportAxisAttributes(TAxis *axis)
 Copy TAxis attributes to this TGaxis
void Paint(Option_t *)
*-*-*-*-*-*-*-*-*-*-*Draw this axis with its current attributes*-*-*-*-*-*-*
*-*                  ==========================================
void PaintAxis(Double_t xmin, Double_t ymin, Double_t xmax, Double_t ymax,
                       Double_t &wmin, Double_t &wmax, Int_t &ndiv,   Option_t *chopt,
                       Double_t gridlength, Bool_t drawGridOnly)
*-*-*-*-*-*-*-*-*-*-*-*Control function to draw an axis*-*-*-*-*-*-*-*-*-*-*
*-*                    ================================
============> Original authors (O.Couet C.E.Vandoni N.Cremel-Somon)
              largely modified and converted to C++ class by Rene Brun
 _Input parameters:
  xmin      : X origin coordinate in WC space.
  xmax      : X end axis coordinate in WC space.
  ymin      : Y origin coordinate in WC space.
  ymax      : Y end axis coordinate in WC space.
  wmin      : Lowest value for the tick mark
              labels written on the axis.
  wmax      : Highest value for the tick mark labels
              written on the axis.
  ndiv      : Number of divisions.
       ndiv=N1 + 100*N2 + 10000*N3
       N1=number of 1st divisions.
       N2=number of 2nd divisions.
       N3=number of 3rd divisions.
           e.g.:
           nndi=0 --> no tick marks.
           nndi=2 --> 2 divisions, one tick mark in the middle
                      of the axis.
  chopt :  Options (see below).
       chopt='G': loGarithmic scale, default is linear.
       chopt='B': Blank axis. Useful to superpose axis.
 Orientation of tick marks on axis.
 ----------------------------------
   Tick marks are normally drawn on the positive side of the axis,
   however, if X0=X1, then negative.
       chopt='+': tick marks are drawn on Positive side. (default)
       chopt='-': tick mark are drawn on the negative side.
       i.e: '+-' --> tick marks are drawn on both sides of the axis.
       chopt='U': Unlabeled axis, default is labeled.
 Size of tick marks
 ------------------
 By default, tick marks have a length equal to 3 per cent of the
 axis length.
 When the option "S" is specified, the length of the tick marks
 is equal to fTickSize*axis_length, where fTickSize may be set
 via TGaxis::SetTickSize.
 Position of labels on axis.
 ---------------------------
   Labels are normally drawn on side opposite to tick marks.
   However:
       chopt='=': on Equal side
 Orientation of labels on axis.
 ------------------------------
   Labels are normally drawn parallel to the axis.
   However if X0=X1, then Orthogonal
           if Y0=Y1, then Parallel
 Position of labels on tick marks.
 ---------------------------------
   Labels are centered on tick marks.
   However , if X0=X1, then they are right adjusted.
       chopt='R': labels are Right adjusted on tick mark.
                    (default is centered)
       chopt='L': labels are Left adjusted on tick mark.
       chopt='C': labels are Centered on tick mark.
       chopt='M': In the Middle of the divisions.
 Format of labels.
 -----------------
   Blank characters are stripped, and then the
   label is correctly aligned. the dot, if last
   character of the string, is also stripped.
   In the following, we have some parameters, like
   tick marks length and characters height (in percentage
   of the length of the axis (WC))
   The default values are as follows:
   Primary tick marks: 3.0 %
   Secondary tick marks: 1.5 %
   Third order tick marks: .75 %
   Characters height for labels: 4%
   Labels offset: 1.0 %
 Optional grid.
 --------------
       chopt='W': cross-Wire
 Axis bining optimization.
 -------------------------
   By default the axis bining is optimized .
       chopt='N': No bining optimization
       chopt='I': Integer labelling
 Maximum Number of Digits for the axis labels
 --------------------------------------------
 See the static function TGaxis::SetMaxDigits
 Time representation.
 --------------------
   Axis labels may be considered as times, plotted in a defined time format.
   The format is set with SetTimeFormat().
   wmin and wmax are considered as two time values in seconds.
   The time axis will be spread around the time offset value (set with
   SetTimeOffset() ). Actually it will go from TimeOffset+wmin to
   TimeOffset+wmax.
   see examples in tutorials timeonaxis.C and timeonaxis2.C
       chopt='t': Plot times with a defined format instead of values
void AdjustBinSize(Double_t A1,  Double_t A2,  Int_t nold
                          ,Double_t &BinLow, Double_t &BinHigh, Int_t &nbins, Double_t &BinWidth)
*-*-*-*-*-*-*-*-*-*-*-*Axis labels optimisation*-*-*-*-*-*-*-*-*-*-*-*-*-*
*-*                    ========================
   This routine adjusts the bining of the axis
   in order to have integer values for the labels
 _Input parameters:
  A1,A2    : Old WMIN,WMAX .
  BinLow,BinHigh : New WMIN,WMAX .
  nold     : Old NDIV (primary divisions)
  nbins    : New NDIV .
void LabelsLimits(const char *label, Int_t &first, Int_t &last)
*-*-*-*-*-*-*-*-*Find first and last character of a label*-*-*-*-*-*-*-*-*-*
*-*              ========================================
void Rotate(Double_t X,  Double_t Y,  Double_t CFI, Double_t SFI
                   ,Double_t XT, Double_t YT, Double_t &U,   Double_t &V)
*-*-*-*-*-*-*-*-*-*-*-*-*-*Rotate axis coordinates*-*-*-*-*-*-*-*-*-*-*-*-*
*-*                        =======================
void SavePrimitive(ofstream &out, Option_t *)
 Save primitive as a C++ statement(s) on output stream out
void SetFunction(const char *funcname)
        specify a function to map the axis values
        =========================================
void SetMaxDigits(Int_t maxd)
 static function to set fgMaxDigits
fgMaxDigits is the maximum number of digits permitted for the axis
labels above which the notation with 10^N is used.
For example, to accept 6 digits number like 900000 on an axis
call TGaxis::SetMaxDigits(6). The default value is 5.
fgMaxDigits must be greater than 0.
void SetName(const char *name)
*-*-*-*-*-*-*-*-*-*-*Change the name of the axis*-*-*-*-*-*-*-*-*-*-*-*-*-*
*-*                  ============================
void SetNoExponent(Bool_t noExponent)
 Set the NoExponent flag
 By default, an exponent of the form 10^N is used when the label values
 are either all very small or very large.
 One can disable the exponent by calling axis.SetNoExponent(kTRUE).
void SetOption(Option_t *option)
*-*-*-*-*-*-*-*-*-*-*-*-*-*-*To set axis options*-*-*-*-*-*-*-*-*-*-*-*-*-*
*-*                          ===================
void SetTitle(const char *title)
*-*-*-*-*-*-*-*-*-*-*Change the title of the axis*-*-*-*-*-*-*-*-*-*-*-*-*
*-*                  ============================
void SetTimeFormat(const char *tformat)
*-*-*-*-*-*-*-*-*-*-*Change the format used for time plotting *-*-*-*-*-*-*-*
*-*                  ========================================
  The format string for date and time use the same options as the one used
  in the standard strftime C function, i.e. :
    for date :
      %a abbreviated weekday name
      %b abbreviated month name
      %d day of the month (01-31)
      %m month (01-12)
      %y year without century
    for time :
      %H hour (24-hour clock)
      %I hour (12-hour clock)
      %p local equivalent of AM or PM
      %M minute (00-59)
      %S seconds (00-61)
      %% %
void SetTimeOffset(Double_t toffset)
 Change the time offset
void Streamer(TBuffer &R__b)
 Stream an object of class TGaxis.
Inline Functions
            Float_t GetGridLength() const
               TF1* GetFunction() const
              Int_t GetLabelColor() const
              Int_t GetLabelFont() const
            Float_t GetLabelOffset() const
            Float_t GetLabelSize() const
            Float_t GetTitleOffset() const
            Float_t GetTitleSize() const
        const char* GetName() const
        const char* GetOption() const
        const char* GetTitle() const
              Int_t GetNdiv() const
           Double_t GetWmin() const
           Double_t GetWmax() const
            Float_t GetTickSize() const
               void SetLabelColor(Int_t labelcolor)
               void SetLabelFont(Int_t labelfont)
               void SetLabelOffset(Float_t labeloffset)
               void SetLabelSize(Float_t labelsize)
               void SetTickSize(Float_t ticksize)
               void SetGridLength(Float_t gridlength)
               void SetTitleOffset(Float_t titleoffset = 1)
               void SetTitleSize(Float_t titlesize)
               void SetWmin(Double_t wmin)
               void SetWmax(Double_t wmax)
            TClass* Class()
            TClass* IsA() const
               void ShowMembers(TMemberInspector& insp, char* parent)
               void StreamerNVirtual(TBuffer& b)
             TGaxis TGaxis(const TGaxis&)
Author: Rene Brun, Olivier Couet 12/12/94
Last update: root/graf:$Name:  $:$Id: TGaxis.cxx,v 1.51 2003/06/02 17:11:42 brun Exp $
Copyright  (C) 1995-2000, Rene Brun and Fons Rademakers.               *
ROOT page - Class index - Top of the page
This page has been automatically generated. If you have any comments or suggestions about the page layout send a mail to ROOT support, or contact the developers with any questions or problems regarding ROOT.