117 fpScene = pVMan -> GetCurrentScene ();
119 std::ostringstream ost;
145 return defaultExtent;
172 (
"G4VSceneHandler::BeginPrimitives",
174 "Nesting detected. It is illegal to nest Begin/EndPrimitives.");
194 (
"G4VSceneHandler::BeginPrimitives2D",
196 "Nesting detected. It is illegal to nest Begin/EndPrimitives.");
326 if (trajectoriesModel)
330 (
"G4VSceneHandler::AddCompound(const G4VTrajectory&)",
337 const_cast<G4VHit&
>(hit).Draw();
342 const_cast<G4VDigi&
>(digi).Draw();
348 G4bool scoreMapHits =
false;
350 if (scoringManager) {
352 for (std::size_t iMesh = 0; iMesh < nMeshes; ++iMesh) {
357 for(MeshScoreMap::const_iterator i = scoreMap.cbegin();
358 i != scoreMap.cend(); ++i) {
359 const G4String& scoreMapName = i->first;
360 if (scoreMapName == mapNam) {
363 mesh->
DrawMesh(scoreMapName, &colorMap);
370 static G4bool first =
true;
374 "Scoring map drawn with default parameters."
375 "\n To get gMocren file for gMocren browser:"
376 "\n /vis/open gMocrenFile"
377 "\n /vis/viewer/flush"
378 "\n Many other options available with /score/draw... commands."
379 "\n You might want to \"/vis/viewer/set/autoRefresh false\"."
391 G4bool scoreMapHits =
false;
393 if (scoringManager) {
395 for (std::size_t iMesh = 0; iMesh < nMeshes; ++iMesh) {
399 for(MeshScoreMap::const_iterator i = scoreMap.cbegin();
400 i != scoreMap.cend(); ++i) {
401 const G4String& scoreMapName = i->first;
403 if (foundHits == &hits) {
406 mesh->
DrawMesh(scoreMapName, &colorMap);
413 static G4bool first =
true;
417 "Scoring map drawn with default parameters."
418 "\n To get gMocren file for gMocren browser:"
419 "\n /vis/open gMocrenFile"
420 "\n /vis/viewer/flush"
421 "\n Many other options available with /score/draw... commands."
422 "\n You might want to \"/vis/viewer/set/autoRefresh false\"."
434 "There has been an attempt to draw a mesh with option \""
435 <<
fpViewer->GetViewParameters().GetSpecialMeshRenderingOption()
437 <<
"but it is not of a recognised type or is not implemented"
438 "\nby the current graphics driver. Instead we draw its"
447 const auto& saveVisAtts = lv->GetVisAttributes();
449 tmpVisAtts = *saveVisAtts;
451 auto colour = saveVisAtts->GetColour();
457 solid->DescribeYourselfTo(*
this);
460 lv->SetVisAttributes(saveVisAtts);
475 for (std::size_t iPoint = 0; iPoint < polymarker.size (); ++iPoint) {
484 for (std::size_t iPoint = 0; iPoint < polymarker.size (); ++iPoint) {
493 for (std::size_t iPoint = 0; iPoint < polymarker.size (); ++iPoint) {
506 visManager->SetCurrentViewer(
nullptr);
512 G4warn <<
" Open a plotter-aware graphics system or remove plotter with" <<
G4endl;
521 (*i) -> SetNeedKernelVisit (
true);
536 auto pSolid = &solid;
540 pBooleanSolid->BoundingLimits(bmin, bmax);
543 auto ptrB = pBooleanSolid->GetConstituentSolid(1);
544 for (
G4int i=0; i<10; ++i) {
556 auto ptrB = pBooleanSolid->GetConstituentSolid(1);
557 for (
G4int i=0; i<10; ++i) {
571 for (
G4int i=0; i<10000; ++i) {
605 auto problematicVolume = pPVModel->GetCurrentPV();
610 "ERROR: G4VSceneHandler::RequestPrimitives"
611 "\n Polyhedron not available for " << solid.
GetName ();
612 G4warn <<
"\n Touchable path: " << pPVModel->GetFullPVPath();
613 static G4bool explanation =
false;
617 "\n This means it cannot be visualized in the usual way on most systems."
618 "\n 1) The solid may not have implemented the CreatePolyhedron method."
619 "\n 2) For Boolean solids, the BooleanProcessor, which attempts to create"
620 "\n the resultant polyhedron, may have failed."
621 "\n Try RayTracer. It uses Geant4's tracking algorithms instead.";
624 G4warn <<
"\n Drawing solid with cloud of points.";
645 for (
G4int i = 0; i < numberOfCloudPoints; ++i) {
687 "The scene has no extent.");
707 const std::vector<G4Scene::Model>& runDurationModelList =
708 fpScene->GetRunDurationModelList();
710 if(runDurationModelList.size()) {
713 static G4int first =
true;
717 "(This could happen more than once - in fact, up to three times"
718 "\nper rebuild, for opaque, transparent and non-hidden markers.)"
724 fpViewer->AccessSceneTree().ResetVisibility();
731 for(std::size_t i = 0; i < runDurationModelList.size(); ++i) {
732 if(runDurationModelList[i].fActive) {
733 fpModel = runDurationModelList[i].fpModel;
734 fpModel->SetModelingParameters(pMP);
737 fpModel->DescribeYourselfTo(*
this);
749 fpModel->DescribeYourselfTo(sceneTreeScene);
753 fpModel->SetModelingParameters(0);
765 for (
const auto& model: runDurationModelList) {
769 G4int nTouchables = 0;
770 G4cout <<
"Numbers of touchables by depth in model \""
771 << pvModel->GetGlobalDescription() <<
"\":";
772 for (
const auto& dn : pvModel->GetNumberOfTouchables()) {
773 G4cout <<
"\n Depth " << dn.first <<
": " << dn.second;
774 nTouchables += dn.second;
776 G4cout <<
"\n Total number of touchables: " << nTouchables <<
G4endl;
782 G4cout <<
"Problematic volumes:";
784 G4cout <<
"\n " << prob.first->GetName() <<
" (" << prob.second <<
')';
812 const std::vector<const G4Event*>* events =
814 std::size_t nKeptEvents = 0;
816 nKeptEvents = events->size();
819 if(
fpScene->GetRefreshAtEndOfEvent())
826 if(events && events->size())
827 event = events->back();
838 for(
const auto& event : *events)
844 if(!
fpScene->GetRefreshAtEndOfRun())
848 G4warn <<
"WARNING: Cannot refresh events accumulated over more"
849 "\n than one runs. Refreshed just the last run."
872 if(!
fpViewer->ReadyToDraw())
return;
873 const std::vector<G4Scene::Model>& EOEModelList =
874 fpScene -> GetEndOfEventModelList ();
875 std::size_t nModels = EOEModelList.size();
879 for (std::size_t i = 0; i < nModels; ++i) {
880 if (EOEModelList[i].fActive) {
881 fpModel = EOEModelList[i].fpModel;
882 fpModel -> SetModelingParameters(pMP);
885 fpModel -> DescribeYourselfTo (*
this);
891 fpModel -> SetModelingParameters(0);
901 if(!
fpViewer->ReadyToDraw())
return;
902 const std::vector<G4Scene::Model>& EORModelList =
903 fpScene -> GetEndOfRunModelList ();
904 std::size_t nModels = EORModelList.size();
908 for (std::size_t i = 0; i < nModels; ++i) {
909 if (EORModelList[i].fActive) {
910 fpModel = EORModelList[i].fpModel;
911 fpModel -> SetModelingParameters(pMP);
914 fpModel -> DescribeYourselfTo (*
this);
920 fpModel -> SetModelingParameters(0);
958 G4bool reallyCullCovered =
1001 return pModelingParams;
1012 G4double safe = radius +
fpScene->GetExtent().GetExtentCentre().mag();
1014 new G4Box(
"_sectioner", safe, safe, 1.e-5 * radius);
1022 (
"_displaced_sectioning_box", sectionBox, requiredTransform);
1030 const auto& vp =
fpViewer->GetViewParameters();
1031 const auto& nPlanes = vp.GetCutawayPlanes().size();
1033 if (nPlanes == 0)
return nullptr;
1035 std::vector<G4DisplacedSolid*> cutaway_solids;
1038 G4double safe = radius +
fpScene->GetExtent().GetExtentCentre().mag();
1039 auto cutawayBox =
new G4Box(
"_cutaway_box", safe, safe, safe);
1053 for (
size_t plane_no = 0; plane_no < nPlanes; plane_no++)
1055 const G4Plane3D& sp = vp.GetCutawayPlanes()[plane_no];
1058 switch (vp.GetCutawayMode()) {
1060 normal = -sp.normal();
1065 normal = sp.normal();
1070 cutaway_solids.push_back
1071 (
new G4DisplacedSolid(
"_displaced_cutaway_box", cutawayBox, requiredTransform));
1078 switch (vp.GetCutawayMode()) {
1084 else if (nPlanes == 3) {
1095 else if (nPlanes == 3) {
1104 "Not programmed for more than 3 cutaway planes");
1113 const std::map<G4String,G4AttDef>* vaDefs =
1124 const std::map<G4String,G4AttDef>* pvDefs = pPVModel->
GetAttDefs();
1133 const std::map<G4String,G4AttDef>* trajModelDefs = trajModel->
GetAttDefs();
1134 if (trajModelDefs) {
1140 const std::map<G4String,G4AttDef>* trajDefs = traj->
GetAttDefs();
1145 for (
G4int i = 0; i < nPoints; ++i) {
1148 const std::map<G4String,G4AttDef>* pointDefs = trajPoint->
GetAttDefs();
1161 const std::map<G4String,G4AttDef>* hitsDefs = hit->
GetAttDefs();
1176 if (!pVA) pVA =
fpViewer->GetViewParameters().GetDefaultVisAttributes();
1177 return pVA->GetColour();
1182 if (!pVA) pVA =
fpViewer->GetViewParameters().GetDefaultTextVisAttributes();
1183 return pVA->GetColour();
1189 if (lineWidth < 1.) lineWidth = 1.;
1190 lineWidth *=
fpViewer -> GetViewParameters().GetGlobalLineWidthScale();
1191 if (lineWidth < 1.) lineWidth = 1.;
1203 if (pVisAttribs -> IsForceDrawingStyle ()) {
1205 pVisAttribs -> GetForcedDrawingStyle ();
1208 switch (forcedStyle) {
1210 switch (viewerStyle) {
1238 return resultantStyle;
1246 G4int numberOfCloudPoints =
fpViewer->GetViewParameters().GetNumberOfCloudPoints();
1247 if (pVisAttribs -> IsForceDrawingStyle() &&
1249 pVisAttribs -> GetForcedNumberOfCloudPoints() > 0) {
1250 numberOfCloudPoints = pVisAttribs -> GetForcedNumberOfCloudPoints();
1252 return numberOfCloudPoints;
1256 G4bool isAuxEdgeVisible =
fpViewer->GetViewParameters().IsAuxEdgeVisible ();
1257 if (pVisAttribs -> IsForceAuxEdgeVisible()) {
1260 return isAuxEdgeVisible;
1269 fpViewer -> GetViewParameters().GetDefaultMarker();
1274 markerSizeType =
world;
1277 size = userSpecified ?
1282 size *=
fpViewer -> GetViewParameters().GetGlobalMarkerScale();
1283 if (markerSizeType ==
screen && size < 1.) size = 1.;
1292 G4int lineSegmentsPerCircle =
fpViewer->GetViewParameters().GetNoOfSides();
1296 if (lineSegmentsPerCircle < pVisAttribs->GetMinLineSegmentsPerCircle()) {
1299 "G4VSceneHandler::GetNoOfSides: attempt to set the"
1300 "\nnumber of line segments per circle < " << lineSegmentsPerCircle
1304 return lineSegmentsPerCircle;
1309 os <<
"Scene handler " << sh.
fName <<
" has "
1311 for (std::size_t i = 0; i < sh.
fViewerList.size (); ++i) {
1319 os <<
"\n This scene handler currently has no scene.";
1325void G4VSceneHandler::PseudoSceneFor3DRectMeshPositions::AddSolid(
const G4Box&) {
1334 fPositionByMaterial.insert(std::make_pair(material,
position));
1335 if (fNameAndVisAttsByMaterial.find(material) == fNameAndVisAttsByMaterial.end())
1337 fNameAndVisAttsByMaterial[material] = NameAndVisAtts(name,*pVisAtts);
1341void G4VSceneHandler::PseudoSceneForTetVertices::AddSolid(
const G4VSolid& solid) {
1342 if (fpPVModel->GetCurrentDepth() == fpMesh->GetMeshDepth()) {
1345 const auto& tet =
dynamic_cast<const G4Tet&
>(solid);
1346 const auto& material = fpPVModel->GetCurrentLV()->GetMaterial();
1347 const auto&
name = material? material->GetName(): fpMesh->GetContainerVolume()->GetName();
1348 const auto& pVisAtts = fpPVModel->GetCurrentLV()->GetVisAttributes();
1350 if (fpCurrentObjectTransformation->xx() == 1. &&
1351 fpCurrentObjectTransformation->yy() == 1. &&
1352 fpCurrentObjectTransformation->zz() == 1.) {
1353 const auto& vertices = tet.GetVertices();
1354 fVerticesByMaterial.insert(std::make_pair(material,vertices));
1356 auto vertices = tet.GetVertices();
1357 for (
auto&& vertex: vertices) {
1358 vertex =
G4Point3D(vertex).transform(*fpCurrentObjectTransformation);
1360 fVerticesByMaterial.insert(std::make_pair(material,vertices));
1362 if (fNameAndVisAttsByMaterial.find(material) == fNameAndVisAttsByMaterial.end())
1364 fNameAndVisAttsByMaterial[material] =
NameAndVisAtts(name,*pVisAtts);
1366 catch (
const std::bad_cast&) {
1368 ed <<
"Called for a mesh that is not a tetrahedron mesh: " << solid.
GetName();
1379 G4bool implemented =
false;
1383 switch (
fpViewer->GetViewParameters().GetSpecialMeshRenderingOption()) {
1397 switch (
fpViewer->GetViewParameters().GetSpecialMeshRenderingOption()) {
1419 if (containerVisAtts ==
nullptr || containerVisAtts->IsVisible()) {
1420 auto solid = containerLogical->GetSolid();
1424 if (containerVisAtts !=
nullptr) tmpVisAtts = *containerVisAtts;
1426 polyhedron->SetVisAttributes(tmpVisAtts);
1446 ed <<
"Called with a mesh that is not rectangular:" << mesh;
1451 static G4bool firstPrint =
true;
1456 <<
"Special case drawing of 3D rectangular G4VNestedParameterisation as dots:"
1464 static std::map<G4String,std::map<const G4Material*,G4Polymarker>> dotsByMaterialAndMesh;
1468 if (dotsByMaterial.empty()) {
1476 const G4bool useFullExtent =
true;
1484 std::multimap<const G4Material*,const G4ThreeVector> positionByMaterial;
1485 std::map<const G4Material*,G4VSceneHandler::NameAndVisAtts> nameAndVisAttsByMaterial;
1488 (&tmpPVModel,&mesh,positionByMaterial,nameAndVisAttsByMaterial);
1495 const auto& halfX = prms.
fHalfX;
1496 const auto& halfY = prms.fHalfY;
1497 const auto& halfZ = prms.fHalfZ;
1500 G4int nDotsTotal = 0;
1501 for (
const auto& entry: nameAndVisAttsByMaterial) {
1503 const auto& material = entry.first;
1504 const auto& nameAndVisAtts = nameAndVisAttsByMaterial[material];
1505 const auto& name = nameAndVisAtts.fName;
1506 const auto& visAtts = nameAndVisAtts.fVisAtts;
1513 dotsByMaterial[material] = dots;
1515 auto& dotsInMap = dotsByMaterial[material];
1516 const auto& range = positionByMaterial.equal_range(material);
1517 for (
auto posByMat = range.first; posByMat != range.second; ++posByMat) {
1518 dotsInMap.push_back(
GetPointInBox(posByMat->second, halfX, halfY, halfZ));
1524 << std::setw(30) << std::left << name.substr(0,30) << std::right
1525 <<
": " << std::setw(7) << nDots <<
" dots"
1526 <<
": colour " << std::fixed << std::setprecision(2)
1527 << visAtts.GetColour() << std::defaultfloat
1531 nDotsTotal += nDots;
1535 G4cout <<
"Total number of dots: " << nDotsTotal <<
G4endl;
1544 parameterisationName = pPVModel->GetFullPVPath().back().GetPhysicalVolume()->GetName();
1549 auto keepVP =
fpViewer->GetViewParameters();
1550 auto vp =
fpViewer->GetViewParameters();
1551 vp.SetMarkerHidden();
1555 for (
const auto& entry: dotsByMaterial) {
1556 const auto& dots = entry.second;
1563 const auto& fullPVPath = pPVModel->GetFullPVPath();
1564 auto leafPV = fullPVPath.back().GetPhysicalVolume();
1565 leafPV->SetName(dots.GetInfo());
1572 fpViewer->SetViewParameters(keepVP);
1575 pPVModel->GetFullPVPath().back().GetPhysicalVolume()->SetName(parameterisationName);
1590 ed <<
"Called with a mesh that is not rectangular:" << mesh;
1595 static G4bool firstPrint =
true;
1600 <<
"Special case drawing of 3D rectangular G4VNestedParameterisation as surfaces:"
1608 static std::map<G4String,std::map<const G4Material*,G4Polyhedron>> boxesByMaterialAndMesh;
1612 if (boxesByMaterial.empty()) {
1620 const G4bool useFullExtent =
true;
1628 std::multimap<const G4Material*,const G4ThreeVector> positionByMaterial;
1629 std::map<const G4Material*,G4VSceneHandler::NameAndVisAtts> nameAndVisAttsByMaterial;
1632 (&tmpPVModel,&mesh,positionByMaterial,nameAndVisAttsByMaterial);
1639 const auto& sizeX = 2.*prms.
fHalfX;
1640 const auto& sizeY = 2.*prms.fHalfY;
1641 const auto& sizeZ = 2.*prms.fHalfZ;
1644 G4int nBoxesTotal = 0, nFacetsTotal = 0;
1645 for (
const auto& entry: nameAndVisAttsByMaterial) {
1647 const auto& material = entry.first;
1648 const auto& nameAndVisAtts = nameAndVisAttsByMaterial[material];
1649 const auto& name = nameAndVisAtts.fName;
1650 const auto& visAtts = nameAndVisAtts.fVisAtts;
1652 std::vector<G4ThreeVector> positionsForPolyhedron;
1653 const auto& range = positionByMaterial.equal_range(material);
1654 for (
auto posByMat = range.first; posByMat != range.second; ++posByMat) {
1655 const auto&
position = posByMat->second;
1656 positionsForPolyhedron.push_back(
position);
1661 auto& polyhedron = boxesByMaterial[material];
1664 polyhedron.SetVisAttributes(visAtts);
1665 polyhedron.SetInfo(name);
1669 << std::setw(30) << std::left << name.substr(0,30) << std::right
1670 <<
": " << std::setw(7) << nBoxes <<
" boxes"
1671 <<
" (" << std::setw(7) << 6*nBoxes <<
" faces)"
1672 <<
": reduced to " << std::setw(7) << polyhedron.GetNoFacets() <<
" facets ("
1673 << std::setw(2) << std::fixed << std::setprecision(2) << 100*polyhedron.GetNoFacets()/(6*nBoxes)
1674 <<
"%): colour " << std::fixed << std::setprecision(2)
1675 << visAtts.GetColour() << std::defaultfloat
1679 nBoxesTotal += nBoxes;
1680 nFacetsTotal += polyhedron.GetNoFacets();
1684 G4cout <<
"Total number of boxes: " << nBoxesTotal <<
" (" << 6*nBoxesTotal <<
" faces)"
1685 <<
": reduced to " << nFacetsTotal <<
" facets ("
1686 << std::setw(2) << std::fixed << std::setprecision(2) << 100*nFacetsTotal/(6*nBoxesTotal) <<
"%)"
1696 parameterisationName = pPVModel->GetFullPVPath().back().GetPhysicalVolume()->GetName();
1702 for (
const auto& entry: boxesByMaterial) {
1703 const auto& poly = entry.second;
1710 const auto& fullPVPath = pPVModel->GetFullPVPath();
1711 auto leafPV = fullPVPath.back().GetPhysicalVolume();
1712 leafPV->SetName(poly.GetInfo());
1719 pPVModel->GetFullPVPath().back().GetPhysicalVolume()->SetName(parameterisationName);
1733 ed <<
"Called with mesh that is not a tetrahedron mesh:" << mesh;
1738 static G4bool firstPrint =
true;
1744 <<
"Special case drawing of tetrahedron mesh as dots"
1752 static std::map<G4String,std::map<const G4Material*,G4Polymarker>> dotsByMaterialAndMesh;
1756 if (dotsByMaterial.empty()) {
1764 const G4bool useFullExtent =
true;
1772 std::multimap<const G4Material*,std::vector<G4ThreeVector>> verticesByMaterial;
1773 std::map<const G4Material*,G4VSceneHandler::NameAndVisAtts> nameAndVisAttsByMaterial;
1776 (&tmpPVModel,&mesh,verticesByMaterial,nameAndVisAttsByMaterial);
1783 G4int nDotsTotal = 0;
1784 for (
const auto& entry: nameAndVisAttsByMaterial) {
1786 const auto& material = entry.first;
1787 const auto& nameAndVisAtts = nameAndVisAttsByMaterial[material];
1788 const auto& name = nameAndVisAtts.fName;
1789 const auto& visAtts = nameAndVisAtts.fVisAtts;
1796 dotsByMaterial[material] = dots;
1798 auto& dotsInMap = dotsByMaterial[material];
1799 const auto& range = verticesByMaterial.equal_range(material);
1800 for (
auto vByMat = range.first; vByMat != range.second; ++vByMat) {
1807 << std::setw(30) << std::left << name.substr(0,30) << std::right
1808 <<
": " << std::setw(7) << nDots <<
" dots"
1809 <<
": colour " << std::fixed << std::setprecision(2)
1810 << visAtts.GetColour() << std::defaultfloat
1814 nDotsTotal += nDots;
1818 G4cout <<
"Total number of dots: " << nDotsTotal <<
G4endl;
1827 parameterisationName = pPVModel->GetFullPVPath().back().GetPhysicalVolume()->GetName();
1832 auto keepVP =
fpViewer->GetViewParameters();
1833 auto vp =
fpViewer->GetViewParameters();
1834 vp.SetMarkerHidden();
1839 for (
const auto& entry: dotsByMaterial) {
1840 const auto& dots = entry.second;
1847 const auto& fullPVPath = pPVModel->GetFullPVPath();
1848 auto leafPV = fullPVPath.back().GetPhysicalVolume();
1849 leafPV->SetName(dots.GetInfo());
1856 fpViewer->SetViewParameters(keepVP);
1859 pPVModel->GetFullPVPath().back().GetPhysicalVolume()->SetName(parameterisationName);
1873 ed <<
"Called with mesh that is not a tetrahedron mesh:" << mesh;
1878 static G4bool firstPrint =
true;
1884 <<
"Special case drawing of tetrahedron mesh as surfaces"
1890 static std::map<G4String,std::map<const G4Material*,G4Polyhedron>> surfacesByMaterialAndMesh;
1894 if (surfacesByMaterial.empty()) {
1902 const G4bool useFullExtent =
true;
1910 std::multimap<const G4Material*,std::vector<G4ThreeVector>> verticesByMaterial;
1911 std::map<const G4Material*,G4VSceneHandler::NameAndVisAtts> nameAndVisAttsByMaterial;
1914 (&tmpPVModel,&mesh,verticesByMaterial,nameAndVisAttsByMaterial);
1921 G4int nTetsTotal = 0, nFacetsTotal = 0;
1922 for (
const auto& entry: nameAndVisAttsByMaterial) {
1924 const auto& material = entry.first;
1925 const auto& nameAndVisAtts = nameAndVisAttsByMaterial[material];
1926 const auto& name = nameAndVisAtts.fName;
1927 const auto& visAtts = nameAndVisAtts.fVisAtts;
1929 std::vector<G4ThreeVector> verticesForPolyhedron;
1930 const auto& range = verticesByMaterial.equal_range(material);
1931 for (
auto vByMat = range.first; vByMat != range.second; ++vByMat) {
1932 const std::vector<G4ThreeVector>& vertices = vByMat->second;
1933 for (
const auto& vertex: vertices)
1934 verticesForPolyhedron.push_back(vertex);
1939 auto& polyhedron = surfacesByMaterial[material];
1942 polyhedron.SetVisAttributes(visAtts);
1943 polyhedron.SetInfo(name);
1947 << std::setw(30) << std::left << name.substr(0,30) << std::right
1948 <<
": " << std::setw(7) << nTets <<
" tetrahedra"
1949 <<
" (" << std::setw(7) << 4*nTets <<
" faces)"
1950 <<
": reduced to " << std::setw(7) << polyhedron.GetNoFacets() <<
" facets ("
1951 << std::setw(2) << std::fixed << std::setprecision(2) << 100*polyhedron.GetNoFacets()/(4*nTets)
1952 <<
"%): colour " << std::fixed << std::setprecision(2)
1953 << visAtts.GetColour() << std::defaultfloat
1957 nTetsTotal += nTets;
1958 nFacetsTotal += polyhedron.GetNoFacets();
1962 G4cout <<
"Total number of tetrahedra: " << nTetsTotal <<
" (" << 4*nTetsTotal <<
" faces)"
1963 <<
": reduced to " << nFacetsTotal <<
" facets ("
1964 << std::setw(2) << std::fixed << std::setprecision(2) << 100*nFacetsTotal/(4*nTetsTotal) <<
"%)"
1974 parameterisationName = pPVModel->GetFullPVPath().back().GetPhysicalVolume()->GetName();
1980 for (
const auto& entry: surfacesByMaterial) {
1981 const auto& poly = entry.second;
1988 const auto& fullPVPath = pPVModel->GetFullPVPath();
1989 auto leafPV = fullPVPath.back().GetPhysicalVolume();
1990 leafPV->SetName(poly.GetInfo());
1998 pPVModel->GetFullPVPath().back().GetPhysicalVolume()->SetName(parameterisationName);
2034 else if (p + q + r > 1.)
2041 return vertices[0]*a + vertices[1]*p + vertices[2]*q + vertices[3]*r;
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *description)
std::ostringstream G4ExceptionDescription
HepGeom::Plane3D< G4double > G4Plane3D
HepGeom::Point3D< G4double > G4Point3D
CLHEP::Hep3Vector G4ThreeVector
std::ostream & operator<<(std::ostream &os, const G4VSceneHandler &sh)
std::vector< G4VViewer * >::iterator G4ViewerListIterator
void print(G4double elem)
G4GLOB_DLL std::ostream G4cout
Hep3Vector orthogonal() const
void AddAtts(const std::vector< G4AttValue > *values, const std::map< G4String, G4AttDef > *defs)
const G4VHit * GetCurrentHit() const
G4VSolid * GetSolid() const
const G4VisAttributes * GetVisAttributes() const
G4Material * GetMaterial() const
MeshType GetMeshType() const
G4VPhysicalVolume * GetContainerVolume() const
const G4Transform3D & GetTransform() const
const ThreeDRectangleParameters & GetThreeDRectParameters() const
G4int GetMeshDepth() const
void SetCBDParameters(const std::vector< G4double > &)
void SetNumberOfCloudPoints(G4int)
void SetCBDAlgorithmNumber(G4int)
void SetExplodeFactor(G4double explodeFactor)
void SetVisAttributesModifiers(const std::vector< VisAttributesModifier > &)
void SetExplodeCentre(const G4Point3D &explodeCentre)
void SetCutawayMode(CutawayMode)
void SetCutawaySolid(G4DisplacedSolid *pCutawaySolid)
void SetSectionSolid(G4DisplacedSolid *pSectionSolid)
void SetEvent(const G4Event *pEvent)
void SetCullingInvisible(G4bool)
void SetSpecialMeshVolumes(const std::vector< PVNameCopyNo > &)
void SetSpecialMeshRendering(G4bool)
std::vector< G4AttValue > * CreateCurrentAttValues() const
void DescribeYourselfTo(G4VGraphicsScene &)
G4LogicalVolume * GetCurrentLV() const
const std::map< G4String, G4AttDef > * GetAttDefs() const
G4int GetCurrentDepth() const
void SetMarkerType(MarkerType)
MarkerType GetMarkerType() const
const G4Transform3D * fpCurrentObjectTransformation
static G4RunManager * GetMasterRunManager()
const G4Run * GetCurrentRun() const
std::vector< const G4Event * > * GetEventVector() const
G4VScoringMesh * GetMesh(G4int i) const
std::size_t GetNumberOfMesh() const
static G4ScoringManager * GetScoringManagerIfExist()
const G4ApplicationState & GetCurrentState() const
static G4StateManager * GetStateManager()
const G4VTrajectory * GetCurrentTrajectory() const
std::vector< G4AttValue > * CreateCurrentAttValues() const
const std::map< G4String, G4AttDef > * GetAttDefs() const
virtual std::vector< G4AttValue > * CreateAttValues() const
virtual const std::map< G4String, G4AttDef > * GetAttDefs() const
G4double GetScreenSize() const
void SetSize(SizeType, G4double)
void SetScreenSize(G4double)
void SetWorldSize(G4double)
void SetPosition(const G4Point3D &)
G4double GetWorldSize() const
G4LogicalVolume * GetLogicalVolume() const
const G4String & GetName() const
virtual void BeginModeling()
G4int GetNumberOfCloudPoints(const G4VisAttributes *) const
G4int GetNoOfSides(const G4VisAttributes *)
void DrawTetMeshAsSurfaces(const G4Mesh &)
virtual void ClearTransientStore()
void LoadAtts(const G4Visible &, G4AttHolder *)
void DrawEvent(const G4Event *)
G4ModelingParameters * CreateModelingParameters()
const G4Colour & GetTextColour(const G4Text &)
const G4Colour & GetColour()
void Draw3DRectMeshAsDots(const G4Mesh &)
void AddSolidT(const T &solid)
G4Transform3D fObjectTransformation
virtual void EndPrimitives()
G4bool fTransientsDrawnThisEvent
void AddSolidWithAuxiliaryEdges(const T &solid)
virtual G4DisplacedSolid * CreateSectionSolid()
virtual void EndModeling()
std::map< G4VPhysicalVolume *, G4String > fProblematicVolumes
const G4int fSceneHandlerId
virtual const G4VisExtent & GetExtent() const
virtual void ProcessScene()
G4double GetMarkerSize(const G4VMarker &, MarkerSizeType &)
virtual void PreAddSolid(const G4Transform3D &objectTransformation, const G4VisAttributes &)
G4VSceneHandler(G4VGraphicsSystem &system, G4int id, const G4String &name="")
G4bool fTransientsDrawnThisRun
virtual void PostAddSolid()
const G4String & GetName() const
void AddViewerToList(G4VViewer *pView)
virtual void EndPrimitives2D()
virtual void SetScene(G4Scene *)
void DrawEndOfRunModels()
G4bool fMarkForClearingTransientStore
const G4VisAttributes * fpVisAttribs
virtual void BeginPrimitives2D(const G4Transform3D &objectTransformation=G4Transform3D())
G4ThreeVector GetPointInBox(const G4ThreeVector &pos, G4double halfX, G4double halfY, G4double halfZ) const
virtual void RequestPrimitives(const G4VSolid &solid)
G4bool fReadyForTransients
G4ViewParameters::DrawingStyle GetDrawingStyle(const G4VisAttributes *)
void RemoveViewerFromList(G4VViewer *pView)
virtual G4DisplacedSolid * CreateCutawaySolid()
void DrawTetMeshAsDots(const G4Mesh &)
virtual void BeginPrimitives(const G4Transform3D &objectTransformation=G4Transform3D())
G4double GetLineWidth(const G4VisAttributes *)
G4ThreeVector GetPointInTet(const std::vector< G4ThreeVector > &vertices) const
G4VGraphicsSystem & fSystem
virtual void AddSolid(const G4Box &)
virtual void ClearStore()
void Draw3DRectMeshAsSurfaces(const G4Mesh &)
virtual void AddCompound(const G4VTrajectory &)
virtual ~G4VSceneHandler()
virtual void AddPrimitive(const G4Polyline &)=0
G4bool GetAuxEdgeVisible(const G4VisAttributes *)
void StandardSpecialMeshRendering(const G4Mesh &)
std::map< G4String, RunScore * > MeshScoreMap
void DrawMesh(const G4String &psName, G4VScoreColorMap *colorMap, G4int axflg=111)
MeshScoreMap GetScoreMap() const
virtual G4ThreeVector GetPointOnSurface() const
virtual G4Polyhedron * GetPolyhedron() const
virtual std::vector< G4AttValue > * CreateAttValues() const
virtual const std::map< G4String, G4AttDef > * GetAttDefs() const
virtual G4VTrajectoryPoint * GetPoint(G4int i) const =0
virtual G4int GetPointEntries() const =0
virtual std::vector< G4AttValue > * CreateAttValues() const
virtual void DrawTrajectory() const
virtual const std::map< G4String, G4AttDef > * GetAttDefs() const
static G4VVisManager * GetConcreteInstance()
const std::vector< G4ModelingParameters::VisAttributesModifier > & GetVisAttributesModifiers() const
G4int GetNoOfSides() const
G4bool IsSpecialMeshRendering() const
CutawayMode GetCutawayMode() const
G4double GetExplodeFactor() const
G4int GetNumberOfCloudPoints() const
const std::vector< G4double > & GetCBDParameters() const
G4int GetCBDAlgorithmNumber() const
const std::vector< G4ModelingParameters::PVNameCopyNo > & GetSpecialMeshVolumes() const
G4bool IsCullingInvisible() const
const G4VisAttributes * GetDefaultVisAttributes() const
G4bool IsDensityCulling() const
G4double GetVisibleDensity() const
const G4Point3D & GetExplodeCentre() const
G4bool IsCullingCovered() const
const G4Plane3D & GetSectionPlane() const
DrawingStyle GetDrawingStyle() const
const std::map< G4String, G4AttDef > * GetAttDefs() const
G4bool IsForceLineSegmentsPerCircle() const
G4double GetLineWidth() const
void SetColour(const G4Colour &)
void SetVisibility(G4bool=true)
void SetForceAuxEdgeVisible(G4bool=true)
G4int GetForcedLineSegmentsPerCircle() const
void SetForceWireframe(G4bool=true)
const std::vector< G4AttValue > * CreateAttValues() const
G4bool IsForcedAuxEdgeVisible() const
static G4int GetMinLineSegmentsPerCircle()
static const G4VisExtent & GetNullExtent()
void SetEventRefreshing(G4bool)
G4bool GetTransientsDrawnThisEvent() const
G4bool GetTransientsDrawnThisRun() const
static Verbosity GetVerbosity()
const G4Event * GetRequestedEvent() const
static G4VisManager * GetInstance()
friend class G4VSceneHandler
void SetVisAttributes(const G4VisAttributes *)
const G4VisAttributes * GetVisAttributes() const
virtual void SetInfo(const G4String &info)
static void SetNumberOfRotationSteps(G4int n)
static void ResetNumberOfRotationSteps()
const char * name(G4int ptype)