// @(#)root/histpainter:$Name:  $:$Id: THistPainter.h,v 1.23 2004/10/05 10:28:24 brun Exp $
// Author: Rene Brun   26/08/99

/*************************************************************************
 * Copyright (C) 1995-2000, Rene Brun and Fons Rademakers.               *
 * All rights reserved.                                                  *
 *                                                                       *
 * For the licensing terms see $ROOTSYS/LICENSE.                         *
 * For the list of contributors see $ROOTSYS/README/CREDITS.             *
 *************************************************************************/
#ifndef ROOT_THistPainter
#define ROOT_THistPainter


//////////////////////////////////////////////////////////////////////////
//                                                                      //
// THistPainter                                                         //
//                                                                      //
// helper class to draw histograms                                      //
//                                                                      //
//////////////////////////////////////////////////////////////////////////


#ifndef ROOT_TVirtualHistPainter
#include "TVirtualHistPainter.h"
#endif

#ifndef ROOT_TH1
#include "TH1.h"
#endif
#ifndef ROOT_TCutG
#include "TCutG.h"
#endif

class TGaxis;
class TPainter3dAlgorithms;
class TGraphPainter;
const Int_t kMaxCuts = 16;

class THistPainter : public TVirtualHistPainter {

protected:
    TH1                  *fH;                 //pointer to histogram to paint
    TAxis                *fXaxis;             //pointer to X axis
    TAxis                *fYaxis;             //pointer to Y axis
    TAxis                *fZaxis;             //pointer to Z axis
    TList                *fFunctions;         //pointer to histogram list of functions
    TPainter3dAlgorithms *fLego;              //pointer to a TPainter3dAlgorithms object
    TGraphPainter        *fGraphPainter;      //pointer to a fGraphPainter object
    Double_t             *fXbuf;              //X buffer coordinates
    Double_t             *fYbuf;              //Y buffer coordinates
    Int_t                 fNcuts;             //Number of graphical cuts
    Int_t                 fCutsOpt[kMaxCuts]; //sign of each cut
    TCutG                *fCuts[kMaxCuts];    //Pointers to graphical cuts
    TList                *fStack;             //Pointer to stack of histograms (if any)

public:
    THistPainter();
    virtual ~THistPainter();
    virtual void       DefineColorLevels(Int_t ndivz);
    virtual Int_t      DistancetoPrimitive(Int_t px, Int_t py);
    virtual void       DrawPanel();
    virtual void       ExecuteEvent(Int_t event, Int_t px, Int_t py);
    virtual void       FitPanel();
    virtual TList     *GetContourList(Double_t contour) const;
    virtual char      *GetObjectInfo(Int_t px, Int_t py) const;
    virtual TList     *GetStack() const {return fStack;}
    virtual Bool_t     IsInside(Int_t x, Int_t y);
    virtual Bool_t     IsInside(Double_t x, Double_t y);
    virtual Int_t      MakeChopt(Option_t *option);
    virtual Int_t      MakeCuts(char *cutsopt);
    virtual void       Paint(Option_t *option="");
    virtual void       PaintArrows(Option_t *option);
    virtual void       PaintAxis(Bool_t drawGridOnly=kFALSE);
    virtual void       PaintBar(Option_t *option);
    virtual void       PaintBarH(Option_t *option);
    virtual void       PaintBoxes(Option_t *option);
    virtual void       PaintColorLevels(Option_t *option);
    virtual void       PaintContour(Option_t *option);
    virtual Int_t      PaintContourLine(Double_t elev1, Int_t icont1, Double_t x1, Double_t y1,
                           Double_t elev2, Int_t icont2, Double_t x2, Double_t y2,
                           Double_t *xarr, Double_t *yarr, Int_t *itarr, Double_t *levels);
    virtual void       PaintErrors(Option_t *option);
    virtual void       Paint2DErrors(Option_t *option);
    virtual void       PaintFrame();
    virtual void       PaintFunction(Option_t *option);
    virtual void       PaintHist(Option_t *option);
    virtual void       PaintH3(Option_t *option="");
    virtual void       PaintH3Iso();
    virtual Int_t      PaintInit();
    virtual Int_t      PaintInitH();
    virtual void       PaintLego(Option_t *option);
    virtual void       PaintLegoAxis(TGaxis *axis, Double_t ang);
    virtual void       PaintPalette();
    virtual void       PaintScatterPlot(Option_t *option);
    virtual void       PaintStat(Int_t dostat, TF1 *fit);
    virtual void       PaintStat2(Int_t dostat, TF1 *fit);
    virtual void       PaintSurface(Option_t *option);
    virtual void       PaintTriangles(Option_t *option);
    virtual void       PaintTable(Option_t *option);
    virtual void       PaintText(Option_t *option);
    virtual void       PaintTitle();
    virtual void       PaintTF3();
    virtual void       ProcessMessage(const char *mess, const TObject *obj);
    static  Int_t      ProjectAitoff2xy(Double_t l, Double_t b, Double_t &Al, Double_t &Ab);
    static  Int_t      ProjectMercator2xy(Double_t l, Double_t b, Double_t &Al, Double_t &Ab);
    static  Int_t      ProjectSinusoidal2xy(Double_t l, Double_t b, Double_t &Al, Double_t &Ab);
    static  Int_t      ProjectParabolic2xy(Double_t l, Double_t b, Double_t &Al, Double_t &Ab);
    virtual void       RecalculateRange();
    virtual void       RecursiveRemove(TObject *) {;}
    virtual void       SetHistogram(TH1 *h);
    virtual void       SetStack(TList *stack) {fStack = stack;}
    virtual Int_t      TableInit();

    static const char * GetBestFormat(Double_t v, Double_t e, const char *f);

    ClassDef(THistPainter,0)  //Helper class to draw histograms
};

#endif


syntax highlighted by Code2HTML, v. 0.9.1