// @(#)root/table:$Id$
// Author: Valery Fine(fine@bnl.gov)   25/12/98

/*************************************************************************
 * 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_TVolumeView
#define ROOT_TVolumeView

#include <assert.h>

#include "TVolume.h"

//////////////////////////////////////////////////////////////////////////
//                                                                      //
// TVolumeView                                                          //
//                                                                      //
//////////////////////////////////////////////////////////////////////////

// typedef TVolumeView TNodeView;

class TVolumeView : public TObjectSet, public TAtt3D  {
protected:
   TList          *fListOfShapes;     //Pointer to the list of the "extra" shape definitions

   virtual void    PaintShape(Option_t *option);
   TVolumeView(TVolumeView &viewNode);


public:
   TVolumeView():TObjectSet(),fListOfShapes(0) {;}
   TVolumeView(TVolumeView *viewNode,TVolumePosition *nodePosition=0);
   TVolumeView(TVolumeView *viewNode,const Char_t *NodeName1,const Char_t *NodeName2=0);
   TVolumeView(TVolumeView *viewNode,TVolumeView *topNode);
   TVolumeView(TVolumeView *viewNode,const TVolumeView *node1,const TVolumeView *node2);
   TVolumeView(TVolume &pattern,Int_t maxDepLevel=0,const TVolumePosition *nodePosition=0,EDataSetPass iopt=kMarked,TVolumeView *root=0);
   TVolumeView(Double_t *translate, Double_t *rotate, UInt_t positionId, TVolume *thisNode,
               const Char_t *thisNodePath, const Char_t *matrixName=0, Int_t matrixType=0);
   TVolumeView(TVolume *thisNode,TVolumePosition *nodePosition);
   virtual ~TVolumeView();
   virtual TVolume *AddNode(TVolume *node);
   virtual void     Add(TDataSet *dataset);
   virtual void     Add(TVolumeView *node);
   virtual void     Add(TShape *shape, Bool_t IsMaster=kFALSE);
   virtual void     Browse(TBrowser *b);
   virtual void     Draw(Option_t *depth="3"); // *MENU*
   virtual Int_t    DistancetoPrimitive(Int_t px, Int_t py);
   virtual TVolumePosition *GetPosition() const { return (TVolumePosition *)GetObject();}
   virtual TVolume *GetNode() const ;
   virtual Int_t    GetGlobalRange(const TVolumeView *rootNode,Float_t *min, Float_t *max);
   virtual TList   *GetListOfShapes() const;
   virtual void     GetLocalRange(Float_t *min, Float_t *max);
   virtual char  *GetObjectInfo(Int_t px, Int_t py) const;
   virtual TShape  *GetShape()  const;
   virtual Int_t    GetVisibility() const;
   virtual Bool_t   IsMarked() const;
   virtual Bool_t   Is3D() const {return kTRUE;}
   virtual TVolumePosition  *Local2Master(const TVolumeView *localNode,const TVolumeView *masterNode=0);
   virtual TVolumePosition  *Local2Master(const Char_t *localName, const Char_t *masterName=0);
   virtual Float_t *Local2Master(const Float_t *local, Float_t *master,
                                 const Char_t *localName, const Char_t *masterName=0, Int_t nVector=1);
   virtual Float_t   *Local2Master(const Float_t *local, Float_t *master,
                                   const TVolumeView *localNode,
                                   const TVolumeView *masterNode=0, Int_t nVector=1);
   virtual TList   *Nodes(){ return GetList();}
   virtual void     Paint(Option_t *option="");
   virtual TString  PathP() const;
   virtual void     SetLineAttributes(); // *MENU*
   virtual void     SavePrimitive(std::ostream &out, Option_t *option="");
   virtual void     SetVisibility(Int_t vis=1); // *MENU*
   virtual void     Sizeof3D() const;
   ClassDef(TVolumeView,1)  // Special kind of TDataSet
};

inline void    TVolumeView::Add(TDataSet * /*dataset*/){ assert(0);}
inline void    TVolumeView::Add(TVolumeView *node){ TDataSet::Add(node);}
inline Bool_t  TVolumeView::IsMarked() const { return TestBit(kMark); }
inline TList  *TVolumeView::GetListOfShapes() const {return fListOfShapes;}
inline TShape *TVolumeView::GetShape()  const
       {return fListOfShapes ? (TShape *)fListOfShapes->First():0;}
inline Int_t   TVolumeView::GetVisibility() const {return GetNode() ? GetNode()->GetVisibility():0;}

#endif

 TVolumeView.h:1
 TVolumeView.h:2
 TVolumeView.h:3
 TVolumeView.h:4
 TVolumeView.h:5
 TVolumeView.h:6
 TVolumeView.h:7
 TVolumeView.h:8
 TVolumeView.h:9
 TVolumeView.h:10
 TVolumeView.h:11
 TVolumeView.h:12
 TVolumeView.h:13
 TVolumeView.h:14
 TVolumeView.h:15
 TVolumeView.h:16
 TVolumeView.h:17
 TVolumeView.h:18
 TVolumeView.h:19
 TVolumeView.h:20
 TVolumeView.h:21
 TVolumeView.h:22
 TVolumeView.h:23
 TVolumeView.h:24
 TVolumeView.h:25
 TVolumeView.h:26
 TVolumeView.h:27
 TVolumeView.h:28
 TVolumeView.h:29
 TVolumeView.h:30
 TVolumeView.h:31
 TVolumeView.h:32
 TVolumeView.h:33
 TVolumeView.h:34
 TVolumeView.h:35
 TVolumeView.h:36
 TVolumeView.h:37
 TVolumeView.h:38
 TVolumeView.h:39
 TVolumeView.h:40
 TVolumeView.h:41
 TVolumeView.h:42
 TVolumeView.h:43
 TVolumeView.h:44
 TVolumeView.h:45
 TVolumeView.h:46
 TVolumeView.h:47
 TVolumeView.h:48
 TVolumeView.h:49
 TVolumeView.h:50
 TVolumeView.h:51
 TVolumeView.h:52
 TVolumeView.h:53
 TVolumeView.h:54
 TVolumeView.h:55
 TVolumeView.h:56
 TVolumeView.h:57
 TVolumeView.h:58
 TVolumeView.h:59
 TVolumeView.h:60
 TVolumeView.h:61
 TVolumeView.h:62
 TVolumeView.h:63
 TVolumeView.h:64
 TVolumeView.h:65
 TVolumeView.h:66
 TVolumeView.h:67
 TVolumeView.h:68
 TVolumeView.h:69
 TVolumeView.h:70
 TVolumeView.h:71
 TVolumeView.h:72
 TVolumeView.h:73
 TVolumeView.h:74
 TVolumeView.h:75
 TVolumeView.h:76
 TVolumeView.h:77
 TVolumeView.h:78
 TVolumeView.h:79
 TVolumeView.h:80
 TVolumeView.h:81
 TVolumeView.h:82
 TVolumeView.h:83
 TVolumeView.h:84
 TVolumeView.h:85
 TVolumeView.h:86
 TVolumeView.h:87
 TVolumeView.h:88