46 fpDefaultVisAttributes (0),
49 fCullInvisible (false),
50 fDensityCulling (false),
51 fVisibleDensity (0.01 *
g /
cm3),
53 fCBDAlgorithmNumber (0),
72 fpDefaultVisAttributes (pDefaultVisAttributes),
73 fDrawingStyle (drawingStyle),
75 fCullInvisible (isCullingInvisible),
76 fDensityCulling (isDensityCulling),
77 fVisibleDensity (visibleDensity),
78 fCullCovered (isCullingCovered),
79 fCBDAlgorithmNumber(0),
81 fNoOfSides (noOfSides),
96 const std::vector<G4PhysicalVolumeModel::G4PhysicalVolumeNodeID>& path):
97 fVisAtts(visAtts), fSignifier(signifier)
100 typedef std::vector<PVNodeID>
PVPath;
101 typedef PVPath::const_iterator PVPathConstIterator;
102 PVPathConstIterator i;
103 for (i = path.begin();
106 fPVNameCopyNoPath.push_back
108 (i->GetPhysicalVolume()->GetName(),
115 if (visibleDensity < 0 &&
fWarning) {
116 G4cout <<
"G4ModelingParameters::SetVisibleDensity: attempt to set negative "
117 "density - ignored." <<
G4endl;
121 G4cout <<
"G4ModelingParameters::SetVisibleDensity: density > "
123 <<
" g / cm3 - did you mean this?"
132 if (nSides < nSidesMin) {
135 G4cout <<
"G4ModelingParameters::SetNoOfSides: attempt to set the"
136 "\nnumber of sides per circle < " << nSidesMin
137 <<
"; forced to" << nSides <<
G4endl;
145 delete fpSectionSolid;
146 fpSectionSolid = pSectionSolid;
151 delete fpCutawaySolid;
152 fpCutawaySolid = pCutawaySolid;
157 os <<
"Modeling parameters (warning ";
163 os <<
"\n Default vis. attributes: ";
167 os <<
"\n Current requested drawing style: ";
170 os <<
"wireframe";
break;
172 os <<
"hidden line removal (hlr)";
break;
174 os <<
"surface (hsr)";
break;
176 os <<
"surface and edges (hlhsr)";
break;
177 default: os <<
"unrecognised";
break;
180 os <<
"\n Culling: ";
184 os <<
"\n Culling invisible objects: ";
188 os <<
"\n Density culling: ";
190 os <<
"on - invisible if density less than "
195 os <<
"\n Culling daughters covered by opaque mothers: ";
199 os <<
"\n Colour by density: ";
212 os <<
"\n No. of sides used in circle polygon approximation: "
215 os <<
"\n Section (DCUT) shape (G4VSolid) pointer: ";
219 os <<
"\n Cutaway (DCUT) shape (G4VSolid) pointer: ";
223 os <<
"\n Event pointer: " << mp.
fpEvent;
225 os <<
"\n Vis attributes modifiers: ";
226 const std::vector<G4ModelingParameters::VisAttributesModifier>& vams =
237 G4bool G4ModelingParameters::operator !=
241 (fWarning != mp.fWarning) ||
242 (*fpDefaultVisAttributes != *mp.fpDefaultVisAttributes) ||
243 (fCulling != mp.fCulling) ||
244 (fCullInvisible != mp.fCullInvisible) ||
245 (fDensityCulling != mp.fDensityCulling) ||
246 (fCullCovered != mp.fCullCovered) ||
247 (fCBDAlgorithmNumber != mp.fCBDAlgorithmNumber) ||
248 (fExplodeFactor != mp.fExplodeFactor) ||
249 (fExplodeCentre != mp.fExplodeCentre) ||
250 (fNoOfSides != mp.fNoOfSides) ||
251 (fpSectionSolid != mp.fpSectionSolid) ||
252 (fpCutawaySolid != mp.fpCutawaySolid) ||
253 (fpEvent != mp.fpEvent)
257 if (fDensityCulling &&
258 (fVisibleDensity != mp.fVisibleDensity))
return true;
260 if (fCBDAlgorithmNumber > 0) {
261 if (fCBDParameters.size() != mp.fCBDParameters.size())
return true;
262 else if (fCBDParameters != mp.fCBDParameters)
return true;
265 if (fVisAttributesModifiers != mp.fVisAttributesModifiers)
271 G4bool G4ModelingParameters::VisAttributesModifier::operator!=
274 if (fSignifier != rhs.fSignifier)
return true;
275 if (fPVNameCopyNoPath != rhs.fPVNameCopyNoPath)
return true;
276 switch (fSignifier) {
278 if (fVisAtts.IsVisible() != rhs.fVisAtts.IsVisible())
282 if (fVisAtts.IsDaughtersInvisible() !=
283 rhs.fVisAtts.IsDaughtersInvisible())
287 if (fVisAtts.GetColour() != rhs.fVisAtts.GetColour())
291 if (fVisAtts.GetLineStyle() != rhs.fVisAtts.GetLineStyle())
295 if (fVisAtts.GetLineWidth() != rhs.fVisAtts.GetLineWidth())
299 if (fVisAtts.GetForcedDrawingStyle() !=
300 rhs.fVisAtts.GetForcedDrawingStyle())
304 if (fVisAtts.GetForcedDrawingStyle() !=
305 rhs.fVisAtts.GetForcedDrawingStyle())
309 if (fVisAtts.IsForceAuxEdgeVisible() !=
310 rhs.fVisAtts.IsForceAuxEdgeVisible() ||
311 fVisAtts.IsForcedAuxEdgeVisible() !=
312 rhs.fVisAtts.IsForcedAuxEdgeVisible())
316 if (fVisAtts.GetForcedLineSegmentsPerCircle() !=
317 rhs.fVisAtts.GetForcedLineSegmentsPerCircle())
324 G4bool G4ModelingParameters::PVNameCopyNo::operator!=
327 if (
fName != rhs.fName)
return true;
328 if (fCopyNo != rhs.fCopyNo)
return true;
332 std::ostream&
operator <<
335 os <<
"Touchable path: physical-volume-name:copy-number pairs:\n ";
337 for (i = path.begin(); i != path.end(); ++i) {
338 if (i != path.begin()) {
341 os << i->GetName() <<
':' << i->GetCopyNo();
351 G4bool G4ModelingParameters::PVPointerCopyNo::operator!=
354 if (fpPV != rhs.fpPV)
return true;
355 if (fCopyNo != rhs.fCopyNo)
return true;
359 std::ostream&
operator <<
362 os <<
"Touchable path: physical-volume-pointer:copy-number pairs:\n ";
364 for (i = path.begin(); i != path.end(); ++i) {
365 if (i != path.begin()) {
368 os <<
'(' << (
void*)(i->GetPVPointer()) <<
')' << i->GetName() <<
':' << i->GetCopyNo();
373 std::ostream&
operator <<
375 const std::vector<G4ModelingParameters::VisAttributesModifier>& vams)
377 std::vector<G4ModelingParameters::VisAttributesModifier>::const_iterator
379 for (iModifier = vams.begin();
380 iModifier != vams.end();
383 iModifier->GetPVNameCopyNoPath();
384 os <<
'\n' << vamPath;
387 switch (iModifier->GetVisAttributesSignifier()) {
389 os <<
" visibility ";
397 os <<
" daughtersInvisible ";
405 os <<
" colour " << c;
426 os <<
" forceWireframe ";
436 os <<
" forceSolid ";
445 os <<
" forceAuxEdgeVisible: ";
460 os <<
" lineSegmentsPerCircle "
std::vector< PVNameCopyNo > PVNameCopyNoPath
G4VSolid * fpCutawaySolid
std::ostream & operator<<(std::ostream &, const BasicVector3D< float > &)
G4VSolid * fpSectionSolid
ForcedDrawingStyle GetForcedDrawingStyle() const
G4int SetNoOfSides(G4int)
DrawingStyle fDrawingStyle
PVPointerCopyNoPath::const_iterator PVPointerCopyNoPathConstIterator
VisAttributesModifier(const G4VisAttributes &visAtts, VisAttributesSignifier signifier, const PVNameCopyNoPath &path)
G4bool IsForceAuxEdgeVisible() const
void SetSectionSolid(G4VSolid *pSectionSolid)
G4bool IsForcedAuxEdgeVisible() const
static G4int GetMinLineSegmentsPerCircle()
static constexpr double g
std::vector< PVNodeID > PVPath
G4double GetLineWidth() const
G4int fCBDAlgorithmNumber
#define G4BestUnit(a, b)
#define G4_USE_G4BESTUNIT_FOR_VERBOSE 1
std::vector< PVPointerCopyNo > PVPointerCopyNoPath
std::vector< VisAttributesModifier > fVisAttributesModifiers
G4bool IsForceDrawingStyle() const
const G4String & GetName() const
G4PhysicalVolumeModel::G4PhysicalVolumeNodeID PVNodeID
const G4VisAttributes * fpDefaultVisAttributes
G4GLOB_DLL std::ostream G4cout
void SetCutawaySolid(G4VSolid *pCutawaySolid)
void SetVisibleDensity(G4double)
PVNameCopyNoPath::const_iterator PVNameCopyNoPathConstIterator
static constexpr double cm3
LineStyle GetLineStyle() const
G4int GetForcedLineSegmentsPerCircle() const
const G4Colour & GetColour() const
const G4String & GetName() const
G4bool IsDaughtersInvisible() const
std::vector< G4double > fCBDParameters