39#if ( defined(G4GEOM_USE_USOLIDS) || defined(G4GEOM_USE_PARTIAL_USOLIDS) )
41#include <VecGeom/volumes/UnplacedParallelepiped.h>
45class G4UPara :
public G4UAdapter<vecgeom::UnplacedParallelepiped>
47 using Shape_t = vecgeom::UnplacedParallelepiped;
48 using Base_t = G4UAdapter<vecgeom::UnplacedParallelepiped>;
52 G4UPara(
const G4String& pName,
56 G4UPara(
const G4String& pName,
81 void SetThetaAndPhi(
double pTheta,
double pPhi);
86 void ComputeDimensions(G4VPVParameterisation* p,
88 const G4VPhysicalVolume* pRep)
override;
92 inline G4bool IsFaceted()
const override;
97 const G4VoxelLimits& pVoxelLimit,
98 const G4AffineTransform& pTransform,
101 G4VSolid* Clone()
const override;
103 G4Polyhedron* CreatePolyhedron ()
const override;
112 G4UPara(
const G4UPara& rhs);
113 G4UPara& operator=(
const G4UPara& rhs);
118 void CheckParameters();
126 G4double fTalpha,fTthetaCphi,fTthetaSphi;
127 struct {
G4double a,b,c,d; } fPlanes[4];
139inline G4bool G4UPara::IsFaceted()
const
CLHEP::Hep3Vector G4ThreeVector