34#ifndef G4UTESSELLATEDSOLID_HH
35#define G4UTESSELLATEDSOLID_HH
39#if ( defined(G4GEOM_USE_USOLIDS) || defined(G4GEOM_USE_PARTIAL_USOLIDS) )
41#include <VecGeom/volumes/UnplacedTessellated.h>
46class G4UTessellatedSolid :
public G4UAdapter<vecgeom::UnplacedTessellated>
48 using Shape_t = vecgeom::UnplacedTessellated;
49 using Base_t = G4UAdapter<vecgeom::UnplacedTessellated>;
53 G4UTessellatedSolid();
54 G4UTessellatedSolid(
const G4String& pName);
55 ~G4UTessellatedSolid()
override;
57 G4bool AddFacet(G4VFacet* aFacet);
58 G4VFacet* GetFacet(
G4int i)
const;
60 G4int GetNumberOfFacets()
const;
64 inline G4bool IsFaceted()
const override;
66 void SetSolidClosed(
const G4bool t);
67 G4bool GetSolidClosed()
const;
69 void SetMaxVoxels(
G4int);
77 G4int AllocatedMemoryWithoutVoxels();
78 G4int AllocatedMemory();
79 void DisplayAllocatedMemory();
81 G4UTessellatedSolid(__void__&);
86 G4UTessellatedSolid(
const G4UTessellatedSolid& source );
87 G4UTessellatedSolid& operator=(
const G4UTessellatedSolid& source);
92 const G4VoxelLimits& pVoxelLimit,
93 const G4AffineTransform& pTransform,
96 G4Polyhedron* CreatePolyhedron()
const override;
100 std::vector<G4VFacet*> fFacets;
101 std::vector<G4ThreeVector> fVertexList;
110 return "G4TessellatedSolid";
113inline G4bool G4UTessellatedSolid::IsFaceted()
const
CLHEP::Hep3Vector G4ThreeVector