A poly-extrusion. 
XTRU is a poly-extrusion with fixed outline shape in x-y, a sequence of z extents (segments) and two end faces perpendicular to the z axis. The x-y outline is defined by an ordered list of points; the overall scale of the outline scales linearly between z points and the center can have an x-y offset specified at each segment end.
A TXTRU has the following parameters:
- name: name of the shape
- title: shape's title
- material: (see TMaterial)
- nxy: number of x-y vertex points constituting the outline – this number should be at least 3
- nz: number of planes perpendicular to the z axis where the scaling dimension of the section is given – this number should be at least 2
- Xvtx: array [nxy] of X coordinates of vertices
- Yvtx: array [nxy] of Y coordinates of vertices
- z: array [nz] of z plane positions
- scale: array [nz] of scale factors
- x0: array [nz] of x offsets
- y0: array [nz] of y offsets
All XTRU shapes are correctly rendered in wire mode but can encounter difficulty when rendered as a solid with hidden surfaces. These exceptions occur if the outline shape is not a convex polygon. Both the X3D and OpenGL renderers expect polygons to be convex. The OpenGL spec specifies that points defining a polygon using the GL_POLYGON primitive may be rendered as the convex hull of that set.
Solid rendering under X3D can also give unexpected artifacts if the combination of x-y-z offsets and scales for the segments are chosen in such a manner that they represent a concave shape when sliced along a plane parallel to the z axis.
Choosing sets of point that represent a malformed polygon is not supported, but testing for such a condition is not implemented and thus it is left to the user to avoid this mistake.
 
Definition at line 22 of file TXTRU.h.
|  | 
|  | TXTRU () | 
|  | TXTRU shape - default constructor. 
 | 
|  | 
|  | TXTRU (const char *name, const char *title, const char *material, Int_t nyx, Int_t nz) | 
|  | TXTRU shape - normal constructor. 
 | 
|  | 
|  | TXTRU (const TXTRU &xtru) | 
|  | TXTRU copy constructor. 
 | 
|  | 
|  | ~TXTRU () override | 
|  | TXTRU destructor deallocates arrays. 
 | 
|  | 
| void | Copy (TObject &xtru) const override | 
|  | TXTRU Copy method. 
 | 
|  | 
| virtual void | DefineSection (Int_t secNum, Float_t z, Float_t scale=1., Float_t x0=0., Float_t y0=0.) | 
|  | Set z section iz information expand size of array if necessary. 
 | 
|  | 
| virtual void | DefineVertex (Int_t pointNum, Float_t x, Float_t y) | 
|  | Set vertex point ipt to (x,y) expand size of array if necessary. 
 | 
|  | 
| Int_t | DistancetoPrimitive (Int_t px, Int_t py) override | 
|  | Compute the distance from point px,py to a TXTRU by calculating the closest approach to each corner. 
 | 
|  | 
| const TBuffer3D & | GetBuffer3D (Int_t) const override | 
|  | Get buffer 3d. 
 | 
|  | 
| virtual Int_t | GetNxy () const | 
|  | 
| virtual Int_t | GetNz () const | 
|  | 
| virtual Float_t | GetOutlinePointX (Int_t pointNum) const | 
|  | Return x coordinate of a vertex point. 
 | 
|  | 
| virtual Float_t | GetOutlinePointY (Int_t pointNum) const | 
|  | Return y coordinate of a vertex point. 
 | 
|  | 
| virtual Float_t * | GetScale () const | 
|  | 
| virtual Float_t | GetSectionScale (Int_t secNum) const | 
|  | Return scale factor for a z section. 
 | 
|  | 
| virtual Float_t | GetSectionX0 (Int_t secNum) const | 
|  | Return x0 shift of a z section. 
 | 
|  | 
| virtual Float_t | GetSectionY0 (Int_t secNum) const | 
|  | Return y0 shift of a z section. 
 | 
|  | 
| virtual Float_t | GetSectionZ (Int_t secNum) const | 
|  | Return z of a z section. 
 | 
|  | 
| virtual Float_t * | GetX0 () const | 
|  | 
| virtual Float_t * | GetXvtx () const | 
|  | 
| virtual Float_t * | GetY0 () const | 
|  | 
| virtual Float_t * | GetYvtx () const | 
|  | 
| virtual Float_t * | GetZ () const | 
|  | 
| TClass * | IsA () const override | 
|  | 
| TXTRU & | operator= (const TXTRU &rhs) | 
|  | Deep assignment operator. 
 | 
