20 #include "TGeoManager.h"
21 #include "TGeoMatrix.h"
22 #include "KVTelescope.h"
63 if (!b->InheritsFrom(
"KVTelescope"))
return;
76 TIter next(GetTelescopes());
93 return (
KVTelescope*)GetStructure(
"TELESCOPE", name);
104 if (GetThetaMin() < ((
KVRing*) obj)->GetThetaMin())
106 else if (GetThetaMin() > ((
KVRing*) obj)->GetThetaMin())
122 Double_t sol_ang = 0;
124 TIter nxttel(GetTelescopes());
143 TString name(GetName());
145 name.ReplaceAll(
" ",
"_");
146 TGeoVolume* mother_vol = gGeoManager->MakeVolumeAssembly(name.Data());
148 TIter next(GetTelescopes());
155 Double_t phi = det->
GetPhi();
156 TGeoRotation rot1, rot2;
157 rot2.SetAngles(phi + 90., theta, 0.);
158 rot1.SetAngles(-90., 0., 0.);
161 Double_t dist = det->
GetDistance() + tot_len_tel / 2.;
163 Double_t trans_1 = dist;
165 Double_t trans_2 = dist * TMath::Cos(theta * TMath::DegToRad());
167 SetDistance(trans_2);
169 TGeoTranslation tran1(0, 0, trans_1);
170 TGeoTranslation tran2(0, 0, -trans_2);
171 TGeoHMatrix h = tran2 * rot2 * tran1 * rot1;
172 TGeoHMatrix* ph =
new TGeoHMatrix(h);
174 mother_vol->AddNode(det_vol, 1, ph);
187 if (!gGeoManager)
return;
190 TGeoVolume* vol = GetGeoVolume();
193 TGeoTranslation* tr =
new TGeoTranslation(0, 0, GetDistance());
196 gGeoManager->GetTopVolume()->AddNode(vol, 1, tr);
Base class for KaliVeda framework.
virtual void Add(KVBase *)
Bool_t IsInPhiRange(const Double_t phi)
virtual Double_t GetSolidAngle(void) const
virtual Double_t GetTheta() const
virtual Double_t GetPhi() const
virtual Double_t GetDistance(void) const
Ring in INDRA array (obsolete)
virtual TGeoVolume * GetGeoVolume()
Create and return TGeoVolume representing detectors in this ring.
KVTelescope * GetTelescope(Float_t phi) const
give pointer to telescope in ring which covers azimuthal angle phi
void Add(KVBase *)
Only KVTelescope-derived structures can be placed in a KVRing.
virtual void AddToGeometry()
Construct and position a TGeoVolume shape to represent this ring in the current geometry.
Double_t GetSolidAngle(void) const
Int_t Compare(const TObject *obj) const
rings are sorted according to lower edge polar angle
Associates two detectors placed one behind the other.
virtual TGeoVolume * GetGeoVolume()
Create and return TGeoVolume representing detectors in this telescope.
Double_t GetTotalLengthInCM() const