97 G4bool mtRunInProgress =
false;
98 std::deque<const G4Event*> mtVisEventQueue;
105 G4bool isSubEventRunManagerType =
false;
106 G4bool isValidViewForRun =
false;
121, fInitialised (false)
122, fpGraphicsSystem (0)
126, fpStateDependent (0)
127, fEventRefreshing (false)
128, fTransientsDrawnThisRun (false)
129, fTransientsDrawnThisEvent (false)
130, fNoOfEventsDrawnThisRun (0)
131, fNKeepForPostProcessingRequests (0)
132, fNKeepTheEventRequests (0)
133, fEventKeepingSuspended (false)
134, fDrawEventOnlyIfToBeKept (false)
135, fpRequestedEvent (0)
136, fReviewingKeptEvents (false)
137, fAbortReviewKeptEvents (false)
138, fReviewingPlots (false)
139, fAbortReviewPlots (false)
140, fIsDrawGroup (false)
141, fDrawGroupNestingDepth (0)
142, fIgnoreStateChanges (false)
143, fMaxEventQueueSize (100)
144, fWaitOnEventQueueFull (true)
153 (
"Simple graded message scheme - digit or string (1st character defines):");
155 (
" 0) quiet, // Nothing is printed.");
157 (
" 1) startup, // Startup and endup messages are printed...");
159 (
" 2) errors, // ...and errors...");
161 (
" 3) warnings, // ...and warnings...");
163 (
" 4) confirmations, // ...and confirming messages...");
165 (
" 5) parameters, // ...and parameters of scenes and views...");
167 (
" 6) all // ...and everything available.");
171 (
"G4VisManager::G4VisManager",
173 "Attempt to Construct more than one VisManager");
185 <<
"Visualization Manager instantiating with verbosity \""
215 G4bool propagateToWorkers;
216 auto directory =
new G4UIdirectory (
"/vis/",propagateToWorkers=
false);
217 directory -> SetGuidance (
"Visualization commands.");
220 fDirectoryList.push_back (directory);
236 for (i = 0; i < fSceneList.size (); ++i) {
237 delete fSceneList[i];
239 for (i = 0; i < fAvailableSceneHandlers.size (); ++i) {
240 if (fAvailableSceneHandlers[i] != NULL) {
241 delete fAvailableSceneHandlers[i];
244 for (i = 0; i < fAvailableGraphicsSystems.size (); ++i) {
245 if (fAvailableGraphicsSystems[i]) {
246 delete fAvailableGraphicsSystems[i];
251 G4cout <<
"Visualization Manager deleting..." <<
G4endl;
253 for (i = 0; i < fMessengerList.size (); ++i) {
254 delete fMessengerList[i];
256 for (i = 0; i < fDirectoryList.size (); ++i) {
257 delete fDirectoryList[i];
260 delete fpDigiFilterMgr;
261 delete fpHitFilterMgr;
262 delete fpTrajFilterMgr;
263 delete fpTrajDrawModelMgr;
270 (
"G4VisManager::GetInstance",
279 G4warn <<
"WARNING: G4VisManager::Initialise: already initialised."
285 G4cout <<
"Visualization Manager initialising..." <<
G4endl;
290 "\nYou have instantiated your own Visualization Manager, inheriting"
291 "\n G4VisManager and implementing RegisterGraphicsSystems(), in which"
292 "\n you should, normally, instantiate drivers which do not need"
293 "\n external packages or libraries, and, optionally, drivers under"
294 "\n control of environment variables."
295 "\n Also you should implement RegisterModelFactories()."
296 "\n See visualization/management/include/G4VisExecutive.hh/icc, for example."
297 "\n In your main() you will have something like:"
298 "\n G4VisManager* visManager = new G4VisExecutive;"
299 "\n visManager -> SetVerboseLevel (Verbose);"
300 "\n visManager -> Initialize ();"
301 "\n (Don't forget to delete visManager;)"
314 "\nYou have successfully registered the following graphics systems."
324 directory -> SetGuidance (
"Modeling commands.");
325 fDirectoryList.push_back (directory);
326 directory =
new G4UIdirectory (
"/vis/modeling/trajectories/");
327 directory -> SetGuidance (
"Trajectory model commands.");
328 fDirectoryList.push_back (directory);
329 directory =
new G4UIdirectory (
"/vis/modeling/trajectories/create/");
330 directory -> SetGuidance (
"Create trajectory models and messengers.");
331 fDirectoryList.push_back (directory);
335 directory -> SetGuidance (
"Filtering commands.");
336 fDirectoryList.push_back (directory);
337 directory =
new G4UIdirectory (
"/vis/filtering/trajectories/");
338 directory -> SetGuidance (
"Trajectory filtering commands.");
339 fDirectoryList.push_back (directory);
340 directory =
new G4UIdirectory (
"/vis/filtering/trajectories/create/");
341 directory -> SetGuidance (
"Create trajectory filters and messengers.");
342 fDirectoryList.push_back (directory);
344 directory -> SetGuidance (
"Hit filtering commands.");
345 fDirectoryList.push_back (directory);
346 directory =
new G4UIdirectory (
"/vis/filtering/hits/create/");
347 directory -> SetGuidance (
"Create hit filters and messengers.");
348 fDirectoryList.push_back (directory);
350 directory -> SetGuidance (
"Digi filtering commands.");
351 fDirectoryList.push_back (directory);
352 directory =
new G4UIdirectory (
"/vis/filtering/digi/create/");
353 directory -> SetGuidance (
"Create digi filters and messengers.");
354 fDirectoryList.push_back (directory);
366 "\nYou have successfully registered the following model factories."
377 InitialiseG4ColourMap();
381 "Some /vis commands (optionally) take a string to specify colour."
382 "\n\"/vis/list\" to see available colours."
389void G4VisManager::InitialiseG4ColourMap()
const
398#define TOOLS_COLORS_STAT(name,r,g,b) \
399G4Colour::AddToMap(#name, G4Colour(r,g,b));
480#undef TOOLS_COLORS_STAT
491 directory -> SetGuidance(
"Operations on vis attributes of Geant4 geometry.");
492 fDirectoryList.push_back (directory);
497 directory -> SetGuidance(
"Set vis attributes of Geant4 geometry.");
498 fDirectoryList.push_back (directory);
511 directory -> SetGuidance(
"Commands unique to multithreading mode.");
512 fDirectoryList.push_back (directory);
517 directory -> SetGuidance
518 (
"Set quantities for use in future commands where appropriate.");
519 fDirectoryList.push_back (directory);
531 directory -> SetGuidance (
"Operations on Geant4 scenes.");
532 fDirectoryList.push_back (directory);
544 directory -> SetGuidance (
"Add model to current scene.");
545 fDirectoryList.push_back (directory);
585 directory -> SetGuidance (
"Operations on Geant4 scene handlers.");
586 fDirectoryList.push_back (directory);
593 directory -> SetGuidance (
"Operations on touchables.");
594 fDirectoryList.push_back (directory);
598 directory -> SetGuidance (
"Set vis attributes of current touchable.");
599 fDirectoryList.push_back (directory);
603 directory -> SetGuidance (
"Operations on Geant4 viewers.");
604 fDirectoryList.push_back (directory);
632 directory -> SetGuidance(
"Set default values for future viewers.");
633 fDirectoryList.push_back (directory);
638 directory -> SetGuidance (
"Set view parameters of current viewer.");
639 fDirectoryList.push_back (directory);
664 (fpTrajDrawModelMgr, fpTrajDrawModelMgr->Placement()));
666 (fpTrajDrawModelMgr, fpTrajDrawModelMgr->Placement()));
670 (fpTrajFilterMgr, fpTrajFilterMgr->Placement()));
672 (fpTrajFilterMgr, fpTrajFilterMgr->Placement()));
676 (fpHitFilterMgr, fpHitFilterMgr->Placement()));
678 (fpHitFilterMgr, fpHitFilterMgr->Placement()));
682 (fpDigiFilterMgr, fpDigiFilterMgr->Placement()));
684 (fpDigiFilterMgr, fpDigiFilterMgr->Placement()));
687#include <tools/histo/h1d>
688#include <tools/histo/h2d>
692 std::size_t fNumberOfPlots = 0;
693 std::size_t fTotalEntries = 0;
695 template <
typename HT>
696 PlotResults ResultsOfHnPlots(
const G4String& plotType) {
697 PlotResults plotResults;
699 auto keepControlVerbose = ui->GetVerboseLevel();
700 ui->SetVerboseLevel(0);
701 auto status = ui->ApplyCommand(
"/analysis/" + plotType +
"/getVector");
702 ui->SetVerboseLevel(keepControlVerbose);
704 G4String hexString = ui->GetCurrentValues(
G4String(
"/analysis/" + plotType +
"/getVector"));
705 if(hexString.size()) {
706 void* ptr; std::istringstream is(hexString); is >> ptr;
707 auto vectorOfPlots = (
const std::vector<HT*>*)ptr;
708 for (std::size_t i = 0; i < vectorOfPlots->size(); ++i) {
709 auto plot = (*vectorOfPlots)[i];
710 if (plot ==
nullptr)
continue;
711 ++plotResults.fNumberOfPlots;
712 plotResults.fTotalEntries += plot->entries();
718 void PrintListOfPlots() {
719 std::size_t numberOfPlots = 0;
720 std::size_t numberOfEntries = 0;
721 PlotResults h1results = ResultsOfHnPlots<tools::histo::h1d>(
"h1");
722 numberOfPlots += h1results.fNumberOfPlots;
723 numberOfEntries += h1results.fTotalEntries;
724 PlotResults h2results = ResultsOfHnPlots<tools::histo::h2d>(
"h2");
725 numberOfPlots += h2results.fNumberOfPlots;
726 numberOfEntries += h2results.fTotalEntries;
727 if (numberOfPlots > 0) {
728 G4warn <<
"There are histograms that can be viewed with visualization:";
729 if (h1results.fNumberOfPlots > 0) {
730 G4warn <<
"\n " << h1results.fNumberOfPlots <<
" h1 histograms(s)";
732 if (h2results.fNumberOfPlots > 0) {
733 G4warn <<
"\n " << h2results.fNumberOfPlots <<
" h2 histograms(s)";
736 <<
"\n List them with \"/analysis/list\"."
737 <<
"\n View them immediately with \"/vis/plot\" or \"/vis/reviewPlots\"."
739 if (numberOfEntries == 0) {
741 " But...there are no entries. To make your histograms available for"
742 "\n plotting in this UI session, use CloseFile(false) in your"
743 "\n EndOfRunAction and Reset() in your BeginOfRunAction."
751 if (IsValidView ()) {
754 G4cout <<
"G4VisManager::Enable: visualization enabled." <<
G4endl;
757 std::size_t nKeptEvents = 0;
761 if (nKeptEvents == 1) {isare =
"is"; plural =
"";}
763 "There " << isare <<
' ' << nKeptEvents <<
" kept event" << plural <<
'.'
765 if (nKeptEvents > 0) {
767 " \"/vis/reviewKeptEvents\" to review one by one."
768 "\n To see accumulated, \"/vis/enable\", then \"/vis/viewer/flush\" or \"/vis/viewer/rebuild\"."
777 "G4VisManager::Enable: WARNING: visualization remains disabled for"
778 "\n above reasons. Rectifying with valid vis commands will"
779 "\n automatically enable."
789 "G4VisManager::Disable: visualization disabled."
790 "\n The pointer returned by GetConcreteInstance will be zero."
791 "\n Note that it will become enabled after some valid vis commands."
795 G4int currentTrajectoryType =
797 if (currentTrajectoryType > 0) {
799 "You may wish to disable trajectory production too:"
800 "\n \"/tracking/storeTrajectory 0\""
801 "\nbut don't forget to re-enable with"
803 "\n \"/tracking/storeTrajectory " << currentTrajectoryType
804 <<
"\"\n and maybe \"/vis/viewer/rebuild\""
811 std::size_t nSystems = fAvailableGraphicsSystems.size ();
814 G4warn <<
"G4VisManager::GetAvailableGraphicsSystems: WARNING: no"
815 "\n graphics system available!"
816 "\n 1) Did you have environment variables G4VIS_BUILD_xxxx_DRIVER set"
817 "\n when you compiled/built the visualization code?"
818 "\n 2) Did you instantiate your own Visualization Manager and forget"
819 "\n to implement RegisterGraphicsSystems correctly?"
820 "\n 3) You can register your own graphics system, e.g.,"
821 "\n visManager->RegisterGraphicsSystem(new MyGraphicsSystem);)"
822 "\n after instantiating your vis manager and before"
823 "\n visManager->Initialize()."
827 return fAvailableGraphicsSystems;
833 fAvailableGraphicsSystems.push_back (pSystem);
835 G4cout <<
"G4VisManager::RegisterGraphicsSystem: "
836 << pSystem -> GetName ();
837 if (pSystem -> GetNickname () !=
"") {
838 G4cout <<
" (" << pSystem -> GetNickname () <<
")";
845 G4warn <<
"G4VisManager::RegisterGraphicsSystem: null pointer!"
856 assert (0 != fpTrajDrawModelMgr);
865 G4warn<<
"G4VisManager: Using G4TrajectoryDrawByCharge as fallback trajectory model."<<
G4endl;
866 G4warn<<
"See commands in /vis/modeling/trajectories/ for other options."<<
G4endl;
870 model = fpTrajDrawModelMgr->Current();
878 fpTrajDrawModelMgr->Register(model);
884 fpTrajDrawModelMgr->Register(factory);
889 fpTrajFilterMgr->Register(model);
895 fpTrajFilterMgr->Register(factory);
900 fpHitFilterMgr->Register(model);
906 fpHitFilterMgr->Register(factory);
911 fpDigiFilterMgr->Register(model);
917 fpDigiFilterMgr->Register(factory);
922 fpTrajDrawModelMgr->SetCurrent(model);
929 fDrawGroupNestingDepth++;
930 if (fDrawGroupNestingDepth > 1) {
932 (
"G4VisManager::BeginDraw",
934 "Nesting detected. It is illegal to nest Begin/EndDraw."
938 if (IsValidView ()) {
939 ClearTransientStoreIfMarked();
940 fpSceneHandler -> BeginPrimitives (objectTransform);
949 fDrawGroupNestingDepth--;
950 if (fDrawGroupNestingDepth != 0) {
951 if (fDrawGroupNestingDepth < 0) fDrawGroupNestingDepth = 0;
954 if (IsValidView ()) {
955 fpSceneHandler -> EndPrimitives ();
957 fIsDrawGroup =
false;
964 fDrawGroupNestingDepth++;
965 if (fDrawGroupNestingDepth > 1) {
967 (
"G4VisManager::BeginDraw2D",
969 "Nesting detected. It is illegal to nest Begin/EndDraw2D."
973 if (IsValidView ()) {
974 ClearTransientStoreIfMarked();
975 fpSceneHandler -> BeginPrimitives2D (objectTransform);
984 fDrawGroupNestingDepth--;
985 if (fDrawGroupNestingDepth != 0) {
986 if (fDrawGroupNestingDepth < 0) fDrawGroupNestingDepth = 0;
989 if (IsValidView ()) {
990 fpSceneHandler -> EndPrimitives2D ();
992 fIsDrawGroup =
false;
995template <
class T>
void G4VisManager::DrawT
996(
const T& graphics_primitive,
const G4Transform3D& objectTransform) {
1002 (
"G4VSceneHandler::DrawT",
1004 "Different transform detected in Begin/EndDraw group.");
1006 fpSceneHandler -> AddPrimitive (graphics_primitive);
1008 if (IsValidView ()) {
1009 ClearTransientStoreIfMarked();
1010 fpSceneHandler -> BeginPrimitives (objectTransform);
1011 fpSceneHandler -> AddPrimitive (graphics_primitive);
1012 fpSceneHandler -> EndPrimitives ();
1017template <
class T>
void G4VisManager::DrawT2D
1018(
const T& graphics_primitive,
const G4Transform3D& objectTransform) {
1022 if (objectTransform != fpSceneHandler->GetObjectTransformation()) {
1024 (
"G4VSceneHandler::DrawT",
1026 "Different transform detected in Begin/EndDraw2D group.");
1028 fpSceneHandler -> AddPrimitive (graphics_primitive);
1030 if (IsValidView ()) {
1031 ClearTransientStoreIfMarked();
1032 fpSceneHandler -> BeginPrimitives2D (objectTransform);
1033 fpSceneHandler -> AddPrimitive (graphics_primitive);
1034 fpSceneHandler -> EndPrimitives2D ();
1042 DrawT (circle, objectTransform);
1048 DrawT (polyhedron, objectTransform);
1054 DrawT (line, objectTransform);
1060 DrawT (polymarker, objectTransform);
1066 DrawT (square, objectTransform);
1072 DrawT (text, objectTransform);
1078 DrawT2D (circle, objectTransform);
1084 DrawT2D (polyhedron, objectTransform);
1090 DrawT2D (line, objectTransform);
1096 DrawT2D (polymarker, objectTransform);
1102 DrawT2D (square, objectTransform);
1108 DrawT2D (text, objectTransform);
1115 fpSceneHandler -> AddCompound (hit);
1117 if (IsValidView ()) {
1118 ClearTransientStoreIfMarked();
1119 fpSceneHandler -> AddCompound (hit);
1128 fpSceneHandler -> AddCompound (digi);
1130 if (IsValidView ()) {
1131 ClearTransientStoreIfMarked();
1132 fpSceneHandler -> AddCompound (digi);
1154 fpSceneHandler -> SetModel (&trajectoriesModel);
1155 fpSceneHandler -> AddCompound (traj);
1156 fpSceneHandler -> SetModel (0);
1158 if (IsValidView ()) {
1159 ClearTransientStoreIfMarked();
1160 fpSceneHandler -> SetModel (&trajectoriesModel);
1161 fpSceneHandler -> AddCompound (traj);
1162 fpSceneHandler -> SetModel (0);
1174 Draw (*pSol, attribs, objectTransform);
1183 fpSceneHandler -> PreAddSolid (objectTransform, attribs);
1185 fpSceneHandler -> PostAddSolid ();
1187 if (IsValidView ()) {
1188 ClearTransientStoreIfMarked();
1189 fpSceneHandler -> PreAddSolid (objectTransform, attribs);
1191 fpSceneHandler -> PostAddSolid ();
1214 G4VSolid* pSol = pLV -> GetSolid ();
1215 Draw (*pSol, attribs, objectTransform);
1222 auto modelingParameters = fpSceneHandler->CreateModelingParameters();
1224 const G4bool useFullExtent =
true;
1227 delete modelingParameters;
1232 if (fpGraphicsSystem) {
1235 if (pSceneHandler) {
1236 fAvailableSceneHandlers.push_back (pSceneHandler);
1237 fpSceneHandler = pSceneHandler;
1241 G4warn <<
"ERROR in G4VisManager::CreateSceneHandler during "
1242 << fpGraphicsSystem -> GetName ()
1243 <<
" scene handler creation.\n No action taken."
1248 else PrintInvalidPointers ();
1257 if (!fpSceneHandler) {
1258 PrintInvalidPointers ();
1266 G4warn <<
"ERROR in G4VisManager::CreateViewer: null pointer during "
1267 << fpGraphicsSystem -> GetName ()
1268 <<
" viewer creation.\n No action taken."
1274 if (p -> GetViewId() < 0) {
1276 G4warn <<
"ERROR in G4VisManager::CreateViewer during "
1277 << fpGraphicsSystem -> GetName ()
1278 <<
" viewer instantiation.\n No action taken."
1289 p -> SetViewParameters(initialvp);
1291 if (p -> GetViewId() < 0) {
1293 G4warn <<
"ERROR in G4VisManager::CreateViewer during "
1294 << fpGraphicsSystem -> GetName ()
1295 <<
" viewer initialisation.\n No action taken."
1302 fpSceneHandler -> AddViewerToList (fpViewer);
1305 G4cout <<
"G4VisManager::CreateViewer: new viewer created."
1315 static G4bool warned =
false;
1319 "NOTE: objects with visibility flag set to \"false\""
1320 " will not be drawn!"
1321 "\n \"/vis/viewer/set/culling global false\" to Draw such objects."
1322 "\n Also see other \"/vis/viewer/set\" commands."
1329 static G4bool warned =
false;
1333 "WARNING: covered objects in solid mode will not be rendered!"
1334 "\n \"/vis/viewer/set/culling coveredDaughters false\" to reverse this."
1335 "\n Also see other \"/vis/viewer/set\" commands."
1345 G4cout <<
"G4VisManager::GeometryHasChanged() called." <<
G4endl;
1351 -> GetNavigatorForTracking () -> GetWorldVolume ();
1354 G4warn <<
"WARNING: There is no world volume!" <<
G4endl;
1360 std::size_t iScene, nScenes = sceneList.size ();
1361 for (iScene = 0; iScene < nScenes; ++iScene) {
1362 G4Scene* pScene = sceneList [iScene];
1363 std::vector<G4Scene::Model>& modelList = pScene -> SetRunDurationModelList ();
1364 if (modelList.size ()) {
1367 modelInvalid =
false;
1368 std::vector<G4Scene::Model>::iterator iterModel;
1369 for (iterModel = modelList.begin();
1370 iterModel != modelList.end();
1376 G4warn <<
"WARNING: Model \""
1377 << iterModel->fpModel->GetGlobalDescription ()
1379 "\" is no longer valid - being removed\n from scene \""
1380 << pScene -> GetName () <<
"\""
1383 modelList.erase (iterModel);
1387 }
while (modelInvalid);
1389 if (modelList.size () == 0) {
1391 G4warn <<
"WARNING: No run-duration models left in this scene \""
1392 << pScene -> GetName ()
1398 G4warn <<
" Adding current world to \""
1399 << pScene -> GetName ()
1406 ApplyCommand (
G4String(
"/vis/scene/notifyHandlers " + pScene->
GetName()));
1412 ApplyCommand (
G4String(
"/vis/scene/notifyHandlers " + pScene->
GetName()));
1418 if (fpScene && fpScene -> GetRunDurationModelList ().size () == 0) {
1420 G4warn <<
"WARNING: The current scene \""
1421 << fpScene -> GetName ()
1422 <<
"\" has no run duration models."
1423 <<
"\n Use \"/vis/scene/add/volume\" or create a new scene."
1427 if (fpSceneHandler) {
1428 fpSceneHandler->ClearTransientStore();
1429 fpSceneHandler->ClearStore();
1431 fpViewer->NeedKernelVisit();
1432 fpViewer->SetView();
1433 fpViewer->ClearView();
1434 fpViewer->FinishView();
1443 G4cout <<
"G4VisManager::NotifyHandler() called." <<
G4endl;
1446 if (IsValidView()) {
1450 std::size_t iScene, nScenes = sceneList.size ();
1451 for (iScene = 0; iScene < nScenes; ++iScene) {
1452 G4Scene* pScene = sceneList [iScene];
1453 std::vector<G4Scene::Model>& modelList = pScene -> SetRunDurationModelList ();
1455 if (modelList.size ()) {
1458 ApplyCommand (
G4String(
"/vis/scene/notifyHandlers " + pScene->
GetName()));
1463 if (fpScene && fpScene -> GetRunDurationModelList ().size () == 0) {
1465 G4warn <<
"WARNING: The current scene \""
1466 << fpScene -> GetName ()
1467 <<
"\" has no run duration models."
1468 <<
"\n Use \"/vis/scene/add/volume\" or create a new scene."
1471 fpSceneHandler->ClearTransientStore();
1472 fpSceneHandler->ClearStore();
1473 fpViewer->NeedKernelVisit();
1474 fpViewer->SetView();
1475 fpViewer->ClearView();
1476 fpViewer->FinishView();
1483 return fpTrajFilterMgr->Accept(trajectory);
1488 return fpHitFilterMgr->Accept(hit);
1493 return fpDigiFilterMgr->Accept(digi);
1511 assert (0 != fpTrajDrawModelMgr);
1515 assert (0 != trajectoryModel);
1517 if (IsValidView()) {
1518 trajectoryModel->
Draw(trajectory, visible);
1526 fRunDurationUserVisActions.push_back(
UserVisAction(name,pVisAction));
1528 fUserVisActionExtents[pVisAction] = extent;
1532 "WARNING: No extent set for user vis action \"" << name <<
"\"."
1538 <<
"Run duration user vis action \"" << name <<
"\" registered"
1547 fEndOfEventUserVisActions.push_back(
UserVisAction(name,pVisAction));
1549 fUserVisActionExtents[pVisAction] = extent;
1553 "WARNING: No extent set for user vis action \"" << name <<
"\"."
1559 <<
"End of event user vis action \"" << name <<
"\" registered"
1568 fEndOfRunUserVisActions.push_back(
UserVisAction(name,pVisAction));
1570 fUserVisActionExtents[pVisAction] = extent;
1574 "WARNING: No extent set for user vis action \"" << name <<
"\"."
1580 <<
"End of run user vis action \"" << name <<
"\" registered"
1586 if (pScene != fpScene) {
1595 fpGraphicsSystem = pSystem;
1597 G4cout <<
"G4VisManager::SetCurrentGraphicsSystem: system now "
1598 << pSystem -> GetName () <<
G4endl;
1603 if (!(fpSceneHandler && fpSceneHandler -> GetGraphicsSystem () == pSystem)) {
1607 for (iSH = nSH - 1; iSH >= 0; iSH--) {
1608 if (sceneHandlerList [iSH] -> GetGraphicsSystem () == pSystem)
break;
1611 fpSceneHandler = sceneHandlerList [iSH];
1613 G4cout <<
" Scene Handler now "
1614 << fpSceneHandler -> GetName () <<
G4endl;
1616 if (fpScene != fpSceneHandler -> GetScene ()) {
1617 fpScene = fpSceneHandler -> GetScene ();
1619 G4cout <<
" Scene now \""
1620 << fpScene -> GetName () <<
"\"" <<
G4endl;
1623 const G4ViewerList& viewerList = fpSceneHandler -> GetViewerList ();
1624 if (viewerList.size ()) {
1625 fpViewer = viewerList [0];
1627 G4cout <<
" Viewer now " << fpViewer -> GetName () <<
G4endl;
1642 fpSceneHandler = pSceneHandler;
1644 G4cout <<
"G4VisManager::SetCurrentSceneHandler: scene handler now \""
1645 << pSceneHandler -> GetName () <<
"\"" <<
G4endl;
1647 if (fpScene != fpSceneHandler -> GetScene ()) {
1648 fpScene = fpSceneHandler -> GetScene ();
1650 G4cout <<
" Scene now \""
1651 << fpScene -> GetName () <<
"\"" <<
G4endl;
1654 if (fpGraphicsSystem != pSceneHandler -> GetGraphicsSystem ()) {
1655 fpGraphicsSystem = pSceneHandler -> GetGraphicsSystem ();
1657 G4cout <<
" Graphics system now \""
1658 << fpGraphicsSystem -> GetName () <<
"\"" <<
G4endl;
1661 const G4ViewerList& viewerList = fpSceneHandler -> GetViewerList ();
1662 std::size_t nViewers = viewerList.size ();
1664 std::size_t iViewer;
1665 for (iViewer = 0; iViewer < nViewers; ++iViewer) {
1666 if (fpViewer == viewerList [iViewer])
break;
1668 if (iViewer >= nViewers) {
1669 fpViewer = viewerList [0];
1671 G4cout <<
" Viewer now \"" << fpViewer -> GetName () <<
"\""
1675 if (!IsValidView ()) {
1678 "WARNING: Problem setting scene handler - please report circumstances."
1687 "WARNING: No viewers for this scene handler - please create one."
1695 if (fpViewer ==
nullptr) {
1697 G4cout <<
"G4VisManager::SetCurrentViewer: current viewer pointer zeroed "
1703 G4cout <<
"G4VisManager::SetCurrentViewer: viewer now "
1704 << pViewer -> GetName ()
1707 fpSceneHandler = fpViewer -> GetSceneHandler ();
1708 if (!fpSceneHandler) {
1711 "WARNING: No scene handler for this viewer - please create one."
1719 fpScene = fpSceneHandler -> GetScene ();
1720 fpGraphicsSystem = fpSceneHandler -> GetGraphicsSystem ();
1721 if (!IsValidView ()) {
1724 "WARNING: Problem setting viewer - please report circumstances."
1731(
Verbosity verbosity, std::ostream& out)
const
1733 out <<
"Registered graphics systems are:\n";
1734 if (fAvailableGraphicsSystems.size ()) {
1735 for (
const auto& gs: fAvailableGraphicsSystems) {
1736 const G4String& name = gs->GetName();
1737 const std::vector<G4String>& nicknames = gs->GetNicknames();
1740 out <<
" " << name <<
" (";
1741 for (std::size_t i = 0; i < nicknames.size(); ++i) {
1745 out << nicknames[i];
1755 "You may choose a graphics system (driver) with a parameter of"
1756 "\nthe command \"/vis/open\" or \"/vis/sceneHandler/create\","
1757 "\nor you may omit the driver parameter and choose at run time:"
1758 "\n- by argument in the construction of G4VisExecutive;"
1759 "\n- by environment variable \"G4VIS_DEFAULT_DRIVER\";"
1760 "\n- by entry in \"~/.g4session\";"
1761 "\n- by build flags."
1762 "\n- Note: This feature is not allowed in batch mode."
1763 "\nFor further information see \"examples/basic/B1/exampleB1.cc\""
1764 "\nand \"vis.mac\"."
1767 out <<
" NONE!!! None registered - yet! Mmmmm!" << std::endl;
1771void G4VisManager::PrintAvailableModels (Verbosity verbosity)
const
1776 const std::vector<G4VModelFactory<G4VTrajectoryModel>*>& factoryList =
1780 std::vector<G4VModelFactory<G4VTrajectoryModel>*>::const_iterator i;
1781 for (i = factoryList.begin(); i != factoryList.end(); ++i) {
1786 const G4VisListManager<G4VTrajectoryModel>* listManager =
1787 fpTrajDrawModelMgr->ListManager();
1788 const std::map<G4String, G4VTrajectoryModel*>& modelMap =
1792 std::map<G4String, G4VTrajectoryModel*>::const_iterator i;
1793 for (i = modelMap.begin(); i != modelMap.end(); ++i) {
1794 G4cout <<
" " << i->second->Name();
1795 if (i->second == listManager->
Current())
G4cout <<
" (Current)";
1807 const std::vector<G4VModelFactory<G4VFilter<G4VTrajectory> >*>&
1808 factoryList = fpTrajFilterMgr->FactoryList();
1811 std::vector<G4VModelFactory<G4VFilter<G4VTrajectory> >*>::const_iterator i;
1812 for (i = factoryList.begin(); i != factoryList.end(); ++i) {
1818 const std::vector<G4VFilter<G4VTrajectory>*>&
1819 filterList = fpTrajFilterMgr->FilterList();
1822 std::vector<G4VFilter<G4VTrajectory>*>::const_iterator i;
1823 for (i = filterList.begin(); i != filterList.end(); ++i) {
1831void G4VisManager::PrintAvailableUserVisActions (Verbosity)
const
1834 "You have successfully registered the following user vis actions."
1836 G4cout <<
"Run Duration User Vis Actions:";
1837 if (fRunDurationUserVisActions.empty())
G4cout <<
" none" <<
G4endl;
1840 for (std::size_t i = 0; i < fRunDurationUserVisActions.size(); ++i) {
1841 const G4String&
name = fRunDurationUserVisActions[i].fName;
1846 G4cout <<
"End of Event User Vis Actions:";
1847 if (fEndOfEventUserVisActions.empty())
G4cout <<
" none" <<
G4endl;
1850 for (std::size_t i = 0; i < fEndOfEventUserVisActions.size(); ++i) {
1851 const G4String&
name = fEndOfEventUserVisActions[i].fName;
1856 G4cout <<
"End of Run User Vis Actions:";
1857 if (fEndOfRunUserVisActions.empty())
G4cout <<
" none" <<
G4endl;
1860 for (std::size_t i = 0; i < fEndOfRunUserVisActions.size(); ++i) {
1861 const G4String&
name = fEndOfRunUserVisActions[i].fName;
1867void G4VisManager::PrintAvailableColours (Verbosity)
const {
1869 "Some /vis commands (optionally) take a string to specify colour."
1870 "\nThey are also available in your C++ code, e.g:"
1871 "\n G4Colour niceColour; // Default - white"
1872 "\n G4Colour::GetColour(\"pink\", niceColour);"
1873 "\n logical->SetVisAttributes(niceColour);"
1874 "\nSee G4Colour.hh."
1875 "\nAvailable colours";
1877 G4cout <<
", " << i.first;
1882void G4VisManager::PrintInvalidPointers ()
const {
1884 G4warn <<
"ERROR: G4VisManager::PrintInvalidPointers:";
1885 if (!fpGraphicsSystem) {
1886 G4warn <<
"\n null graphics system pointer.";
1889 G4warn <<
"\n Graphics system is " << fpGraphicsSystem -> GetName ()
1893 "\n Null scene pointer. Use \"/vis/drawVolume\" or"
1894 " \"/vis/scene/create\".";
1895 if (!fpSceneHandler)
1897 "\n Null scene handler pointer. Use \"/vis/open\" or"
1898 " \"/vis/sceneHandler/create\".";
1901 "\n Null viewer pointer. Use \"/vis/viewer/create\".";
1910#ifdef G4MULTITHREADED
1913 if (!pSceneHandler)
return 0;
1915 if (!pScene)
return 0;
1917 if (!pViewer)
return 0;
1934 std::size_t eventQueueSize = mtVisEventQueue.size();
1938 while (eventQueueSize) {
1941 const G4Event*
event = mtVisEventQueue.front();
1956 pVisManager->ClearTransientStoreIfMarked();
1960 ++pVisManager->fNoOfEventsDrawnThisRun;
1964 mtVisEventQueue.pop_front();
1965 pVisManager->EndOfEventCleanup(event);
1966 eventQueueSize = mtVisEventQueue.size();
1971 G4bool runInProgress = mtRunInProgress;
1973 if (!runInProgress) {
1980 std::this_thread::sleep_for(std::chrono::milliseconds(100));
1992void G4VisManager::BeginOfRun ()
1994 if (fIgnoreStateChanges)
return;
2000 isValidViewForRun = fpSceneHandler && IsValidView();
2001 if (!isValidViewForRun)
return;
2006 isFakeRun = (nEventsToBeProcessed == 0);
2007 if (isFakeRun)
return;
2011 isSubEventRunManagerType =
2015 fNKeepForPostProcessingRequests = 0;
2016 fNKeepTheEventRequests = 0;
2017 fEventKeepingSuspended =
false;
2018 fTransientsDrawnThisRun =
false;
2020 fNoOfEventsDrawnThisRun = 0;
2036 mtRunInProgress =
true;
2051void G4VisManager::BeginOfEvent ()
2053 if (fIgnoreStateChanges)
return;
2055 if (!isValidViewForRun)
return;
2056 if (isFakeRun)
return;
2060#ifndef G4MULTITHREADED
2062 fTransientsDrawnThisEvent =
false;
2063 if (fpSceneHandler) fpSceneHandler->SetTransientsDrawnThisEvent(
false);
2094void G4VisManager::EndOfEvent ()
2096 if (fIgnoreStateChanges)
return;
2098 if (!isValidViewForRun)
return;
2099 if (isFakeRun)
return;
2102 if (isSubEventRunManagerType)
return;
2109 if (!currentRun)
return;
2114 if (!currentEvent)
return;
2117 EndOfEventKernel(currentEvent);
2124 if (fIgnoreStateChanges)
return;
2126 if (!isValidViewForRun)
return;
2127 if (isFakeRun)
return;
2130 EndOfEventKernel(event);
2133void G4VisManager::EndOfEventKernel (
const G4Event* currentEvent)
2139 if (fDrawEventOnlyIfToBeKept) {
2147 std::size_t eventQueueSize = mtVisEventQueue.size();
2150 G4bool eventQueueFull =
false;
2151 while (fMaxEventQueueSize > 0 && (
G4int)eventQueueSize >= fMaxEventQueueSize) {
2153 if (fWaitOnEventQueueFull) {
2155 static G4bool warned =
false;
2158 "WARNING: The number of events in the visualisation queue has exceeded"
2160 << fMaxEventQueueSize <<
2161 ".\n If, during a multithreaded run, the simulation gets ahead of the"
2162 "\n visualisation by more than this maximum, the simulation is delayed"
2163 "\n until the vis sub-thread has drawn a few more events and removed them"
2164 "\n from the queue. You may change this maximum number of events with"
2165 "\n \"/vis/multithreading/maxEventQueueSize <N>\", where N is the maximum"
2166 "\n number you wish to allow. N <= 0 means \"unlimited\"."
2167 "\n Alternatively you may choose to discard events for drawing by setting"
2168 "\n \"/vis/multithreading/actionOnEventQueueFull discard\"."
2169 "\n To avoid visualisation altogether: \"/vis/disable\"."
2170 "\n And maybe \"/tracking/storeTrajectories 0\"."
2176 std::this_thread::sleep_for(std::chrono::milliseconds(100));
2180 static G4bool warned =
false;
2183 "WARNING: The number of events in the visualisation queue has exceeded"
2185 << fMaxEventQueueSize <<
2186 ".\n Some events have been discarded for drawing. You may change this"
2187 "\n behaviour with \"/vis/multithreading/actionOnEventQueueFull wait\"."
2188 "\n To avoid visualisation altogether: \"/vis/disable\"."
2189 "\n And maybe \"/tracking/storeTrajectories 0\"."
2194 eventQueueFull =
true;
2199 eventQueueSize = mtVisEventQueue.size();
2203 if (!eventQueueFull) {
2205 if (RequiredToBeKeptForVis(currentEvent->
GetEventID())) {
2207 fNKeepTheEventRequests++;
2215 fNKeepForPostProcessingRequests++;
2218 mtVisEventQueue.push_back(currentEvent);
2235 ClearTransientStoreIfMarked();
2239 fNKeepForPostProcessingRequests++;
2241 if (RequiredToBeKeptForVis(currentEvent->
GetEventID())) {
2243 fNKeepTheEventRequests++;
2247 fpSceneHandler->DrawEvent(currentEvent);
2248 ++fNoOfEventsDrawnThisRun;
2250 EndOfEventCleanup(currentEvent);
2254void G4VisManager::EndOfEventCleanup(
const G4Event* currentEvent)
2256 if (fpScene->GetRefreshAtEndOfEvent()) {
2258 fpSceneHandler->SetMarkForClearingTransientStore(
true);
2263 fpViewer->ShowView();
2269G4bool G4VisManager::RequiredToBeKeptForVis (
G4int eventID)
2272 G4bool requiredToBeKept =
false;
2277 if (fpScene->GetRefreshAtEndOfEvent()) {
2280 if (eventID == nEventsToBeProcessed - 1) {
2281 requiredToBeKept =
true;
2286 G4int maxNumberOfKeptEvents = fpScene->GetMaxNumberOfKeptEvents();
2288 if (maxNumberOfKeptEvents >= 0) {
2290 if (fNKeepTheEventRequests < maxNumberOfKeptEvents) {
2293 requiredToBeKept =
true;
2298 fEventKeepingSuspended =
true;
2299 static G4bool warned =
false;
2303 "WARNING: G4VisManager::EndOfEvent: Automatic event keeping suspended."
2305 if (maxNumberOfKeptEvents > 0) {
2307 "\n The number of events exceeds the maximum, "
2308 << maxNumberOfKeptEvents <<
2309 ", that may be kept by\n the vis manager."
2319 requiredToBeKept =
true;
2324 return requiredToBeKept;
2327void G4VisManager::EndOfRun ()
2329 if (fIgnoreStateChanges)
return;
2332 if (!isValidViewForRun)
return;
2333 if (isFakeRun)
return;
2339 if (nEventsToBeProcessed == 0)
return;
2342 if (!currentRun)
return;
2348 mtRunInProgress =
false;
2352 delete mtVisSubThread;
2353 fpViewer->SwitchToMasterThread();
2358 if (fNoOfEventsDrawnThisRun != noOfEventsRequested) {
2361 <<
"WARNING: Number of events drawn this run, "
2362 << fNoOfEventsDrawnThisRun <<
", is different to number requested, "
2363 << noOfEventsRequested <<
2364 ".\n (This is because you requested \"/vis/multithreading/actionOnEventQueueFull discard\".)"
2373 if (nKeptEvents == 1)
G4warn <<
" event has";
2374 else G4warn <<
" events have";
2375 G4warn <<
" been kept for refreshing and/or reviewing." <<
G4endl;
2376 if (nKeptEvents != fNKeepTheEventRequests) {
2377 if (fNKeepTheEventRequests == 0) {
2378 G4warn <<
"No keep requests were";
2379 }
else if (fNKeepTheEventRequests == 1) {
2380 G4warn <<
"1 keep request was";
2382 G4warn << fNKeepTheEventRequests <<
" keep requests were";
2384 G4warn <<
" made by the vis manager.";
2385 if (fNKeepTheEventRequests == 0) {
2387 "\n The kept events are those you have asked to be kept in your user action(s).";
2390 "\n The same or further events may have been kept by you in your user action(s)."
2391 "\n To turn off event keeping by the vis manager: /vis/drawOnlyToBeKeptEvents"
2392 "\n or use /vis/scene/endOfEventAction <refresh|accumulate> 0";
2397 " \"/vis/reviewKeptEvents\" to review one by one."
2398 "\n To see accumulated, \"/vis/enable\", then \"/vis/viewer/flush\" or \"/vis/viewer/rebuild\"."
2406 "WARNING: G4VisManager::EndOfRun: Automatic event keeping was suspended."
2408 if (fpScene->GetMaxNumberOfKeptEvents() > 0) {
2410 " The number of events in the run exceeded the maximum, "
2411 << fpScene->GetMaxNumberOfKeptEvents() <<
2412 ", that may be\n kept by the vis manager." <<
2413 "\n The number of events kept by the vis manager can be changed with"
2414 "\n \"/vis/scene/endOfEventAction accumulate <N>\", where N is the"
2415 "\n maximum number you wish to allow. N < 0 means \"unlimited\"."
2425 if (fpScene->GetRefreshAtEndOfRun()) {
2426 fpSceneHandler->DrawEndOfRunModels();
2429 if (fpViewer->GetViewParameters().IsAutoRefresh()) {
2430 fpViewer->RefreshView();
2435 fpViewer->ShowView();
2436 fpSceneHandler->SetMarkForClearingTransientStore(
true);
2438 if (fpGraphicsSystem->GetFunctionality() ==
2441 G4warn <<
"\"/vis/viewer/update\" to close file." <<
G4endl;
2446 fEventRefreshing =
false;
2449void G4VisManager::ClearTransientStoreIfMarked(){
2451 if (fpSceneHandler->GetMarkForClearingTransientStore()) {
2452 fpSceneHandler->SetMarkForClearingTransientStore(
false);
2453 fpSceneHandler->ClearTransientStore();
2459 fTransientsDrawnThisEvent = fpSceneHandler->GetTransientsDrawnThisEvent();
2460 fTransientsDrawnThisRun = fpSceneHandler->GetTransientsDrawnThisRun();
2465 fTransientsDrawnThisRun =
false;
2466 fTransientsDrawnThisEvent =
false;
2468 for (i = fAvailableSceneHandlers.begin();
2469 i != fAvailableSceneHandlers.end(); ++i) {
2470 (*i)->SetTransientsDrawnThisEvent(
false);
2471 (*i)->SetTransientsDrawnThisRun(
false);
2476 const G4String& viewerShortName = viewerName.substr(0, viewerName.find (
' '));
2477 return G4StrUtil::strip_copy(viewerShortName);
2482 std::size_t nHandlers = fAvailableSceneHandlers.size ();
2483 std::size_t iHandler, iViewer;
2486 for (iHandler = 0; iHandler < nHandlers; iHandler++) {
2488 const G4ViewerList& viewerList = sceneHandler -> GetViewerList ();
2489 for (iViewer = 0; iViewer < viewerList.size (); iViewer++) {
2490 viewer = viewerList [iViewer];
2491 if (viewerShortName == viewer -> GetShortName ()) {
2498 if (found)
return viewer;
2506 switch (verbosity) {
2507 case quiet: rs =
"quiet (0)";
break;
2508 case startup: rs =
"startup (1)";
break;
2509 case errors: rs =
"errors (2)";
break;
2510 case warnings: rs =
"warnings (3)";
break;
2512 case parameters: rs =
"parameters (5)";
break;
2513 case all: rs =
"all (6)";
break;
2520 os <<
"Available verbosity options:";
2530 G4String ss = G4StrUtil::to_lower_copy(verbosityString);
2532 if (ss[0] ==
'q') verbosity =
quiet;
2533 else if (ss[0] ==
's') verbosity =
startup;
2534 else if (ss[0] ==
'e') verbosity =
errors;
2535 else if (ss[0] ==
'w') verbosity =
warnings;
2537 else if (ss[0] ==
'p') verbosity =
parameters;
2538 else if (ss[0] ==
'a') verbosity =
all;
2542 std::istringstream is(ss);
2545 G4warn <<
"ERROR: G4VisManager::GetVerbosityValue: invalid verbosity \""
2546 << verbosityString <<
"\"\n";
2561 else if (intVerbosity >
all) verbosity =
all;
2562 else verbosity =
Verbosity(intVerbosity);
2578G4bool G4VisManager::IsValidView () {
2582 static G4bool noGSPrinting =
true;
2583 if (!fpGraphicsSystem) {
2587 noGSPrinting =
false;
2590 "WARNING: G4VisManager::IsValidView(): Attempt to draw when no graphics system"
2591 "\n has been instantiated. Use \"/vis/open\" or \"/vis/sceneHandler/create\"."
2592 "\n Alternatively, to avoid this message, suppress instantiation of vis"
2593 "\n manager (G4VisExecutive) and ensure drawing code is executed only if"
2594 "\n G4VVisManager::GetConcreteInstance() is non-zero."
2601 if ((!fpScene) || (!fpSceneHandler) || (!fpViewer)) {
2604 "ERROR: G4VisManager::IsValidView(): Current view is not valid."
2606 PrintInvalidPointers ();
2611 if (fpScene != fpSceneHandler -> GetScene ()) {
2613 G4warn <<
"ERROR: G4VisManager::IsValidView ():";
2614 if (fpSceneHandler -> GetScene ()) {
2616 "\n The current scene \""
2617 << fpScene -> GetName ()
2618 <<
"\" is not handled by"
2619 "\n the current scene handler \""
2620 << fpSceneHandler -> GetName ()
2622 "\n (it currently handles scene \""
2623 << fpSceneHandler -> GetScene () -> GetName ()
2626 "\n (a) attach it to the scene handler with"
2627 "\n /vis/sceneHandler/attach "
2628 << fpScene -> GetName ()
2630 "\n (b) create a new scene handler with "
2631 "\n /vis/sceneHandler/create <graphics-system>,"
2632 "\n in which case it should pick up the the new scene."
2636 G4warn <<
"\n Scene handler \""
2637 << fpSceneHandler -> GetName ()
2638 <<
"\" has null scene pointer."
2639 "\n Attach a scene with /vis/sceneHandler/attach [<scene-name>]"
2646 const G4ViewerList& viewerList = fpSceneHandler -> GetViewerList ();
2647 if (viewerList.size () == 0) {
2650 "ERROR: G4VisManager::IsValidView (): the current scene handler\n \""
2651 << fpSceneHandler -> GetName ()
2652 <<
"\" has no viewers. Do /vis/viewer/create."
2659 if (fpScene -> IsEmpty ()) {
2661 G4bool successful = fpScene -> AddWorldIfEmpty (warn);
2662 if (!successful || fpScene -> IsEmpty ()) {
2664 G4warn <<
"ERROR: G4VisManager::IsValidView ():";
2666 "\n Attempt at some drawing operation when scene is empty."
2667 "\n Maybe the geometry has not yet been defined."
2668 " Try /run/initialize."
2669 "\n Or use \"/vis/scene/add/extent\"."
2678 "WARNING: G4VisManager: the scene was empty, \"world\" has been"
2679 "\n added and the scene handlers notified.";
2691 G4warn<<
"G4VisManager: No model factories registered with G4VisManager."<<
G4endl;
2692 G4warn<<
"G4VisManager::RegisterModelFactories() should be overridden in derived"<<
G4endl;
2693 G4warn<<
"class. See G4VisExecutive for an example."<<
G4endl;
2700#ifdef G4MULTITHREADED
2707 fIgnoreStateChanges = val;
G4TemplateAutoLock< G4Mutex > G4AutoLock
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *description)
std::vector< G4VSceneHandler * >::const_iterator G4SceneHandlerListConstIterator
#define G4MUTEX_INITIALIZER
#define G4MUTEXLOCK(mutex)
#define G4THREADJOIN(worker)
void G4THREADCREATE(_Worker *&worker, _Func func, _Args... args)
#define G4MUTEXUNLOCK(mutex)
void * G4ThreadFunReturnType
void * G4ThreadFunArgType
#define TOOLS_COLORS_STAT(name, r, g, b)
G4VModelFactory< G4VFilter< G4VHit > > G4HitFilterFactory
G4VModelFactory< G4VTrajectoryModel > G4TrajDrawModelFactory
G4VModelFactory< G4VFilter< G4VTrajectory > > G4TrajFilterFactory
G4VModelFactory< G4VFilter< G4VDigi > > G4DigiFilterFactory
G4GLOB_DLL std::ostream G4cout
static void InitialiseColourMap()
static const std::map< G4String, G4Colour > & GetMap()
const G4Event * GetConstCurrentEvent()
static G4EventManager * GetEventManager()
void KeepTheEvent(G4bool vl=true) const
void PostProcessingFinished() const
G4bool KeepTheEventFlag() const
void KeepForPostProcessing() const
static pool_type * GetPool()
G4VSolid * GetSolid() const
void SetWorldVolume(G4VPhysicalVolume *pWorld)
void DescribeYourselfTo(G4VGraphicsScene &)
static G4RunManager * GetMasterRunManager()
static G4RunManagerKernel * GetMasterRunManagerKernel()
static G4RunManagerKernel * GetRunManagerKernel()
G4TrackingManager * GetTrackingManager() const
G4int GetNumberOfEventsToBeProcessed() const
static G4RunManager * GetRunManager()
RMType GetRunManagerType() const
const G4Run * GetCurrentRun() const
G4int GetNumberOfKeptEvents() const
G4bool AddRunDurationModel(G4VModel *, G4bool warn=false)
const G4String & GetName() const
static pool_type * GetPool()
void CreateAndUseWorkspace()
G4int GetStoreTrajectory() const
void SetCurrentTrajectory(const G4VTrajectory *pTraj)
void SetEventID(G4int eventID)
void SetRunID(G4int runID)
static G4TransportationManager * GetTransportationManager()
G4Navigator * GetNavigatorForTracking() const
void SetCoutDestination(G4UIsession *const value)
G4int ApplyCommand(const char *aCommand)
void SetUpForSpecialThread(const G4String &aPrefix)
static G4UImanager * GetUIpointer()
G4LogicalVolume * GetLogicalVolume() const
void SetTransientsDrawnThisRun(G4bool)
void DrawEvent(const G4Event *)
G4Scene * GetScene() const
void SetTransientsDrawnThisEvent(G4bool)
const G4Transform3D & GetObjectTransformation() const
virtual void DescribeYourselfTo(G4VGraphicsScene &scene) const =0
virtual void Draw(const G4VTrajectory &trajectory, const G4bool &visible=true) const =0
virtual void DoneWithMasterThread()
virtual void MovingToMasterThread()
virtual void SwitchToVisSubThread()
virtual void MovingToVisSubThread()
virtual void DoneWithVisSubThread()
static void SetVisManager(G4VisManager *pVisManager)
static G4VVisManager * GetConcreteInstance()
static void SetConcreteInstance(G4VVisManager *)
void SetXGeometryString(const G4String &)
G4bool IsCullingInvisible() const
G4bool IsCullingCovered() const
G4double GetExtentRadius() const
const std::map< G4String, T * > & Map() const
const T * Current() const
void SelectTrajectoryModel(const G4String &model)
void RegisterRunDurationUserVisAction(const G4String &name, G4VUserVisAction *, const G4VisExtent &=G4VisExtent())
G4String fDefaultXGeometryStringBasis
void Draw(const G4Circle &, const G4Transform3D &objectTransformation=G4Transform3D())
void SetCurrentGraphicsSystem(G4VGraphicsSystem *)
void Draw2D(const G4Circle &, const G4Transform3D &objectTransformation=G4Transform3D())
void PrintAvailableGraphicsSystems(Verbosity, std::ostream &=G4cout) const
virtual void RegisterGraphicsSystems()=0
void BeginDraw2D(const G4Transform3D &objectTransformation=G4Transform3D())
void CreateSceneHandler(const G4String &name="")
void SetCurrentSceneHandler(G4VSceneHandler *)
friend class G4VisCommandList
const G4VTrajectoryModel * CurrentTrajDrawModel() const
static Verbosity fVerbosity
G4bool FilterDigi(const G4VDigi &)
void SetTransientsDrawnThisEvent(G4bool)
void SetCurrentScene(G4Scene *)
static std::vector< G4String > VerbosityGuidanceStrings
static G4String VerbosityString(Verbosity)
void RegisterEndOfEventUserVisAction(const G4String &name, G4VUserVisAction *, const G4VisExtent &=G4VisExtent())
G4String ViewerShortName(const G4String &viewerName) const
G4String fDefaultGraphicsSystemBasis
void RegisterModel(G4VTrajectoryModel *model)
void RegisterMessenger(G4UImessenger *messenger)
void SetCurrentViewer(G4VViewer *)
G4String fDefaultXGeometryString
static void PrintAvailableVerbosity(std::ostream &os)
void RegisterModelFactory(G4TrajDrawModelFactory *factory)
G4bool FilterHit(const G4VHit &)
G4VViewer * GetCurrentViewer() const
G4bool RegisterGraphicsSystem(G4VGraphicsSystem *)
static G4ThreadFunReturnType G4VisSubThread(G4ThreadFunArgType)
virtual void RegisterModelFactories()
G4VSceneHandler * GetCurrentSceneHandler() const
static Verbosity GetVerbosity()
void RegisterMessengers()
void ResetTransientsDrawnFlags()
G4bool FilterTrajectory(const G4VTrajectory &)
G4String fDefaultGraphicsSystemName
virtual void SetUpForAThread()
void SetVerboseLevel(G4int)
void IgnoreStateChanges(G4bool)
friend class G4VisStateDependent
G4VisManager(const G4String &verbosityString="warnings")
void DrawGeometry(G4VPhysicalVolume *, const G4Transform3D &t=G4Transform3D())
static Verbosity GetVerbosityValue(const G4String &)
static G4VisManager * GetInstance()
void GeometryHasChanged()
const G4GraphicsSystemList & GetAvailableGraphicsSystems()
void RegisterEndOfRunUserVisAction(const G4String &name, G4VUserVisAction *, const G4VisExtent &=G4VisExtent())
virtual void EventReadyForVis(const G4Event *)
friend class G4VSceneHandler
void BeginDraw(const G4Transform3D &objectTransformation=G4Transform3D())
void CreateViewer(const G4String &name="", const G4String &XGeometry="")
void DispatchToModel(const G4VTrajectory &)
G4VViewer * GetViewer(const G4String &viewerName) const
const std::vector< Factory * > & FactoryList() const
const char * name(G4int ptype)
G4bool IsMultithreadedApplication()
void G4ConsumeParameters(_Args &&...)