|  | 
| void | Print (Option_t *option="") const override | 
|  | Dump the info of this TXTRU shape Option: 
 | 
|  | 
| void | Sizeof3D () const override | 
|  | Return total X3D needed by TNode::ls (when called with option "x") 
 | 
|  | 
| void | SplitConcavePolygon (Bool_t split=kTRUE) | 
|  | (Dis)Enable the splitting of concave polygon outlines into multiple convex polygons. 
 | 
|  | 
| void | Streamer (TBuffer &) override | 
|  | Stream an object of class TShape. 
 | 
|  | 
| void | StreamerNVirtual (TBuffer &ClassDef_StreamerNVirtual_b) | 
|  | 
| virtual void | TruncateNxy (Int_t npts) | 
|  | Truncate the vertex list. 
 | 
|  | 
| virtual void | TruncateNz (Int_t npts) | 
|  | Truncate the z section list. 
 | 
|  | 
|  | TShape () | 
|  | Shape default constructor. 
 | 
|  | 
|  | TShape (const char *name, const char *title, const char *material) | 
|  | Shape normal constructor. 
 | 
|  | 
|  | TShape (const TShape &) | 
|  | copy constructor 
 | 
|  | 
|  | ~TShape () override | 
|  | Shape default destructor. 
 | 
|  | 
| TMaterial * | GetMaterial () const | 
|  | 
| virtual Int_t | GetNumber () const | 
|  | 
| Int_t | GetVisibility () const | 
|  | 
| TShape & | operator= (const TShape &) | 
|  | assignment operator 
 | 
|  | 
| void | Paint (Option_t *option="") override | 
|  | This method is used only when a shape is painted outside a TNode. 
 | 
|  | 
| void | SetName (const char *name) override | 
|  | Set the name of the TNamed. 
 | 
|  | 
| virtual void | SetVisibility (Int_t vis) | 
|  | 
| void | StreamerNVirtual (TBuffer &ClassDef_StreamerNVirtual_b) | 
|  | 
| void | TransformPoints (Double_t *points, UInt_t NbPnts) const | 
|  | Transform points (LocalToMaster) 
 | 
|  | 
|  | TNamed () | 
|  | 
|  | TNamed (const char *name, const char *title) | 
|  | 
|  | TNamed (const TNamed &named) | 
|  | TNamed copy ctor. 
 | 
|  | 
|  | TNamed (const TString &name, const TString &title) | 
|  | 
| virtual | ~TNamed () | 
|  | TNamed destructor. 
 | 
|  | 
| void | Clear (Option_t *option="") override | 
|  | Set name and title to empty strings (""). 
 | 
|  | 
| TObject * | Clone (const char *newname="") const override | 
|  | Make a clone of an object using the Streamer facility. 
 | 
|  | 
| Int_t | Compare (const TObject *obj) const override | 
|  | Compare two TNamed objects. 
 | 
|  | 
| virtual void | FillBuffer (char *&buffer) | 
|  | Encode TNamed into output buffer. 
 | 
|  | 
| const char * | GetName () const override | 
|  | Returns name of object. 
 | 
|  | 
| const char * | GetTitle () const override | 
|  | Returns title of object. 
 | 
|  | 
| ULong_t | Hash () const override | 
|  | Return hash value for this object. 
 | 
|  | 
| Bool_t | IsSortable () const override | 
|  | 
| void | ls (Option_t *option="") const override | 
|  | List TNamed name and title. 
 | 
|  | 
| TNamed & | operator= (const TNamed &rhs) | 
|  | TNamed assignment operator. 
 | 
|  | 
| virtual void | SetNameTitle (const char *name, const char *title) | 
|  | Set all the TNamed parameters (name and title). 
 | 
|  | 
| virtual void | SetTitle (const char *title="") | 
|  | Set the title of the TNamed. 
 | 
|  | 
| virtual Int_t | Sizeof () const | 
|  | Return size of the TNamed part of the TObject. 
 | 
