19#ifndef BDSGEOMETRYFACTORYBASE_H
20#define BDSGEOMETRYFACTORYBASE_H
22#include "BDSExtent.hh"
23#include "BDSFactoryBase.hh"
26#include "G4RotationMatrix.hh"
37class G4VPhysicalVolume;
56 std::map<G4String, G4Colour*>* colourMapping =
nullptr,
57 G4bool autoColour =
true,
58 G4double suggestedLength = 0,
59 G4double suggestedHorizontalWidth = 0,
60 std::vector<G4String>* vacuumBiasVolumeNames =
nullptr,
61 G4UserLimits* userLimitsToAttachToAllLVs =
nullptr) = 0;
70 std::map<G4String, G4Colour*>* mapping,
72 const G4String& preprocessPrefix =
"");
76 G4UserLimits* userLimits);
85 const G4String& acceleratorComponentName)
const;
88 std::set<G4LogicalVolume*>
GetVolumes(
const std::set<G4LogicalVolume*>& allLVs,
89 std::vector<G4String>* volumeNames,
90 G4bool preprocessGDML,
91 const G4String& componentName)
const;
104 G4double y0, G4double ry,
105 G4double z0, G4double rz);
108 void ExpandExtent(G4double x0, G4double xLow, G4double xHigh,
109 G4double y0, G4double yLow, G4double yHigh,
110 G4double z0, G4double zLow, G4double zHigh);
Holder for +- extents in 3 dimensions.
Common temporary storage for all factories no matter what geometry.
A loaded piece of externally provided geometry.
Base class for external geometry loading factories.
G4double ymax
Extent in one dimension.
void ExpandExtent(const BDSExtent &extent)
Expand the acuumulated extents using a (possibly asymmetric) extent instance.
virtual BDSGeometryExternal * Build(G4String componentName, G4String fileName, std::map< G4String, G4Colour * > *colourMapping=nullptr, G4bool autoColour=true, G4double suggestedLength=0, G4double suggestedHorizontalWidth=0, std::vector< G4String > *vacuumBiasVolumeNames=nullptr, G4UserLimits *userLimitsToAttachToAllLVs=nullptr)=0
Main method to load and construct geometry.
virtual G4String PreprocessedName(const G4String &objectName, const G4String &acceleratorComponentName) const
std::set< G4LogicalVolume * > GetVolumes(const std::set< G4LogicalVolume * > &allLVs, std::vector< G4String > *volumeNames, G4bool preprocessGDML, const G4String &componentName) const
Get the volumes that match the name. Volume names are matched exactly and are case sensitive.
virtual void CleanUp()
Virtual clean up that derived classes can override that calls CleanUpBase().
G4double xmin
Extent in one dimension.
G4double ymin
Extent in one dimension.
G4double zmin
Extent in one dimension.
G4double zmax
Extent in one dimension.
G4double xmax
Extent in one dimension.
virtual void ApplyUserLimits(const std::set< G4LogicalVolume * > &lvsIn, G4UserLimits *userLimits)
Attach a set of user limits to every logical volume supplied.
virtual std::set< G4VisAttributes * > ApplyColourMapping(std::set< G4LogicalVolume * > &lvs, std::map< G4String, G4Colour * > *mapping, G4bool autoColour, const G4String &preprocessPrefix="")