File indexing completed on 2025-10-24 09:20:13
0001
0002
0003
0004
0005
0006
0007
0008
0009
0010
0011 #ifndef ROOT_TGLBoxPainter
0012 #define ROOT_TGLBoxPainter
0013
0014 #include <vector>
0015
0016 #include "TGLPlotPainter.h"
0017 #include "TGLQuadric.h"
0018 #include "TString.h"
0019 #include "TGLUtil.h"
0020
0021
0022
0023
0024
0025
0026 class TPolyMarker3D;
0027
0028 class TGLPlotCamera;
0029 class TAxis;
0030 class TH1;
0031
0032 class TGLBoxPainter : public TGLPlotPainter {
0033 private:
0034 TGLTH3Slice fXOZSlice;
0035 TGLTH3Slice fYOZSlice;
0036 TGLTH3Slice fXOYSlice;
0037
0038 enum EBoxType {
0039 kBox,
0040 kBox1
0041 };
0042
0043 mutable EBoxType fType;
0044
0045 TString fPlotInfo;
0046 Rgl::Range_t fMinMaxVal;
0047
0048 mutable TGLQuadric fQuadric;
0049
0050 const TPolyMarker3D *fPolymarker;
0051 std::vector<Double_t> fPMPoints;
0052
0053 TGLBoxPainter(const TGLBoxPainter &);
0054 TGLBoxPainter &operator = (const TGLBoxPainter &);
0055
0056 public:
0057 TGLBoxPainter(TH1 *hist, TGLPlotCamera *camera, TGLPlotCoordinates *coord);
0058
0059 TGLBoxPainter(TH1 *hist, TPolyMarker3D * pm,
0060 TGLPlotCamera *camera, TGLPlotCoordinates *coord);
0061
0062 char *GetPlotInfo(Int_t px, Int_t py) override;
0063 Bool_t InitGeometry() override;
0064 void StartPan(Int_t px, Int_t py) override;
0065 void Pan(Int_t px, Int_t py) override;
0066 void AddOption(const TString &stringOption) override;
0067 void ProcessEvent(Int_t event, Int_t px, Int_t py) override;
0068
0069 private:
0070
0071 void InitGL()const override;
0072 void DeInitGL()const override;
0073
0074 void DrawPlot()const override;
0075
0076 void DrawCloud()const;
0077
0078 void SetPlotColor()const;
0079
0080 void DrawSectionXOZ()const override;
0081 void DrawSectionYOZ()const override;
0082 void DrawSectionXOY()const override;
0083
0084 void DrawPalette()const;
0085 void DrawPaletteAxis()const override;
0086
0087 Bool_t HasSections()const;
0088
0089 ClassDefOverride(TGLBoxPainter, 0)
0090 };
0091
0092 #endif