1 #ifndef PHG4ConeDetector_h
2 #define PHG4ConeDetector_h
6 #include <Geant4/globals.hh>
7 #include <Geant4/G4Region.hh>
8 #include <Geant4/G4SystemOfUnits.hh>
9 #include <Geant4/G4Types.hh>
16 class G4LogicalVolume;
18 class G4VPhysicalVolume;
33 virtual void Construct( G4LogicalVolume* world );
42 void SetR1(
const G4double min,
const G4double max)
43 {rMin1 = min*cm; rMax1=max*cm;}
46 void SetR2(
const G4double min,
const G4double max)
47 {rMin2 = min*cm; rMax2=max*cm;}
54 void SetPhi(
const G4double a,
const G4double b)
58 void SetPlaceZ(
const G4double place_z) {place_in_z = place_z*cm;}
59 void SetPlace(
const G4double place_x,
const G4double place_y,
const G4double place_z)
61 place_in_x = place_x*cm;
62 place_in_y = place_y*cm;
63 place_in_z = place_z*cm;
65 void SetZRot(
const G4double z_angle) {z_rot = z_angle*rad;}
69 return _region->GetRegionalSteppingAction();
80 G4Material* TrackerMaterial;
82 G4Material* InactiveMaterial;
85 G4LogicalVolume* block_logic;
86 G4VPhysicalVolume* block_physi;
105 std::string superdetector;
void SetZlength(const G4double a)
set length in Z
PHG4ConeDetector(PHCompositeNode *Node, const std::string &dnam="BLOCK", const int lyr=0)
constructor
void SetActive(const int i=1)
void SetR2(const G4double min, const G4double max)
set inner and outter radius2
bool IsInConeActive(G4VPhysicalVolume *)
bool IsInConeInactive(G4VPhysicalVolume *)
void SetPlaceZ(const G4double place_z)
void SetMaterial(const std::string &mat)
void SuperDetector(const std::string &name)
void SetPhi(const G4double a, const G4double b)
set phi offset and extention
const std::string SuperDetector() const
virtual void Construct(G4LogicalVolume *world)
construct
virtual G4UserSteppingAction * GetSteppingAction()
virtual ~PHG4ConeDetector(void)
destructor
void SetZRot(const G4double z_angle)
void SetPlace(const G4double place_x, const G4double place_y, const G4double place_z)
void SetR1(const G4double min, const G4double max)
set inner and outter radius1
base class for phenix detector creation