#ifndef ROOT_TGeoPhysicalNode
#define ROOT_TGeoPhysicalNode
#ifndef ROOT_TNamed
#include "TNamed.h"
#endif
#ifndef ROOT_TObjArray
#include "TObjArray.h"
#endif
#ifndef ROOT_TAttLine
#include "TAttLine.h"
#endif
#ifndef ROOT_TObject
#include "TGeoNode.h"
#endif
class TGeoHMatrix;
class TGeoMatrix;
class TGeoVolume;
class TGeoNode;
class TGeoShape;
class TGeoPhysicalNode : public TObject,
public TAttLine
{
protected:
Int_t fLevel;
TObjArray *fMatrices;
TObjArray *fNodes;
TGeoHMatrix *fMatrixOrig;
TGeoPhysicalNode(const TGeoPhysicalNode&);
TGeoPhysicalNode& operator=(const TGeoPhysicalNode&);
void SetAligned(Bool_t flag=kTRUE) {TObject::SetBit(kGeoPNodeAligned,flag);}
public:
enum {
kGeoPNodeFull = BIT(10),
kGeoPNodeVisible = BIT(11),
kGeoPNodeVolAtt = BIT(12),
kGeoPNodeAligned = BIT(13)
};
TGeoPhysicalNode();
TGeoPhysicalNode(const char *path);
virtual ~TGeoPhysicalNode();
void Align(TGeoMatrix *newmat=0, TGeoShape *newshape=0, Bool_t check=kFALSE);
void cd() const;
void Draw(Option_t *option="");
Int_t GetLevel() const {return fLevel;}
TGeoHMatrix *GetMatrix(Int_t level=-1) const;
TGeoHMatrix *GetOriginalMatrix() const {return fMatrixOrig;}
TGeoNode *GetMother(Int_t levup=1) const;
const char *GetName() const;
TGeoNode *GetNode(Int_t level=-1) const;
TGeoShape *GetShape(Int_t level=-1) const;
TGeoVolume *GetVolume(Int_t level=-1) const;
Bool_t IsAligned() const {return TObject::TestBit(kGeoPNodeAligned);}
Bool_t IsVolAttributes() const {return TObject::TestBit(kGeoPNodeVolAtt);}
Bool_t IsVisible() const {return TObject::TestBit(kGeoPNodeVisible);}
Bool_t IsVisibleFull() const {return TObject::TestBit(kGeoPNodeFull);}
Bool_t SetPath(const char *path);
void SetBranchAsState();
void SetIsVolAtt(Bool_t flag=kTRUE) {TObject::SetBit(kGeoPNodeVolAtt,flag);}
void SetVisibility(Bool_t flag=kTRUE) {TObject::SetBit(kGeoPNodeVisible,flag);}
void SetVisibleFull(Bool_t flag=kTRUE) {TObject::SetBit(kGeoPNodeFull,flag);}
virtual void Paint(Option_t *option = "");
ClassDef(TGeoPhysicalNode, 1)
};
class TGeoPNEntry : public TNamed
{
private:
TGeoPhysicalNode *fNode;
TGeoHMatrix *fMatrix;
protected:
TGeoPNEntry(const TGeoPNEntry& pne)
: TNamed(pne), fNode(pne.fNode), fMatrix(NULL) { }
TGeoPNEntry& operator=(const TGeoPNEntry& pne)
{if(this!=&pne) {TNamed::operator=(pne); fNode=pne.fNode; fMatrix=pne.fMatrix;}
return *this;}
public:
TGeoPNEntry();
TGeoPNEntry(const char *unique_name, const char *path);
virtual ~TGeoPNEntry() {;}
inline const char *GetPath() const {return GetTitle();}
TGeoHMatrix *GetMatrix() const {return fMatrix;}
TGeoPhysicalNode *GetPhysicalNode() const {return fNode;}
void SetMatrix(TGeoHMatrix *matrix);
void SetPhysicalNode(TGeoPhysicalNode *node);
ClassDef(TGeoPNEntry, 2)
};
#endif
ROOT page - Class index - Class Hierarchy - 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.