49 fVoxelsVisAttributes[0].SetColour(
G4Colour(1.,0.,0.));
50 fVoxelsVisAttributes[1].SetColour(
G4Colour(0.,1.,0.));
51 fVoxelsVisAttributes[2].SetColour(
G4Colour(0.,0.,1.));
52 fBoundingBoxVisAttributes.SetColour(
G4Colour(.3,0.,.2));
61 fVoxelsVisAttributes[0] = VA_voxelX;
62 fVoxelsVisAttributes[1] = VA_voxelY;
63 fVoxelsVisAttributes[2] = VA_voxelZ;
68 fBoundingBoxVisAttributes = VA_boundingbox;
83 G4double dx=kInfinity, dy=kInfinity, dz=kInfinity;
84 G4double xmax=0, xmin=0, ymax=0, ymin=0, zmax=0, zmin=0;
104 G4PolyhedronBox bounding_polyhedronBox(dx*0.5,dy*0.5,dz*0.5);
105 bounding_polyhedronBox.SetVisAttributes(&fBoundingBoxVisAttributes);
110 ppl->push_back(G4PlacedPolyhedron(bounding_polyhedronBox,
114 const G4VisAttributes* voxelsVisAttributes =
nullptr;
124 t_FirstCenterofVoxelPlane=
G4ThreeVector(xmin,(ymin+ymax)*0.5,
126 voxelsVisAttributes=&fVoxelsVisAttributes[0];
130 t_FirstCenterofVoxelPlane=
G4ThreeVector((xmin+xmax)*0.5,ymin,
133 voxelsVisAttributes=&fVoxelsVisAttributes[1];
138 (ymin+ymax)*0.5,zmin);
140 voxelsVisAttributes=&fVoxelsVisAttributes[2];
146 G4PolyhedronBox voxel_plane(dx*0.5,dy*0.5,dz*0.5);
147 voxel_plane.SetVisAttributes(voxelsVisAttributes);
149 G4SmartVoxelProxy* slice = header->
GetSlice(0);
150 std::size_t slice_no = 0, no_slices = header->
GetNoSlices();
154 while (slice_no<no_slices)
158 G4VoxelLimits newlimit(limit);
159 newlimit.AddLimit(header->
GetAxis(), beginning+step*slice_no,
161 ComputeVoxelPolyhedra(lv,slice->
GetHeader(), newlimit, ppl);
163 current_translation_vector = unit_translation_vector;
164 current_translation_vector *= step*slice_no;
166 ppl->push_back(G4PlacedPolyhedron(voxel_plane,
168 + t_FirstCenterofVoxelPlane)));
172 if (slice_no<no_slices) { slice=header->
GetSlice(slice_no); }
204 GetNavigatorForTracking()->CreateTouchableHistoryHandle();
211 if(pVVisManager !=
nullptr)
215 for (
const auto & i : *pplist)
217 pVVisManager->
Draw(i.GetPolyhedron(),
218 i.GetTransform()*transf3D);
225 "Pointer to visualization manager is null!");
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *description)
std::vector< G4PlacedPolyhedron > G4PlacedPolyhedronList
CLHEP::Hep3Vector G4ThreeVector
G4ReferenceCountedHandle< G4VTouchable > G4TouchableHandle
void DrawVoxels(const G4LogicalVolume *lv) const
void SetVoxelsVisAttributes(G4VisAttributes &, G4VisAttributes &, G4VisAttributes &)
G4PlacedPolyhedronList * CreatePlacedPolyhedra(const G4LogicalVolume *) const
void SetBoundingBoxVisAttributes(G4VisAttributes &)
G4VSolid * GetSolid() const
std::size_t GetNoDaughters() const
G4SmartVoxelHeader * GetVoxelHeader() const
const G4AffineTransform & GetTopTransform() const
G4int GetMaxEquivalentSliceNo() const
G4SmartVoxelNode * GetNode() const
G4SmartVoxelHeader * GetHeader() const
virtual const G4NavigationHistory * GetHistory() const
static G4TransportationManager * GetTransportationManager()
virtual G4bool CalculateExtent(const EAxis pAxis, const G4VoxelLimits &pVoxelLimit, const G4AffineTransform &pTransform, G4double &pMin, G4double &pMax) const =0
static G4VVisManager * GetConcreteInstance()
virtual void Draw(const G4Circle &, const G4Transform3D &objectTransformation=G4Transform3D())=0