|  | 
| void | StreamerNVirtual (TBuffer &ClassDef_StreamerNVirtual_b) | 
|  | 
|  | TObject () | 
|  | TObject constructor. 
 | 
|  | 
|  | TObject (const TObject &object) | 
|  | TObject copy ctor. 
 | 
|  | 
| virtual | ~TObject () | 
|  | TObject destructor. 
 | 
|  | 
| void | AbstractMethod (const char *method) const | 
|  | Use this method to implement an "abstract" method that you don't want to leave purely abstract. 
 | 
|  | 
| virtual void | AppendPad (Option_t *option="") | 
|  | Append graphics object to current pad. 
 | 
|  | 
| virtual void | Browse (TBrowser *b) | 
|  | Browse object. May be overridden for another default action. 
 | 
|  | 
| ULong_t | CheckedHash () | 
|  | Check and record whether this class has a consistent Hash/RecursiveRemove setup (*) and then return the regular Hash value for this object. 
 | 
|  | 
| virtual const char * | ClassName () const | 
|  | Returns name of class to which the object belongs. 
 | 
|  | 
| virtual void | Delete (Option_t *option="") | 
|  | Delete this object. 
 | 
|  | 
| virtual void | Draw (Option_t *option="") | 
|  | Default Draw method for all objects. 
 | 
|  | 
| virtual void | DrawClass () const | 
|  | Draw class inheritance tree of the class to which this object belongs. 
 | 
|  | 
| virtual TObject * | DrawClone (Option_t *option="") const | 
|  | Draw a clone of this object in the current selected pad with: gROOT->SetSelectedPad(c1).
 | 
|  | 
| virtual void | Dump () const | 
|  | Dump contents of object on stdout. 
 | 
|  | 
| virtual void | Error (const char *method, const char *msgfmt,...) const | 
|  | Issue error message. 
 | 
|  | 
| virtual void | Execute (const char *method, const char *params, Int_t *error=nullptr) | 
|  | Execute method on this object with the given parameter string, e.g. 
 | 
|  | 
| virtual void | Execute (TMethod *method, TObjArray *params, Int_t *error=nullptr) | 
|  | Execute method on this object with parameters stored in the TObjArray. 
 | 
|  | 
| virtual void | ExecuteEvent (Int_t event, Int_t px, Int_t py) | 
|  | Execute action corresponding to an event at (px,py). 
 | 
|  | 
| virtual void | Fatal (const char *method, const char *msgfmt,...) const | 
|  | Issue fatal error message. 
 | 
|  | 
| virtual TObject * | FindObject (const char *name) const | 
|  | Must be redefined in derived classes. 
 | 
|  | 
| virtual TObject * | FindObject (const TObject *obj) const | 
|  | Must be redefined in derived classes. 
 | 
|  | 
| virtual Option_t * | GetDrawOption () const | 
|  | Get option used by the graphics system to draw this object. 
 | 
|  | 
| virtual const char * | GetIconName () const | 
|  | Returns mime type name of object. 
 | 
|  | 
| virtual char * | GetObjectInfo (Int_t px, Int_t py) const | 
|  | Returns string containing info about the object at position (px,py). 
 | 
|  | 
| virtual Option_t * | GetOption () const | 
|  | 
| virtual UInt_t | GetUniqueID () const | 
|  | Return the unique object id. 
 | 
|  | 
| virtual Bool_t | HandleTimer (TTimer *timer) | 
|  | Execute action in response of a timer timing out. 
 | 
