56 Int_t thisLevel = level;
57 if (!thisLevel) thisLevel =
fDepth;
97 curNode = curPosition->
GetNode();
98 curPositionId = curPosition->
GetId();
100 Error(
"UpdateTempMatrix",
"No position has been defined");
107 Double_t oldTranslation[] = { 0, 0, 0 };
110 oldTranslation[0] = oldPosition->
GetX();
111 oldTranslation[1] = oldPosition->
GetY();
112 oldTranslation[2] = oldPosition->
GetZ();
124 ,curPosition->
GetX(),curPosition->
GetY(),curPosition->
GetZ()
126 ,newTranslation,newMatrix);
131 ,newTranslation[0],newTranslation[1],newTranslation[2]
135 newTranslation[0] = oldTranslation[0] + curPosition->
GetX();
136 newTranslation[1] = oldTranslation[1] + curPosition->
GetY();
137 newTranslation[2] = oldTranslation[2] + curPosition->
GetZ();
138 newPosition =
SetPositionAt(curNode,newTranslation[0],newTranslation[1],newTranslation[2]);
145 if (newPosition) newPosition->
SetId(curPositionId);
154 Int_t thisLevel = level;
155 if (!thisLevel) thisLevel =
fDepth;
158 *thisPosition = *newPosition;
176 if (position) position->
Reset(node,
x,
y,z,matrix);
191 if (position) *position = curPosition;
R__EXTERN TGeometry * gGeometry
virtual Int_t GetSize() const
Return the capacity of the collection, i.e.
virtual void Reset(TDataSet *l=0, Int_t depth=0)
TDataSet *l != 0 means the new start pointer depth != 0 means the new value for the depth otherwise t...
virtual void UpdateTempMatrix(Double_t x=0, Double_t y=0, Double_t z=0, TRotMatrix *matrix=0)
Update temp matrix.
THashList * GetListOfMatrices() const
virtual void AddAtAndExpand(TObject *obj, Int_t idx)
Add object at position idx.
virtual void Delete(Option_t *option="")
Remove all objects from the array AND delete all heap based objects.
TObject * At(Int_t idx) const
virtual void Error(const char *method, const char *msgfmt,...) const
Issue error message.
Manages a detector rotation matrix.
virtual Double_t GetZ() const
virtual TVolume * GetNode() const
virtual Double_t GetY() const
virtual Double_t GetX(Int_t indx=0) const
Bool_t SetMatrixOwner(Bool_t ownerShips=kTRUE)
virtual UInt_t GetId() const
virtual TVolumePosition * Reset(TVolume *node=0, Double_t x=0, Double_t y=0, Double_t z=0, TRotMatrix *matrix=0)
Reset this position.
virtual void SetId(UInt_t id)
const TRotMatrix * GetMatrix() const
virtual TVolumePosition * SetPositionAt(TVolume *node, Double_t x=0, Double_t y=0, Double_t z=0, TRotMatrix *matrix=0)
to be documented
void ResetPosition(Int_t level=0, TVolumePosition *newPosition=0)
to be documented
~TVolumeViewIter()
to be documented
virtual TDataSet * operator[](const Char_t *path)
operator [] returns the pointer to the TDataSet if it does contain any data (TTable for example)
TVolumeViewIter(TVolumeView *view, Int_t depth=1, Bool_t dir=kIterForward)
to be documented
virtual void Reset(TDataSet *l=0, Int_t depth=0)
to be documented
virtual const TVolumePosition * GetPosition(Int_t level=0) const
to be documented
TVolumePosition * UpdateTempMatrix(TVolumePosition *curPosition)
Pick the "old" position by pieces.
virtual Bool_t Notify()
This method must be overridden to handle object notification.
virtual TVolumePosition * GetPosition() const