class HMdcTrapPlane: public TObject

_HADES_CLASS_DESCRIPTION


 HMdcPointPlane - poin on the plane
 HMdcTrap - trapeze in vol. is used for mdc cell sensitive volume
 HMdcTrapPlane - polygon on the plane is used for cell projection calculation
 HMdcPlane - param. of project planes

 HMdcPointOnPlane

     This class keep point on the plane HMdcPlane

 HMdcLineParam

     This class keep straight line parameters.
     Parameters are two point on the two planes
     (two HMdcPointOnPlane objects).


Function Members (Methods)

public:
HMdcTrapPlane()
HMdcTrapPlane(const HMdcTrapPlane& otrap)
virtual~HMdcTrapPlane()
voidTObject::AbstractMethod(const char* method) const
voidaddPoint(const HGeomVector& v)
voidaddPoint(const HMdcPointPlane& p)
virtual voidTObject::AppendPad(Option_t* option = "")
virtual voidTObject::Browse(TBrowser* b)
voidcalcDir()
static TClass*Class()
virtual const char*TObject::ClassName() const
voidclear()
virtual voidTObject::Clear(Option_t* = "")
voidclearNPoints()
virtual TObject*TObject::Clone(const char* newname = "") const
virtual Int_tTObject::Compare(const TObject* obj) const
voidcopy(HMdcTrapPlane& otrap)
virtual voidTObject::Copy(TObject& object) const
virtual voidTObject::Delete(Option_t* option = "")MENU
virtual Int_tTObject::DistancetoPrimitive(Int_t px, Int_t py)
virtual voidTObject::Draw(Option_t* option = "")
virtual voidTObject::DrawClass() constMENU
virtual TObject*TObject::DrawClone(Option_t* option = "") constMENU
virtual voidTObject::Dump() constMENU
virtual voidTObject::Error(const char* method, const char* msgfmt) const
virtual voidTObject::Execute(const char* method, const char* params, Int_t* error = 0)
virtual voidTObject::Execute(TMethod* method, TObjArray* params, Int_t* error = 0)
virtual voidTObject::ExecuteEvent(Int_t event, Int_t px, Int_t py)
virtual voidTObject::Fatal(const char* method, const char* msgfmt) const
virtual TObject*TObject::FindObject(const char* name) const
virtual TObject*TObject::FindObject(const TObject* obj) const
virtual Option_t*TObject::GetDrawOption() const
static Long_tTObject::GetDtorOnly()
virtual const char*TObject::GetIconName() const
Bool_tgetLineInd(Int_t line, Int_t& p1, Int_t& p2) const
virtual const char*TObject::GetName() const
Int_tgetNPoints() const
virtual char*TObject::GetObjectInfo(Int_t px, Int_t py) const
static Bool_tTObject::GetObjectStat()
virtual Option_t*TObject::GetOption() const
virtual const char*TObject::GetTitle() const
virtual UInt_tTObject::GetUniqueID() const
Bool_tgetXCross(Int_t line, Double_t y, Double_t& x) const
Double_tgetXMax() const
Int_tgetXMaxPoint() const
Double_tgetXMin() const
Int_tgetXMinPoint() const
Bool_tgetXminXmax(Double_t y, Double_t& x1, Double_t& x2)
Bool_tgetXminXmax(Double_t y1i, Double_t y2i, Double_t& x1, Double_t& x2)
voidgetXYMinMax(Int_t& xMin, Int_t& xMax, Int_t& yMin, Int_t& yMax) const
Double_tgetYMax() const
Int_tgetYMaxPoint() const
Double_tgetYMin() const
Int_tgetYMinPoint() const
virtual Bool_tTObject::HandleTimer(TTimer* timer)
virtual ULong_tTObject::Hash() const
virtual voidTObject::Info(const char* method, const char* msgfmt) const
virtual Bool_tTObject::InheritsFrom(const char* classname) const
virtual Bool_tTObject::InheritsFrom(const TClass* cl) const
virtual voidTObject::Inspect() constMENU
voidTObject::InvertBit(UInt_t f)
virtual TClass*IsA() const
virtual Bool_tTObject::IsEqual(const TObject* obj) const
virtual Bool_tTObject::IsFolder() const
Bool_tTObject::IsOnHeap() const
virtual Bool_tTObject::IsSortable() const
Bool_tTObject::IsZombie() const
virtual voidTObject::ls(Option_t* option = "") const
voidTObject::MayNotUse(const char* method) const
virtual Bool_tTObject::Notify()
static voidTObject::operator delete(void* ptr)
static voidTObject::operator delete(void* ptr, void* vp)
static voidTObject::operator delete[](void* ptr)
static voidTObject::operator delete[](void* ptr, void* vp)
void*TObject::operator new(size_t sz)
void*TObject::operator new(size_t sz, void* vp)
void*TObject::operator new[](size_t sz)
void*TObject::operator new[](size_t sz, void* vp)
HMdcTrapPlane&operator=(const HMdcTrapPlane&)
HMdcPointPlane&operator[](Int_t i)
virtual voidTObject::Paint(Option_t* option = "")
virtual voidTObject::Pop()
voidprint() const
virtual voidTObject::Print(Option_t* option = "") const
virtual Int_tTObject::Read(const char* name)
virtual voidTObject::RecursiveRemove(TObject* obj)
voidTObject::ResetBit(UInt_t f)
virtual voidTObject::SaveAs(const char* filename = "", Option_t* option = "") constMENU
virtual voidTObject::SavePrimitive(basic_ostream<char,char_traits<char> >& out, Option_t* option = "")
voidset(const HMdcTrapPlane& otrap)
voidTObject::SetBit(UInt_t f)
voidTObject::SetBit(UInt_t f, Bool_t set)
virtual voidTObject::SetDrawOption(Option_t* option = "")MENU
static voidTObject::SetDtorOnly(void* obj)
static voidTObject::SetObjectStat(Bool_t stat)
virtual voidTObject::SetUniqueID(UInt_t uid)
virtual voidShowMembers(TMemberInspector& insp, char* parent)
virtual voidStreamer(TBuffer& b)
voidStreamerNVirtual(TBuffer& b)
virtual voidTObject::SysError(const char* method, const char* msgfmt) const
Bool_tTObject::TestBit(UInt_t f) const
Int_tTObject::TestBits(UInt_t f) const
Int_ttwoContoursSum(const HMdcTrapPlane& c1i, const HMdcTrapPlane& c2i)
virtual voidTObject::UseCurrentStyle()
virtual voidTObject::Warning(const char* method, const char* msgfmt) const
virtual Int_tTObject::Write(const char* name = 0, Int_t option = 0, Int_t bufsize = 0)
virtual Int_tTObject::Write(const char* name = 0, Int_t option = 0, Int_t bufsize = 0) const
protected:
Double_tcalcX(Int_t ip1, Int_t ip2, Double_t y) const
virtual voidTObject::DoError(int level, const char* location, const char* fmt, va_list va) const
voidTObject::MakeZombie()
Int_tnextP(Int_t p) const
Int_tnextXMaxP(Int_t p) const
Int_tnextXMinP(Int_t p) const
Int_tprevP(Int_t p) const
Int_tprevXMaxP(Int_t p) const
Int_tprevXMinP(Int_t p) const