|  | 
| Bool_t | HasInconsistentHash () const | 
|  | Return true is the type of this object is known to have an inconsistent setup for Hash and RecursiveRemove (i.e. 
 | 
|  | 
| virtual void | Info (const char *method, const char *msgfmt,...) const | 
|  | Issue info message. 
 | 
|  | 
| virtual Bool_t | InheritsFrom (const char *classname) const | 
|  | Returns kTRUE if object inherits from class "classname". 
 | 
|  | 
| virtual Bool_t | InheritsFrom (const TClass *cl) const | 
|  | Returns kTRUE if object inherits from TClass cl. 
 | 
|  | 
| virtual void | Inspect () const | 
|  | Dump contents of this object in a graphics canvas. 
 | 
|  | 
| void | InvertBit (UInt_t f) | 
|  | 
| Bool_t | IsDestructed () const | 
|  | IsDestructed. 
 | 
|  | 
| virtual Bool_t | IsEqual (const TObject *obj) const | 
|  | Default equal comparison (objects are equal if they have the same address in memory). 
 | 
|  | 
| virtual Bool_t | IsFolder () const | 
|  | Returns kTRUE in case object contains browsable objects (like containers or lists of other objects). 
 | 
|  | 
| R__ALWAYS_INLINE Bool_t | IsOnHeap () const | 
|  | 
| R__ALWAYS_INLINE Bool_t | IsZombie () const | 
|  | 
| void | MayNotUse (const char *method) const | 
|  | Use this method to signal that a method (defined in a base class) may not be called in a derived class (in principle against good design since a child class should not provide less functionality than its parent, however, sometimes it is necessary). 
 | 
|  | 
| virtual Bool_t | Notify () | 
|  | This method must be overridden to handle object notification (the base implementation is no-op). 
 | 
|  | 
| void | Obsolete (const char *method, const char *asOfVers, const char *removedFromVers) const | 
|  | Use this method to declare a method obsolete. 
 | 
|  | 
| void | operator delete (void *ptr) | 
|  | Operator delete. 
 | 
|  | 
| void | operator delete (void *ptr, void *vp) | 
|  | Only called by placement new when throwing an exception. 
 | 
|  | 
| void | operator delete[] (void *ptr) | 
|  | Operator delete []. 
 | 
|  | 
| void | operator delete[] (void *ptr, void *vp) | 
|  | Only called by placement new[] when throwing an exception. 
 | 
|  | 
| void * | operator new (size_t sz) | 
|  | 
| void * | operator new (size_t sz, void *vp) | 
|  | 
| void * | operator new[] (size_t sz) | 
|  | 
| void * | operator new[] (size_t sz, void *vp) | 
|  | 
| TObject & | operator= (const TObject &rhs) | 
|  | TObject assignment operator. 
 | 
|  | 
| virtual void | Pop () | 
|  | Pop on object drawn in a pad to the top of the display list. 
 | 
|  | 
| virtual Int_t | Read (const char *name) | 
|  | Read contents of object with specified name from the current directory. 
 | 
|  | 
| virtual void | RecursiveRemove (TObject *obj) | 
|  | Recursively remove this object from a list. 
 | 
|  | 
| void | ResetBit (UInt_t f) | 
|  | 
| virtual void | SaveAs (const char *filename="", Option_t *option="") const | 
|  | Save this object in the file specified by filename. 
 | 
|  | 
| virtual void | SavePrimitive (std::ostream &out, Option_t *option="") | 
|  | Save a primitive as a C++ statement(s) on output stream "out". 
 | 
|  | 
| void | SetBit (UInt_t f) | 
|  | 
| void | SetBit (UInt_t f, Bool_t set) | 
|  | Set or unset the user status bits as specified in f. 
 | 
|  | 
| virtual void | SetDrawOption (Option_t *option="") | 
|  | Set drawing option for object. 
 | 
|  | 
| virtual void | SetUniqueID (UInt_t uid) | 
|  | Set the unique object id. 
 | 
|  | 
| void | StreamerNVirtual (TBuffer &ClassDef_StreamerNVirtual_b) | 
|  | 
| virtual void | SysError (const char *method, const char *msgfmt,...) const | 
|  | Issue system error message. 
 | 
|  | 
| R__ALWAYS_INLINE Bool_t | TestBit (UInt_t f) const | 
|  | 
| Int_t | TestBits (UInt_t f) const | 
|  | 
| virtual void | UseCurrentStyle () | 
|  | Set current style settings in this object This function is called when either TCanvas::UseCurrentStyle or TROOT::ForceStyle have been invoked. 
 | 
|  | 
| virtual void | Warning (const char *method, const char *msgfmt,...) const | 
|  | Issue warning message. 
 | 
|  | 
| virtual Int_t | Write (const char *name=nullptr, Int_t option=0, Int_t bufsize=0) | 
|  | Write this object to the current directory. 
 | 
|  | 
| virtual Int_t | Write (const char *name=nullptr, Int_t option=0, Int_t bufsize=0) const | 
|  | Write this object to the current directory. 
 | 
|  | 
|  | TAttLine () | 
|  | AttLine default constructor. 
 | 
|  | 
|  | TAttLine (Color_t lcolor, Style_t lstyle, Width_t lwidth) | 
|  | AttLine normal constructor. 
 | 
|  | 
| virtual | ~TAttLine () | 
|  | AttLine destructor. 
 | 
|  | 
| void | Copy (TAttLine &attline) const | 
|  | Copy this line attributes to a new TAttLine. 
 | 
|  | 
| Int_t | DistancetoLine (Int_t px, Int_t py, Double_t xp1, Double_t yp1, Double_t xp2, Double_t yp2) | 
|  | Compute distance from point px,py to a line. 
 | 
|  | 
| virtual Color_t | GetLineColor () const | 
|  | Return the line color. 
 | 
|  | 
| virtual Style_t | GetLineStyle () const | 
|  | Return the line style. 
 | 
|  | 
| virtual Width_t | GetLineWidth () const | 
|  | Return the line width. 
 | 
|  | 
| virtual void | Modify () | 
|  | Change current line attributes if necessary. 
 | 
|  | 
| virtual void | ResetAttLine (Option_t *option="") | 
|  | Reset this line attributes to default values. 
 | 
|  | 
| virtual void | SaveLineAttributes (std::ostream &out, const char *name, Int_t coldef=1, Int_t stydef=1, Int_t widdef=1) | 
|  | Save line attributes as C++ statement(s) on output stream out. 
 | 
|  | 
| virtual void | SetLineAttributes () | 
|  | Invoke the DialogCanvas Line attributes. 
 | 
|  | 
| virtual void | SetLineColor (Color_t lcolor) | 
|  | Set the line color. 
 | 
|  | 
| virtual void | SetLineColorAlpha (Color_t lcolor, Float_t lalpha) | 
|  | Set a transparent line color. 
 | 
|  | 
| virtual void | SetLineStyle (Style_t lstyle) | 
|  | Set the line style. 
 | 
|  | 
| virtual void | SetLineWidth (Width_t lwidth) | 
|  | Set the line width. 
 | 
|  | 
| void | StreamerNVirtual (TBuffer &ClassDef_StreamerNVirtual_b) | 
|  | 
|  | TAttFill () | 
|  | AttFill default constructor. 
 | 
|  | 
|  | TAttFill (Color_t fcolor, Style_t fstyle) | 
|  | AttFill normal constructor. 
 | 
|  | 
| virtual | ~TAttFill () | 
|  | AttFill destructor. 
 | 
|  | 
| void | Copy (TAttFill &attfill) const | 
|  | Copy this fill attributes to a new TAttFill. 
 | 
|  | 
| virtual Color_t | GetFillColor () const | 
|  | Return the fill area color. 
 | 
|  | 
| virtual Style_t | GetFillStyle () const | 
|  | Return the fill area style. 
 | 
|  | 
| virtual Bool_t | IsTransparent () const | 
|  | 
| virtual void | Modify () | 
|  | Change current fill area attributes if necessary. 
 | 
|  | 
| virtual void | ResetAttFill (Option_t *option="") | 
|  | Reset this fill attributes to default values. 
 | 
|  | 
| virtual void | SaveFillAttributes (std::ostream &out, const char *name, Int_t coldef=1, Int_t stydef=1001) | 
|  | Save fill attributes as C++ statement(s) on output stream out. 
 | 
|  | 
| virtual void | SetFillAttributes () | 
|  | Invoke the DialogCanvas Fill attributes. 
 | 
|  | 
| virtual void | SetFillColor (Color_t fcolor) | 
|  | Set the fill area color. 
 | 
|  | 
| virtual void | SetFillColorAlpha (Color_t fcolor, Float_t falpha) | 
|  | Set a transparent fill color. 
 | 
|  | 
| virtual void | SetFillStyle (Style_t fstyle) | 
|  | Set the fill area style. 
 | 
|  | 
| void | StreamerNVirtual (TBuffer &ClassDef_StreamerNVirtual_b) | 
|  | 
|  | TAtt3D () | 
|  | 
| virtual | ~TAtt3D () | 
|  | 
| void | StreamerNVirtual (TBuffer &ClassDef_StreamerNVirtual_b) | 
|  |