Logo ROOT   6.08/07
Reference Guide
TTUBS.h
Go to the documentation of this file.
1 // @(#)root/g3d:$Id$
2 // Author: Nenad Buncic 18/09/95
3 
4 /*************************************************************************
5  * Copyright (C) 1995-2000, Rene Brun and Fons Rademakers. *
6  * All rights reserved. *
7  * *
8  * For the licensing terms see $ROOTSYS/LICENSE. *
9  * For the list of contributors see $ROOTSYS/README/CREDITS. *
10  *************************************************************************/
11 
12 #ifndef ROOT_TTUBS
13 #define ROOT_TTUBS
14 
15 
16 ////////////////////////////////////////////////////////////////////////////
17 // //
18 // TTUBS //
19 // //
20 // TUBS is a phi segment of a tube. It has 5 parameters, the same 3 as //
21 // TUBE plus the phi limits. The segment start at first limit and //
22 // includes increasing phi value up to the second limit or that plus //
23 // 360 degrees. //
24 // //
25 ////////////////////////////////////////////////////////////////////////////
26 
27 #ifndef ROOT_TTUBE
28 #include "TTUBE.h"
29 #endif
30 
31 class TTUBS : public TTUBE {
32 protected:
33  Float_t fPhi1; // first phi limit
34  Float_t fPhi2; // second phi limit
35  virtual void MakeTableOfCoSin() const; // Create the table of the fSiTab; fCoTab
36 
37  virtual void SetPoints(Double_t *points) const;
38 
39 public:
40  TTUBS();
41  TTUBS(const char *name, const char *title, const char *material, Float_t rmin, Float_t rmax, Float_t dz,
42  Float_t phi1, Float_t phi2);
43  TTUBS(const char *name, const char *title, const char *material, Float_t rmax, Float_t dz,
44  Float_t phi1, Float_t phi2);
45  virtual ~TTUBS();
46 
47  virtual Int_t DistancetoPrimitive(Int_t px, Int_t py);
48  virtual const TBuffer3D &GetBuffer3D(Int_t reqSections) const;
49  virtual Float_t GetPhi1() const {return fPhi1;}
50  virtual Float_t GetPhi2() const {return fPhi2;}
51  virtual void Sizeof3D() const;
52 
53  ClassDef(TTUBS,1) //TUBS shape
54 };
55 
56 #endif
virtual Float_t GetPhi1() const
Definition: TTUBS.h:49
virtual const TBuffer3D & GetBuffer3D(Int_t reqSections) const
Get buffer 3d.
Definition: TTUBS.cxx:182
float Float_t
Definition: RtypesCore.h:53
int Int_t
Definition: RtypesCore.h:41
virtual ~TTUBS()
TUBS shape default destructor.
Definition: TTUBS.cxx:116
#define ClassDef(name, id)
Definition: Rtypes.h:254
Float_t fPhi2
Definition: TTUBS.h:34
point * points
Definition: X3DBuffer.c:20
Float_t fPhi1
Definition: TTUBS.h:33
Generic 3D primitive description class.
Definition: TBuffer3D.h:19
double Double_t
Definition: RtypesCore.h:55
TTUBS()
TUBS shape default constructor.
Definition: TTUBS.cxx:47
virtual Float_t GetPhi2() const
Definition: TTUBS.h:50
virtual void Sizeof3D() const
Return total X3D needed by TNode::ls (when called with option "x")
Definition: TTUBS.cxx:170
virtual void SetPoints(Double_t *points) const
Create TUBS points.
Definition: TTUBS.cxx:136
virtual Int_t DistancetoPrimitive(Int_t px, Int_t py)
Compute distance from point px,py to a TUBE.
Definition: TTUBS.cxx:126
A tube.
Definition: TTUBE.h:34
virtual void MakeTableOfCoSin() const
Make table of sine and cosine.
Definition: TTUBS.cxx:80
char name[80]
Definition: TGX11.cxx:109
A segment of a tube.
Definition: TTUBS.h:31