Data Members

public:
enum TObject::EStatusBits { kCanDelete
kMustCleanup
kObjInCanvas
kIsReferenced
kHasUUID
kCannotPick
kNoContextMenu
kInvalidObject
};
enum TObject::[unnamed] { kIsOnHeap
kNotDeleted
kZombie
kBitMask
kSingleKey
kOverwrite
kWriteDelete
};
protected:
Char_tdir
Int_tnPointsnumber points
HMdcPointPlanepoints[16]
UChar_txMaxPointpoint number with maximal x
UChar_txMinPointpoint number with minimal x
UChar_tyMaxPointpoint number with maximal y
UChar_tyMinPointpoint number with minimal y

Class Charts

Inheritance Inherited Members Includes Libraries
Class Charts

Function documentation

HMdcTrapPlane(const HMdcTrapPlane& otrap)
 constructor creates the copy of obj. Trap
void copy(HMdcTrapPlane& otrap)
 copy obj "this" to otarp
void set(const HMdcTrapPlane& otrap)
 copy obj "this" to otrap
void clear()
void clearNPoints(void)
void print() const
 print Trap;
void addPoint(const HGeomVector& v)
void addPoint(const HMdcPointPlane& p)
void calcDir(void)
void getXYMinMax(Int_t& xMin, Int_t& xMax, Int_t& yMin, Int_t& yMax) const
 Return points number of maximal and minimal value of X and Y.
Int_t twoContoursSum(const HMdcTrapPlane& c1i, const HMdcTrapPlane& c2i)
 Function combine two countours in one
Bool_t getLineInd(Int_t line, Int_t& p1, Int_t& p2) const
 Return points indices for line number "line".
Bool_t getXCross(Int_t line, Double_t y, Double_t& x) const
 Function calculate X for Y="y" on the piece of line number "line".
 Return kFALSE if it don't cross this line piece.
Double_t calcX(Int_t ip1, Int_t ip2, Double_t y) const
 Function calculate X for Y="y" on the piece of line p1-p2.
Bool_t getXminXmax(Double_t y, Double_t& x1, Double_t& x2)
 Function calculate X for Y="y" on the piece of line number "line".
 Return kFALSE if it don't cross this line piece.
Bool_t getXminXmax(Double_t y1i, Double_t y2i, Double_t& x1, Double_t& x2)
 Function calculate X minimal (x1) and X maximal (x2)
 in Y reagion from y1i to y2i.
 Return kFALSE if Y region outside of polygon.
HMdcTrapPlane()
{nPoints=4; dir=0;}
~HMdcTrapPlane()
{}
HMdcPointPlane& operator[](Int_t i)
Int_t getNPoints(void)
{return nPoints;}
Int_t getXMinPoint(void)
{return xMinPoint;}
Int_t getXMaxPoint(void)
{return xMaxPoint;}
Int_t getYMinPoint(void)
{return yMinPoint;}
Int_t getYMaxPoint(void)
{return yMaxPoint;}
Double_t getXMin(void)
{return points[xMinPoint].getX();}
Double_t getXMax(void)
{return points[xMaxPoint].getX();}
Double_t getYMin(void)
{return points[yMinPoint].getY();}
Double_t getYMax(void)
{return points[yMaxPoint].getY();}
Int_t nextP(Int_t p) const
{p++; return p<nPoints ? p:0;}
Int_t prevP(Int_t p) const
 For nextPXMax and nextPXMin calcDir must be called before.
{if(p<=0) p=nPoints; return --p;}
Int_t nextXMaxP(Int_t p) const
{return dir==1 ? nextP(p):prevP(p);}
Int_t nextXMinP(Int_t p) const
{return dir==1 ? prevP(p):nextP(p);}
Int_t prevXMaxP(Int_t p) const
{return dir==1 ? prevP(p):nextP(p);}
Int_t prevXMinP(Int_t p) const
{return dir==1 ? nextP(p):prevP(p);}

Last change: Sat May 22 13:04:13 2010
Last generated: 2010-05-22 13:04

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.