19#include "BDSColours.hh"
20#include "BDSColourFromMaterial.hh"
21#include "BDSGeometryExternal.hh"
22#include "BDSGeometryFactoryBase.hh"
23#include "BDSGlobalConstants.hh"
24#include "BDSUtilities.hh"
27#include "G4AssemblyVolume.hh"
29#include "G4LogicalVolume.hh"
30#include "G4RotationMatrix.hh"
32#include "G4VisAttributes.hh"
33#include "G4VPhysicalVolume.hh"
40BDSGeometryFactoryBase::BDSGeometryFactoryBase()
45BDSGeometryFactoryBase::~BDSGeometryFactoryBase()
49 std::map<G4String, G4Colour*>* mapping,
51 const G4String& prefixToStripFromName)
53 std::set<G4VisAttributes*> visAttributes;
56 if (!mapping && !autoColour)
57 {
return visAttributes;}
61 if (mapping->size() == 1)
64 vis->SetVisibility(
true);
65 visAttributes.insert(vis);
67 {lv->SetVisAttributes(*vis);}
73 std::map<G4String, G4VisAttributes*> attMap;
74 for (
const auto& it : *mapping)
76 G4VisAttributes* vis =
new G4VisAttributes(*(it.second));
77 vis->SetVisibility(
true);
78 visAttributes.insert(vis);
79 attMap[it.first] = vis;
84 const G4String& name = lv->GetName();
85 for (
const auto& it : attMap)
89 lv->SetVisAttributes(it.second);
100 const G4VisAttributes* existingVis = lv->GetVisAttributes();
104 G4VisAttributes* vis =
new G4VisAttributes(*c);
105 vis->SetVisibility(
true);
106 visAttributes.insert(vis);
107 lv->SetVisAttributes(vis);
112 return visAttributes;
116 G4UserLimits* userLimits)
118 for (
auto& lv : lvsIn)
119 {lv->SetUserLimits(userLimits);}
128 const G4String& )
const
132 std::vector<G4String>* volumeNames,
133 G4bool preprocessFile,
134 const G4String& componentName)
const
137 {
return std::set<G4LogicalVolume*>();}
139 std::vector<G4String> expectedVolumeNames;
143 expectedVolumeNames.resize(volumeNames->size());
144 std::transform(volumeNames->begin(),
146 expectedVolumeNames.begin(),
147 [&](
const G4String& n){return PreprocessedName(n, componentName);});
150 {expectedVolumeNames = *volumeNames;}
152 std::set<G4LogicalVolume*> volsMatched;
153 for (
const auto& en : expectedVolumeNames)
155 for (
auto lv : allLVs)
157 if (lv->GetName() == en)
158 {volsMatched.insert(lv);}
186 G4double y0, G4double ry,
187 G4double z0, G4double rz)
198 G4double y0, G4double yLow, G4double yHigh,
199 G4double z0, G4double zLow, G4double zHigh)
static BDSColourFromMaterial * Instance()
Singleton pattern.
G4Colour * GetColour(const G4Material *material, const G4String &prefixToStripFromName="")
Get colour from name.
static BDSColours * Instance()
singleton pattern
Holder for +- extents in 3 dimensions.
G4double XPos() const
Accessor.
G4double ZPos() const
Accessor.
G4double XNeg() const
Accessor.
G4double YNeg() const
Accessor.
G4double YPos() const
Accessor.
G4double ZNeg() const
Accessor.
virtual void FactoryBaseCleanUp()
Empty containers for next use - factories are never deleted so can't rely on scope.
G4double ymax
Extent in one dimension.
void ExpandExtent(const BDSExtent &extent)
Expand the acuumulated extents using a (possibly asymmetric) extent instance.
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="")
G4bool StrContains(const G4String &str, const G4String &test)
Utility function to simplify lots of syntax changes for pedantic g4 changes.