63 fpCommand =
new G4UIcommand (
"/vis/viewer/addCutawayPlane",
this);
64 fpCommand -> SetGuidance
65 (
"Add cutaway plane to current viewer.");
68 parameter -> SetDefaultValue (0);
69 parameter -> SetGuidance (
"Coordinate of point on the plane.");
70 fpCommand->SetParameter(parameter);
72 parameter -> SetDefaultValue (0);
73 parameter -> SetGuidance (
"Coordinate of point on the plane.");
74 fpCommand->SetParameter(parameter);
76 parameter -> SetDefaultValue (0);
77 parameter -> SetGuidance (
"Coordinate of point on the plane.");
78 fpCommand->SetParameter(parameter);
80 parameter -> SetDefaultValue (
"m");
81 parameter -> SetGuidance (
"Unit of point on the plane.");
82 fpCommand->SetParameter(parameter);
84 parameter -> SetDefaultValue (1);
85 parameter -> SetGuidance (
"Component of plane normal.");
86 fpCommand->SetParameter(parameter);
88 parameter -> SetDefaultValue (0);
89 parameter -> SetGuidance (
"Component of plane normal.");
90 fpCommand->SetParameter(parameter);
92 parameter -> SetDefaultValue (0);
93 parameter -> SetGuidance (
"Component of plane normal.");
94 fpCommand->SetParameter(parameter);
113 "ERROR: No current viewer - \"/vis/viewer/list\" to see possibilities."
121 std::istringstream is (newValue);
122 is >> x >> y >> z >> unit >> nx >> ny >> nz;
124 x *= F; y *= F; z *= F;
130 G4cout <<
"Cutaway planes for viewer \"" << viewer->
GetName() <<
"\" now:";
132 for (std::size_t i = 0; i < cutaways.size(); ++i)
133 G4cout <<
"\n " << i <<
": " << cutaways[i];
144 fpCommandCentreAndZoomInOn =
new G4UIcommand (
"/vis/viewer/centreAndZoomInOn",
this);
145 fpCommandCentreAndZoomInOn->SetGuidance
146 (
"Centre and zoom in on the given physical volume.");
147 fpCommandCentreAndZoomInOn->SetGuidance
148 (
"The names of all volumes in all worlds are matched against pv-name. If"
149 "\ncopy-no is supplied, it matches the copy number too. If pv-name is of the"
150 "\nform \"/regexp/\", where regexp is a regular expression (see C++ regex),"
151 "\nthe match uses the usual rules of regular expression matching."
152 "\nOtherwise an exact match is required."
153 "\nFor example, \"/Shap/\" matches \"Shape1\" and \"Shape2\".");
154 fpCommandCentreAndZoomInOn->SetGuidance
155 (
"It may help to see a textual representation of the geometry hierarchy of"
156 "\nthe worlds. Try \"/vis/drawTree [worlds]\" or one of the driver/browser"
157 "\ncombinations that have the required functionality, e.g., HepRepFile.");
158 fpCommandCentreAndZoomInOn->SetGuidance
159 (
"If there are more than one matching physical volumes they will all be"
160 "\nincluded. If this is not what you want, and what you want is to centre on a"
161 "\nparticular touchable, then select the touchable (\"/vis/set/touchable\") and"
162 "\nuse \"/vis/touchable/centreOn\". (You may need \"/vis/touchable/findPath\".)");
164 parameter =
new G4UIparameter(
"pv-name",
's',omitable =
false);
166 fpCommandCentreAndZoomInOn->SetParameter(parameter);
167 parameter =
new G4UIparameter(
"copy-no",
'i',omitable =
true);
169 parameter->
SetGuidance (
"Copy number. -1 means any or all copy numbers");
170 fpCommandCentreAndZoomInOn->SetParameter(parameter);
172 fpCommandCentreOn =
new G4UIcommand (
"/vis/viewer/centreOn",
this);
173 fpCommandCentreOn->SetGuidance (
"Centre the view on the given physical volume.");
181 delete fpCommandCentreAndZoomInOn;
182 delete fpCommandCentreOn;
195 if (!currentViewer) {
198 "ERROR: No current viewer - \"/vis/viewer/list\" to see possibilities."
206 std::istringstream is (newValue);
207 is >> pvName >> copyNo;
212 std::size_t nWorlds = transportationManager->
GetNoWorlds();
213 std::vector<G4PhysicalVolumesSearchScene::Findings> findingsVector;
214 std::vector<G4VPhysicalVolume*>::iterator iterWorld =
216 for (std::size_t i = 0; i < nWorlds; ++i, ++iterWorld) {
223 for (
const auto& findings: searchScene.
GetFindings()) {
224 findingsVector.push_back(findings);
228 if (findingsVector.empty()) {
231 <<
"WARNING: Volume \"" << pvName <<
"\" ";
233 G4warn <<
"copy number " << copyNo;
241 std::vector<std::vector<G4PhysicalVolumeModel::G4PhysicalVolumeNodeID>> foundPaths;
244 G4Scene tempScene(
"Centre Scene");
245 G4bool successfullyAdded =
true;
246 for (
const auto& findings: findingsVector) {
248 findings.fpFoundPV->SetCopyNo(findings.fFoundPVCopyNo);
255 findings.fFoundObjectTransformation,
258 findings.fFoundBasePVPath);
262 successfullyAdded =
false;
266 G4cout <<
"\"" << findings.fpFoundPV->GetName()
267 <<
"\", copy no. " << findings.fFoundPVCopyNo
268 <<
",\n found in searched volume \""
269 << findings.fpSearchPV->GetName()
270 <<
"\" at depth " << findings.fFoundDepth
271 <<
",\n base path: \"" << findings.fFoundBasePVPath
272 <<
",\n has been added to temporary scene \"" << tempScene.
GetName() <<
"\"."
275 foundPaths.push_back(findings.fFoundFullPVPath);
279 delete sceneModel.fpModel;
281 if (!successfullyAdded)
return;
290 if (command == fpCommandCentreAndZoomInOn) {
307 Twinkle(currentViewer,newVP,foundPaths);
313 <<
"Viewer \"" << currentViewer->
GetName()
315 if (fpCommandCentreAndZoomInOn) {
316 G4cout <<
"and zoomed in";
318 G4cout <<
" on physical volume(s) \"" << pvName <<
'\"'
329 fpCommand =
new G4UIcommand (
"/vis/viewer/changeCutawayPlane",
this);
330 fpCommand -> SetGuidance(
"Change cutaway plane.");
333 parameter -> SetGuidance (
"Index of plane: 0, 1, 2.");
334 fpCommand->SetParameter(parameter);
336 parameter -> SetDefaultValue (0);
337 parameter -> SetGuidance (
"Coordinate of point on the plane.");
338 fpCommand->SetParameter(parameter);
340 parameter -> SetDefaultValue (0);
341 parameter -> SetGuidance (
"Coordinate of point on the plane.");
342 fpCommand->SetParameter(parameter);
344 parameter -> SetDefaultValue (0);
345 parameter -> SetGuidance (
"Coordinate of point on the plane.");
346 fpCommand->SetParameter(parameter);
348 parameter -> SetDefaultValue (
"m");
349 parameter -> SetGuidance (
"Unit of point on the plane.");
350 fpCommand->SetParameter(parameter);
352 parameter -> SetDefaultValue (1);
353 parameter -> SetGuidance (
"Component of plane normal.");
354 fpCommand->SetParameter(parameter);
356 parameter -> SetDefaultValue (0);
357 parameter -> SetGuidance (
"Component of plane normal.");
358 fpCommand->SetParameter(parameter);
360 parameter -> SetDefaultValue (0);
361 parameter -> SetGuidance (
"Component of plane normal.");
362 fpCommand->SetParameter(parameter);
381 "ERROR: No current viewer - \"/vis/viewer/list\" to see possibilities."
390 std::istringstream is (newValue);
391 is >> index >> x >> y >> z >> unit >> nx >> ny >> nz;
393 x *= F; y *= F; z *= F;
400 G4cout <<
"Cutaway planes for viewer \"" << viewer->
GetName() <<
"\" now:";
402 for (std::size_t i = 0; i < cutaways.size(); ++i)
403 G4cout <<
"\n " << i <<
": " << cutaways[i];
413 G4bool omitable, currentAsDefault;
415 fpCommand -> SetGuidance (
"Clears viewer.");
416 fpCommand -> SetGuidance
417 (
"By default, clears current viewer. Specified viewer becomes current."
418 "\n\"/vis/viewer/list\" to see possible viewer names.");
419 fpCommand -> SetParameterName (
"viewer-name",
421 currentAsDefault =
true);
430 return viewer ? viewer -> GetName () :
G4String(
"none");
441 G4warn <<
"ERROR: Viewer \"" << clearName
442 <<
"\" not found - \"/vis/viewer/list\" to see possibilities."
452 G4cout <<
"Viewer \"" << clearName <<
"\" cleared." <<
G4endl;
461 (
"/vis/viewer/clearCutawayPlanes",
this);
462 fpCommand -> SetGuidance (
"Clear cutaway planes of current viewer.");
481 "ERROR: No current viewer - \"/vis/viewer/list\" to see possibilities."
490 G4cout <<
"Cutaway planes for viewer \"" << viewer->
GetName()
491 <<
"\" now cleared." <<
G4endl;
500 G4bool omitable, currentAsDefault;
502 fpCommand -> SetGuidance (
"Clears transients from viewer.");
503 fpCommand -> SetGuidance
504 (
"By default, operates on current viewer. Specified viewer becomes current."
505 "\n\"/vis/viewer/list\" to see possible viewer names.");
506 fpCommand -> SetParameterName (
"viewer-name",
508 currentAsDefault =
true);
517 return viewer ? viewer -> GetName () :
G4String(
"none");
528 G4warn <<
"ERROR: Viewer \"" << clearName
529 <<
"\" not found - \"/vis/viewer/list\" to see possibilities."
540 G4cout <<
"Viewer \"" << clearName <<
"\" cleared of transients."
550 (
"/vis/viewer/clearVisAttributesModifiers",
this);
551 fpCommand -> SetGuidance (
"Clear vis attribute modifiers of current viewer.");
552 fpCommand -> SetGuidance (
"(These are used for touchables, etc.)");
571 "ERROR: No current viewer - \"/vis/viewer/list\" to see possibilities."
580 G4cout <<
"Vis attributes modifiers for viewer \"" << viewer->
GetName()
581 <<
"\" now cleared." <<
G4endl;
591 fpCommand =
new G4UIcommand (
"/vis/viewer/clone",
this);
592 fpCommand -> SetGuidance (
"Clones viewer.");
593 fpCommand -> SetGuidance
594 (
"By default, clones current viewer. Clone becomes current."
595 "\nClone name, if not provided, is derived from the original name."
596 "\n\"/vis/viewer/list\" to see possible viewer names.");
598 parameter =
new G4UIparameter (
"original-viewer-name",
's', omitable =
true);
599 parameter -> SetCurrentAsDefault (
true);
600 fpCommand -> SetParameter (parameter);
601 parameter =
new G4UIparameter (
"clone-name",
's', omitable =
true);
602 parameter -> SetDefaultValue (
"none");
603 fpCommand -> SetParameter (parameter);
613 return "\"" + originalName +
"\"";
621 std::istringstream is (newValue);
626 while (is.get(c) && c ==
' '){}
628 while (is.get(c) && c !=
'"') {originalName += c;}
632 while (is.get(c) && c !=
' ') {originalName += c;}
634 G4StrUtil::strip(originalName,
' ');
635 G4StrUtil::strip(originalName,
'"');
638 if (!originalViewer) {
640 G4warn <<
"ERROR: Viewer \"" << originalName
641 <<
"\" not found - \"/vis/viewer/list\" to see possibilities."
646 originalName = originalViewer->
GetName();
648 while (is.get(c) && c ==
' '){}
650 while (is.get(c) && c !=
'"') {cloneName += c;}
654 while (is.get(c) && c !=
' ') {cloneName += c;}
656 G4StrUtil::strip(cloneName,
' ');
657 G4StrUtil::strip(cloneName,
'"');
659 G4bool errorWhileNaming =
false;
660 if (cloneName ==
"none") {
663 cloneName = originalName;
664 std::ostringstream oss;
665 oss <<
'-' << subID++;
666 G4String::size_type lastDashPosition, nextSpacePosition;
667 if ((lastDashPosition = cloneName.rfind(
'-')) != G4String::npos &&
668 (nextSpacePosition = cloneName.find(
" ", lastDashPosition)) !=
670 cloneName.insert(nextSpacePosition, oss.str());
672 G4String::size_type spacePosition = cloneName.find(
' ');
673 if (spacePosition != G4String::npos)
674 cloneName.insert(spacePosition, oss.str());
676 errorWhileNaming =
true;
678 }
while (!errorWhileNaming &&
fpVisManager -> GetViewer (cloneName));
681 if (errorWhileNaming) {
683 G4warn <<
"ERROR: While naming clone viewer \"" << cloneName
692 G4warn <<
"ERROR: Putative clone viewer \"" << cloneName
693 <<
"\" already exists."
705 (
G4String(
"/vis/viewer/create ! \"" + cloneName +
"\" " + windowSizeHint));
709 G4cout <<
"Viewer \"" << originalName <<
"\" cloned." <<
G4endl;
710 G4cout <<
"Clone \"" << cloneName <<
"\" now current." <<
G4endl;
718 fpCommand =
new G4UIcommand (
"/vis/viewer/colourByDensity",
this);
719 fpCommand -> SetGuidance
720 (
"If a volume has no vis attributes, colour it by density.");
721 fpCommand -> SetGuidance
722 (
"Provide algorithm number, e.g., \"1\" (or \"0\" to switch off)."
723 "\nThen a unit of density, e.g., \"g/cm3\"."
724 "\nThen parameters for the algorithm assumed to be densities in that unit.");
725 fpCommand -> SetGuidance
726 (
"Algorithm 1: Simple algorithm takes 3 parameters: d0, d1 and d2."
727 "\n Volumes with density < d0 are invisible."
728 "\n Volumes with d0 <= density < d1 have colour on range red->green."
729 "\n Volumes with d1 <= density < d2 have colour on range green->blue."
730 "\n Volumes with density > d2 are blue.");
733 parameter -> SetGuidance (
"Algorithm number (or \"0\" to switch off).");
734 parameter -> SetDefaultValue (1);
735 fpCommand->SetParameter(parameter);
737 parameter -> SetGuidance (
"Unit of following densities, e.g., \"g/cm3\".");
738 parameter -> SetDefaultValue (
"g/cm3");
739 fpCommand->SetParameter(parameter);
741 parameter -> SetGuidance (
"Density parameter 0");
742 parameter -> SetDefaultValue (0.5);
743 fpCommand->SetParameter(parameter);
745 parameter -> SetGuidance (
"Density parameter 1");
746 parameter -> SetDefaultValue (3.0);
747 fpCommand->SetParameter(parameter);
749 parameter -> SetGuidance (
"Density parameter 2.");
750 parameter -> SetDefaultValue (10.0);
751 fpCommand->SetParameter(parameter);
770 "ERROR: No current viewer - \"/vis/viewer/list\" to see possibilities."
777 G4int algorithmNumber;
780 std::istringstream is (newValue);
781 is >> algorithmNumber >> unit >> d0 >> d1 >> d2;
783 if (algorithmNumber < 0 || algorithmNumber > 1) {
786 "ERROR: Unrecognised algorithm number: " << algorithmNumber
792 std::vector<G4double> parameters;
793 if (algorithmNumber > 0) {
794 const G4String where =
"G4VisCommandViewerColourByDensity::SetNewValue";
799 d0 *= valueOfUnit; d1 *= valueOfUnit; d2 *= valueOfUnit;
803 "ERROR: Unrecognised or inappropriate unit: " << unit
808 parameters.push_back(d0);
809 parameters.push_back(d1);
810 parameters.push_back(d2);
820 <<
" selected for viewer \"" << viewer->
GetName()
837 fpCommand -> SetGuidance
838 (
"Copy the camera-specific parameters from the specified viewer.");
839 fpCommand -> SetGuidance
840 (
"Note: To copy ALL view parameters, including scene modifications,"
841 "\nuse \"/vis/viewer/set/all\"");
842 fpCommand -> SetParameterName (
"from-viewer-name", omitable =
false);
858 if (!currentViewer) {
861 "ERROR: G4VisCommandsViewerCopyViewFrom::SetNewValue: no current viewer."
867 const G4String& fromViewerName = newValue;
871 G4warn <<
"ERROR: Viewer \"" << fromViewerName
872 <<
"\" not found - \"/vis/viewer/list\" to see possibilities."
878 if (fromViewer == currentViewer) {
881 "WARNING: G4VisCommandsViewerSet::SetNewValue:"
882 "\n from-viewer and current viewer are identical."
894 G4cout <<
"Camera parameters of viewer \"" << currentViewer->
GetName()
895 <<
"\"\n set to those of viewer \"" << fromViewer->
GetName()
905 fpCommand =
new G4UIcommand (
"/vis/viewer/create",
this);
906 fpCommand -> SetGuidance
907 (
"Creates a viewer. If the scene handler name is specified, then a"
908 "\nviewer of that scene handler is created. Otherwise, a viewer"
909 "\nof the current scene handler is created.");
910 fpCommand -> SetGuidance
911 (
"If the viewer name is not specified a name is generated from the name"
912 "\nof the scene handler and a serial number.");
913 fpCommand -> SetGuidance(
"The scene handler and viewer become current.");
914 fpCommand -> SetGuidance
915 (
"(Note: the system adds the graphics system name to the viewer name"
916 "\nfor identification, but for selecting, copying, etc., only characters"
917 "\nup to the first blank are used. For example, if the viewer name is"
918 "\n\"viewer-0 (G4OpenGLStoredQt)\", it may be referenced by \"viewer-0\","
919 "\nfor example in \"/vis/viewer/select viewer-0\".)");
920 fpCommand -> SetGuidance
921 (
"Window size and placement hints, e.g. 600x600-100+100 (in pixels):");
922 fpCommand -> SetGuidance
923 (
"- single number, e.g., \"600\": square window;");
924 fpCommand -> SetGuidance
925 (
"- two numbers, e.g., \"800x600\": rectangluar window;");
926 fpCommand -> SetGuidance
927 (
"- two numbers plus placement hint, e.g., \"600x600-100+100\" places window of size"
928 "\n 600x600 100 pixels left and 100 pixels down from top right corner.");
929 fpCommand -> SetGuidance
930 (
"- If not specified, the default is \"600\", i.e., 600 pixels square, placed"
931 "\n at the window manager's discretion...or picked up from the previous viewer.");
932 fpCommand -> SetGuidance
933 (
"- This is an X-Windows-type geometry string, see:"
934 "\n https://en.wikibooks.org/wiki/Guide_to_X11/Starting_Programs,"
935 "\n \"Specifying window geometry\".");
937 parameter =
new G4UIparameter (
"scene-handler",
's', omitable =
true);
938 parameter -> SetCurrentAsDefault (
true);
939 fpCommand -> SetParameter (parameter);
940 parameter =
new G4UIparameter (
"viewer-name",
's', omitable =
true);
941 parameter -> SetCurrentAsDefault (
true);
942 fpCommand -> SetParameter (parameter);
943 parameter =
new G4UIparameter (
"window-size-hint",
's', omitable =
true);
944 parameter -> SetCurrentAsDefault (
true);
945 fpCommand -> SetParameter (parameter);
952G4String G4VisCommandViewerCreate::NextName () {
953 std::ostringstream oss;
955 oss <<
"viewer-" << fId <<
" (";
957 oss << sceneHandler -> GetGraphicsSystem () -> GetName ();
960 oss <<
"no_scene_handlers";
969 auto currentSceneHandler =
fpVisManager->GetCurrentSceneHandler();
970 if (currentSceneHandler) {
971 sceneHandlerName = currentSceneHandler->GetName();
974 sceneHandlerName =
"none";
978 const auto& viewerName = NextName();
984 windowSizeHint = currentViewer->GetViewParameters().GetXGeometryString();
987 windowSizeHint =
fpVisManager->GetDefaultXGeometryString();
991 return sceneHandlerName +
" \"" + viewerName +
"\" " + windowSizeHint;
1000 std::istringstream is (newValue);
1001 is >> sceneHandlerName;
1006 while (is.get(c) && c ==
' '){}
1008 while (is.get(c) && c !=
'"') {newName += c;}
1012 while (is.get(c) && c !=
' ') {newName += c;}
1014 G4StrUtil::strip(newName,
' ');
1015 G4StrUtil::strip(newName,
'"');
1018 is >> windowSizeHintString;
1022 std::size_t nHandlers = sceneHandlerList.size ();
1023 if (nHandlers == 0) {
1026 "ERROR: G4VisCommandViewerCreate::SetNewValue: no scene handlers."
1027 "\n Create a scene handler with \"/vis/sceneHandler/create\"";
1032 std::size_t iHandler;
1033 for (iHandler = 0; iHandler < nHandlers; ++iHandler) {
1034 if (sceneHandlerList [iHandler] -> GetName () == sceneHandlerName)
break;
1037 if (iHandler >= nHandlers) {
1042 "G4VisCommandViewerCreate::SetNewValue: invalid scene handler specified.";
1050 if (sceneHandler !=
fpVisManager -> GetCurrentSceneHandler ()) {
1056 if (newName ==
"") {
1059 if (newName == nextName) fId++;
1062 for (std::size_t ih = 0; ih < nHandlers; ++ih) {
1064 const G4ViewerList& viewerList = sh -> GetViewerList ();
1065 for (std::size_t iViewer = 0; iViewer < viewerList.size (); iViewer++) {
1066 if (viewerList [iViewer] -> GetShortName () == newShortName ) {
1069 "ERROR: Viewer \"" << newShortName <<
"\" already exists.";
1078 windowSizeHintString =
fExistingVP.GetXGeometryString();
1081 fpVisManager -> CreateViewer (newName,windowSizeHintString);
1086 if (newViewer && newViewer -> GetName () == newName) {
1100 G4cout <<
"New viewer \"" << newName <<
"\" created." <<
G4endl;
1110 ed <<
"ERROR: New viewer doesn\'t match!!! Curious!!";
1112 ed <<
"WARNING: No viewer created.";
1124 G4warn <<
"Issue /vis/viewer/refresh or flush to see effect."
1134 fDollyIncrement (0.),
1137 G4bool omitable, currentAsDefault;
1140 (
"/vis/viewer/dolly",
this);
1141 fpCommandDolly -> SetGuidance
1142 (
"Incremental dolly.");
1143 fpCommandDolly -> SetGuidance
1144 (
"Moves the camera incrementally towards target point.");
1145 fpCommandDolly -> SetParameterName(
"increment",
1147 currentAsDefault=
true);
1148 fpCommandDolly -> SetDefaultUnit(
"m");
1151 (
"/vis/viewer/dollyTo",
this);
1152 fpCommandDollyTo -> SetGuidance
1153 (
"Dolly to specific coordinate.");
1154 fpCommandDollyTo -> SetGuidance
1155 (
"Places the camera towards target point relative to standard camera point.");
1156 fpCommandDollyTo -> SetParameterName(
"distance",
1158 currentAsDefault=
true);
1159 fpCommandDollyTo -> SetDefaultUnit(
"m");
1163 delete fpCommandDolly;
1164 delete fpCommandDollyTo;
1169 if (command == fpCommandDolly) {
1170 currentValue = fpCommandDolly->ConvertToString(fDollyIncrement,
"m");
1172 else if (command == fpCommandDollyTo) {
1173 currentValue = fpCommandDollyTo->ConvertToString(fDollyTo,
"m");
1175 return currentValue;
1185 if (!currentViewer) {
1188 "ERROR: G4VisCommandsViewerDolly::SetNewValue: no current viewer."
1196 if (command == fpCommandDolly) {
1197 fDollyIncrement = fpCommandDolly->GetNewDoubleValue(newValue);
1200 else if (command == fpCommandDollyTo) {
1201 fDollyTo = fpCommandDolly->GetNewDoubleValue(newValue);
1215 G4bool omitable, currentAsDefault;
1217 fpCommand -> SetGuidance
1218 (
"Compound command: \"/vis/viewer/refresh\" + \"/vis/viewer/update\".");
1219 fpCommand -> SetGuidance
1220 (
"Useful for refreshing and initiating post-processing for graphics"
1221 "\nsystems which need post-processing. By default, acts on current"
1222 "\nviewer. \"/vis/viewer/list\" to see possible viewers. Viewer"
1223 "\nbecomes current.");
1224 fpCommand -> SetParameterName (
"viewer-name",
1226 currentAsDefault =
true);
1236 return viewer ? viewer -> GetName () :
G4String(
"none");
1247 G4warn <<
"ERROR: Viewer \"" << flushName <<
"\"" <<
1248 " not found - \"/vis/viewer/list\"\n to see possibilities."
1258 G4cout <<
"Viewer \"" << viewer -> GetName () <<
"\""
1259 <<
" flushed." <<
G4endl;
1267 fpCommand =
new G4UIcommand (
"/vis/viewer/interpolate",
this);
1268 fpCommand -> SetGuidance
1269 (
"Interpolate views defined by the first argument, which can contain "
1270 "Unix-shell-style pattern matching characters such as '*', '?' and '[' "
1271 "- see \"man sh\" and look for \"Pattern Matching\". The contents "
1272 "of each file are assumed to be \"/vis/viewer\" commands "
1273 "that specify a particular view. The files are processed in alphanumeric "
1274 "order of filename. The files may be written by hand or produced by the "
1275 "\"/vis/viewer/save\" command.");
1276 fpCommand -> SetGuidance
1277 (
"The default is to search the working directory for files with a .g4view "
1278 "extension. Another procedure is to assemble view files in a subdirectory, "
1279 "e.g., \"myviews\"; then they can be interpolated with\n"
1280 "\"/vis/viewer/interpolate myviews\".");
1281 fpCommand -> SetGuidance
1282 (
"To export interpolated views to file for a future possible movie, "
1283 "write \"export\" as 5th parameter (OpenGL only).");
1285 parameter =
new G4UIparameter(
"pattern",
's', omitable =
true);
1286 parameter -> SetGuidance(
"Pattern that defines the view files.");
1287 parameter -> SetDefaultValue(
"*.g4view");
1288 fpCommand -> SetParameter(parameter);
1289 parameter =
new G4UIparameter(
"no-of-points",
'i', omitable =
true);
1290 parameter -> SetGuidance (
"Number of interpolation points per interval.");
1291 parameter -> SetDefaultValue(50);
1292 fpCommand -> SetParameter(parameter);
1293 parameter =
new G4UIparameter(
"wait-time",
's', omitable =
true);
1294 parameter -> SetGuidance(
"Wait time per interpolated point");
1295 parameter -> SetDefaultValue(
"20.");
1296 fpCommand -> SetParameter(parameter);
1297 parameter =
new G4UIparameter(
"time-unit",
's', omitable =
true);
1298 parameter -> SetDefaultValue(
"millisecond");
1299 fpCommand -> SetParameter (parameter);
1300 parameter =
new G4UIparameter(
"export",
's', omitable =
true);
1301 parameter -> SetDefaultValue(
"no");
1302 fpCommand -> SetParameter (parameter);
1318 if (!currentViewer) {
1321 "ERROR: G4VisCommandViewerInterpolate::SetNewValue: no current viewer."
1328 G4int nInterpolationPoints;
1333 std::istringstream iss (newValue);
1336 >> nInterpolationPoints
1337 >> waitTimePerPointString
1340 G4String waitTimePerPointDimString(waitTimePerPointString +
' ' + timeUnit);
1343 G4int waitTimePerPointmilliseconds = waitTimePerPoint/millisecond;
1344 if (waitTimePerPointmilliseconds < 0) waitTimePerPointmilliseconds = 0;
1365 const G4int safety = 99;
1366 G4int safetyCount = 0;
1367 G4fs::path pathPattern = pattern.c_str();
1371 (pathPattern.parent_path().string().length() ?
1372 pathPattern.parent_path().string() :
1374 G4fs::path parentPath = parentPathString.c_str();
1377 std::set<G4fs::path> paths;
1379 if (G4fs::is_directory(pathPattern)) {
1382 for (
const auto& path: G4fs::directory_iterator(pathPattern)) {
1383 if (safetyCount++ >= safety)
break;
1393 for (
G4int i = 0; i < (
G4int)pattern.length(); ++i) {
1394 if (pattern[i] ==
'.') {
1395 regexp_pattern +=
"\\.";
1396 }
else if (pattern[i] ==
'*') {
1397 regexp_pattern +=
".*";
1398 }
else if (pattern[i] ==
'?') {
1399 regexp_pattern +=
"(.{1,1})";
1401 regexp_pattern += pattern[i];
1404 std::regex regexp(regexp_pattern, std::regex_constants::basic | std::regex_constants::icase);
1406 for (
const auto& path: G4fs::directory_iterator(parentPath)) {
1407 const auto& pathname = path.path().relative_path().string();
1408 if (std::regex_match(pathname, regexp)) {
1409 if (safetyCount++ >= safety)
break;
1415 if (safetyCount > safety) {
1418 "/vis/viewer/interpolate:"
1419 "\n the number of way points has been limited to the maximum currently allowed: "
1425 std::vector<G4ViewParameters> viewVector;
1426 for (
const auto& path: paths) {
1427 uiManager->
ApplyCommand(
"/control/execute " + path.relative_path().string());
1431 viewVector.push_back(vp);
1435 (currentViewer,viewVector,
1436 nInterpolationPoints,waitTimePerPointmilliseconds,exportString);
1446 G4cout <<
"Viewer \"" << currentViewer -> GetName () <<
"\""
1447 <<
" restored." <<
G4endl;
1455 fpCommand =
new G4UIcommand (
"/vis/viewer/list",
this);
1456 fpCommand -> SetGuidance (
"Lists viewers(s).");
1457 fpCommand -> SetGuidance
1458 (
"See \"/vis/verbose\" for definition of verbosity.");
1462 parameter -> SetDefaultValue (
"all");
1463 fpCommand -> SetParameter (parameter);
1466 parameter -> SetDefaultValue (
"warnings");
1467 fpCommand -> SetParameter (parameter);
1480 std::istringstream is (newValue);
1481 is >> name >> verbosityString;
1488 if (currentViewer) {
1489 currentViewerShortName = currentViewer -> GetShortName ();
1492 currentViewerShortName =
"none";
1497 std::size_t nHandlers = sceneHandlerList.size ();
1499 G4bool foundCurrent =
false;
1500 for (std::size_t iHandler = 0; iHandler < nHandlers; ++iHandler) {
1502 const G4ViewerList& viewerList = sceneHandler -> GetViewerList ();
1504 <<
"Scene handler \"" << sceneHandler -> GetName () <<
"\" ("
1506 const G4Scene* pScene = sceneHandler -> GetScene ();
1508 G4cout <<
", scene \"" << pScene -> GetName () <<
"\"";
1511 std::size_t nViewers = viewerList.size ();
1512 if (nViewers == 0) {
1513 G4cout <<
"\n No viewers for this scene handler." <<
G4endl;
1516 for (std::size_t iViewer = 0; iViewer < nViewers; ++iViewer) {
1517 const G4VViewer* thisViewer = viewerList [iViewer];
1518 G4String thisName = thisViewer -> GetName ();
1519 G4String thisShortName = thisViewer -> GetShortName ();
1520 if (name !=
"all") {
1521 if (thisShortName != shortName)
continue;
1525 if (thisShortName == currentViewerShortName) {
1526 foundCurrent =
true;
1532 G4cout <<
" viewer \"" << thisName <<
"\"";
1534 G4cout <<
"\n " << *thisViewer;
1541 if (!foundCurrent) {
1542 G4cout <<
"No valid current viewer - please create or select one."
1548 if (name !=
"all") {
1549 G4cout <<
" of name \"" << name <<
"\"";
1558 fPanIncrementRight (0.),
1559 fPanIncrementUp (0.),
1566 (
"/vis/viewer/pan",
this);
1567 fpCommandPan -> SetGuidance
1568 (
"Incremental pan.");
1569 fpCommandPan -> SetGuidance
1570 (
"Moves the camera incrementally right and up by these amounts (as seen"
1571 "\nfrom viewpoint direction).");
1573 parameter =
new G4UIparameter(
"right-increment",
'd', omitable =
true);
1574 parameter -> SetCurrentAsDefault (
true);
1575 fpCommandPan -> SetParameter (parameter);
1576 parameter =
new G4UIparameter(
"up-increment",
'd', omitable =
true);
1577 parameter -> SetCurrentAsDefault (
true);
1578 fpCommandPan -> SetParameter (parameter);
1579 parameter =
new G4UIparameter (
"unit",
's', omitable =
true);
1580 parameter -> SetDefaultValue (
"m");
1581 fpCommandPan -> SetParameter (parameter);
1584 (
"/vis/viewer/panTo",
this);
1585 fpCommandPanTo -> SetGuidance
1586 (
"Pan to specific coordinate.");
1587 fpCommandPanTo -> SetGuidance
1588 (
"Places the camera in this position right and up relative to standard"
1589 "\ntarget point (as seen from viewpoint direction).");
1590 parameter =
new G4UIparameter(
"right",
'd', omitable =
true);
1591 parameter -> SetCurrentAsDefault (
true);
1592 fpCommandPanTo -> SetParameter (parameter);
1594 parameter -> SetCurrentAsDefault (
true);
1595 fpCommandPanTo -> SetParameter (parameter);
1596 parameter =
new G4UIparameter (
"unit",
's', omitable =
true);
1597 parameter -> SetDefaultValue (
"m");
1598 fpCommandPanTo -> SetParameter (parameter);
1602 delete fpCommandPan;
1603 delete fpCommandPanTo;
1608 if (command == fpCommandPan) {
1609 currentValue =
ConvertToString(fPanIncrementRight, fPanIncrementUp,
"m");
1611 else if (command == fpCommandPanTo) {
1614 return currentValue;
1624 if (!currentViewer) {
1627 "ERROR: G4VisCommandsViewerPan::SetNewValue: no current viewer."
1635 if (command == fpCommandPan) {
1639 else if (command == fpCommandPanTo) {
1641 vp.
SetPan(fPanToRight, fPanToUp);
1655 G4bool omitable, currentAsDefault;
1657 fpCommand -> SetGuidance (
"Forces rebuild of graphical database.");
1658 fpCommand -> SetGuidance
1659 (
"By default, acts on current viewer. \"/vis/viewer/list\""
1660 "\nto see possible viewers. Viewer becomes current.");
1661 fpCommand -> SetParameterName (
"viewer-name",
1663 currentAsDefault =
true);
1673 return viewer -> GetName ();
1689 G4warn <<
"ERROR: Viewer \"" << rebuildName
1690 <<
"\" not found - \"/vis/viewer/list\" to see possibilities."
1697 if (!sceneHandler) {
1699 G4warn <<
"ERROR: Viewer \"" << viewer->
GetName() <<
"\"" <<
1700 " has no scene handler - report serious bug."
1719 G4bool omitable, currentAsDefault;
1721 fpCommand -> SetGuidance
1722 (
"Refreshes viewer.");
1723 fpCommand -> SetGuidance
1724 (
"By default, acts on current viewer. \"/vis/viewer/list\""
1725 "\nto see possible viewers. Viewer becomes current.");
1726 fpCommand -> SetParameterName (
"viewer-name",
1728 currentAsDefault =
true);
1737 return viewer ? viewer -> GetName () :
G4String(
"none");
1749 G4warn <<
"ERROR: Viewer \"" << refreshName <<
"\"" <<
1750 " not found - \"/vis/viewer/list\"\n to see possibilities."
1757 if (!sceneHandler) {
1759 G4warn <<
"ERROR: Viewer \"" << refreshName <<
"\"" <<
1760 " has no scene handler - report serious bug."
1769 G4cout <<
"NOTE: SceneHandler \"" << sceneHandler->
GetName()
1770 <<
"\", to which viewer \"" << refreshName <<
"\"" <<
1771 "\n is attached, has no scene - \"/vis/scene/create\" and"
1772 " \"/vis/sceneHandler/attach\""
1773 "\n (or use compound command \"/vis/drawVolume\")."
1779 G4bool successful = scene -> AddWorldIfEmpty (warn);
1783 "WARNING: Scene is empty. Perhaps no geometry exists."
1784 "\n Try /run/initialize."
1795 G4cout <<
"Refreshing viewer \"" << viewer -> GetName () <<
"\"..."
1798 viewer -> SetView ();
1799 viewer -> ClearView ();
1800 viewer -> DrawView ();
1802 G4cout <<
"Viewer \"" << viewer -> GetName () <<
"\"" <<
" refreshed."
1803 "\n (You might also need \"/vis/viewer/update\".)" <<
G4endl;
1811 G4bool omitable, currentAsDefault;
1813 fpCommand -> SetGuidance (
"Resets viewer.");
1814 fpCommand -> SetGuidance
1815 (
"By default, acts on current viewer. \"/vis/viewer/list\""
1816 "\nto see possible viewers. Viewer becomes current.");
1817 fpCommand -> SetParameterName (
"viewer-name",
1819 currentAsDefault =
true);
1829 return viewer -> GetName ();
1844 G4warn <<
"ERROR: Viewer \"" << resetName
1845 <<
"\" not found - \"/vis/viewer/list\" to see possibilities."
1858 G4bool omitable, currentAsDefault;
1860 fpCommand -> SetGuidance (
"Resets only the camera parameters.");
1861 fpCommand -> SetGuidance
1862 (
"By default, acts on current viewer. \"/vis/viewer/list\""
1863 "\nto see possible viewers. Viewer becomes current.");
1864 fpCommand -> SetParameterName (
"viewer-name",
1866 currentAsDefault =
true);
1876 return viewer -> GetName ();
1891 G4warn <<
"ERROR: Viewer \"" << resetName
1892 <<
"\" not found - \"/vis/viewer/list\" to see possibilities."
1909 fpCommand -> SetGuidance
1910 (
"Write commands that define the current view to file.");
1911 fpCommand -> SetGuidance
1912 (
"Read them back into the same or any viewer with \"/control/execute\".");
1913 fpCommand -> SetGuidance
1914 (
"If the filename is omitted the view is saved to a file "
1915 "\"g4_nn.g4view\", where nn is a sequential two-digit number.");
1916 fpCommand -> SetGuidance
1917 (
"If the filename is \"-\", the data are written to G4cout.");
1918 fpCommand -> SetGuidance
1919 (
"If you are wanting to save views for future interpolation a recommended "
1920 "procedure is: save views to \"g4_nn.g4view\", as above, then move the files "
1921 "into a sub-directory, say, \"views\", then interpolate with"
1922 "\"/vis/viewer/interpolate views\"");
1923 fpCommand -> SetParameterName (
"filename", omitable =
true);
1924 fpCommand -> SetDefaultValue (
"");
1957 if (!currentViewer) {
1960 "ERROR: G4VisCommandsViewerSave::SetNewValue: no current viewer."
1967 if (!currentScene) {
1970 "ERROR: G4VisCommandsViewerSave::SetNewValue: no current scene."
1979 const std::vector<G4ModelingParameters::VisAttributesModifier>*
1982 std::vector<G4ModelingParameters::VisAttributesModifier>::const_iterator i;
1983 for (i = privateVAMs->begin(); i != privateVAMs->end(); ++i) {
1991 if (newValue.length() == 0) {
1993 const G4int maxNoOfFiles = 100;
1994 static G4int sequenceNumber = 0;
1995 if (sequenceNumber >= maxNoOfFiles) {
1998 <<
"ERROR: G4VisCommandsViewerSave::SetNewValue: Maximum number, "
2000 <<
", of files exceeded."
2005 std::ostringstream oss;
2006 oss << std::setw(2) << std::setfill(
'0') << sequenceNumber++;
2007 filename =
"g4_" + oss.str() +
".g4view";
2010 if (filename ==
"-") {
2012 WriteCommands(
G4cout,vp,stp);
2015 if (!G4StrUtil::contains(filename,
'.')) {
2017 filename +=
".g4view";
2019 std::ofstream ofs(filename);
2023 "ERROR: G4VisCommandsViewerSave::SetNewValue: Trouble opening file \""
2024 << filename <<
"\"."
2030 WriteCommands(ofs,vp,stp);
2035 G4warn <<
"Viewer \"" << currentViewer -> GetName ()
2036 <<
"\"" <<
" saved to ";
2037 if (filename ==
"-") {
2040 G4warn <<
"file \'" << filename <<
"\"." <<
2041 "\n Read the view back into this or any viewer with"
2042 "\n \"/control/execute " << filename <<
"\" or use"
2043 "\n \"/vis/viewer/interpolate\" if you have several saved files -"
2044 "\n see \"help /vis/viewer/interpolate\" for guidance.";
2056 G4bool omitable, currentAsDefault;
2059 (
"/vis/viewer/scale",
this);
2060 fpCommandScale -> SetGuidance (
"Incremental (non-uniform) scaling.");
2061 fpCommandScale -> SetGuidance
2062 (
"Multiplies components of current scaling by components of this factor."
2063 "\n Scales (x,y,z) by corresponding components of the resulting factor.");
2064 fpCommandScale -> SetGuidance
2066 fpCommandScale -> SetParameterName
2067 (
"x-scale-multiplier",
"y-scale-multiplier",
"z-scale-multiplier",
2068 omitable=
true, currentAsDefault=
true);
2071 (
"/vis/viewer/scaleTo",
this);
2072 fpCommandScaleTo -> SetGuidance (
"Absolute (non-uniform) scaling.");
2073 fpCommandScaleTo -> SetGuidance
2074 (
"Scales (x,y,z) by corresponding components of this factor.");
2075 fpCommandScaleTo -> SetParameterName
2076 (
"x-scale-factor",
"y-scale-factor",
"z-scale-factor",
2077 omitable=
true, currentAsDefault=
true);
2081 delete fpCommandScale;
2082 delete fpCommandScaleTo;
2087 if (command == fpCommandScale) {
2088 currentValue = fpCommandScale->ConvertToString(
G4ThreeVector(fScaleMultiplier));
2090 else if (command == fpCommandScaleTo) {
2091 currentValue = fpCommandScaleTo->ConvertToString(
G4ThreeVector(fScaleTo));
2093 return currentValue;
2103 if (!currentViewer) {
2106 "ERROR: G4VisCommandsViewerScale::SetNewValue: no current viewer."
2114 if (command == fpCommandScale) {
2115 fScaleMultiplier = fpCommandScale->GetNew3VectorValue(newValue);
2118 else if (command == fpCommandScaleTo) {
2119 fScaleTo = fpCommandScale->GetNew3VectorValue(newValue);
2135 fpCommand -> SetGuidance (
"Selects viewer.");
2136 fpCommand -> SetGuidance
2137 (
"Specify viewer by name. \"/vis/viewer/list\" to see possible viewers.");
2138 fpCommand -> SetParameterName (
"viewer-name", omitable =
false);
2158 G4warn <<
"ERROR: Viewer \"" << selectName <<
"\"";
2159 G4warn <<
" not found - \"/vis/viewer/list\""
2160 "\n to see possibilities."
2168 G4warn <<
"WARNING: Viewer \"" << viewer -> GetName () <<
"\""
2169 <<
" already selected." <<
G4endl;
2186 G4bool omitable, currentAsDefault;
2188 fpCommand -> SetGuidance
2189 (
"Triggers graphical database post-processing for viewers"
2190 "\nusing that technique.");
2191 fpCommand -> SetGuidance
2192 (
"For such viewers the view only becomes visible with this command."
2193 "\nBy default, acts on current viewer. \"/vis/viewer/list\""
2194 "\nto see possible viewers. Viewer becomes current.");
2195 fpCommand -> SetParameterName (
"viewer-name",
2197 currentAsDefault =
true);
2207 return viewer -> GetName ();
2224 "WARNING: command \"/vis/viewer/update\" could not be applied: no current viewer."
2231 if (!sceneHandler) {
2233 G4warn <<
"ERROR: Viewer \"" << updateName <<
"\"" <<
2234 " has no scene handler - report serious bug."
2243 G4cout <<
"NOTE: SceneHandler \"" << sceneHandler->
GetName()
2244 <<
"\", to which viewer \"" << updateName <<
"\"" <<
2245 "\n is attached, has no scene - \"/vis/scene/create\" and"
2246 " \"/vis/sceneHandler/attach\""
2247 "\n (or use compound command \"/vis/drawVolume\")."
2254 G4cout <<
"Viewer \"" << viewer -> GetName () <<
"\"";
2257 viewer -> ShowView ();
2259 sceneHandler -> SetMarkForClearingTransientStore(
true);
2265 fZoomMultiplier (1.),
2268 G4bool omitable, currentAsDefault;
2271 (
"/vis/viewer/zoom",
this);
2272 fpCommandZoom -> SetGuidance (
"Incremental zoom.");
2273 fpCommandZoom -> SetGuidance
2274 (
"Multiplies current magnification by this factor.");
2275 fpCommandZoom -> SetParameterName(
"multiplier",
2277 currentAsDefault=
true);
2280 (
"/vis/viewer/zoomTo",
this);
2281 fpCommandZoomTo -> SetGuidance (
"Absolute zoom.");
2282 fpCommandZoomTo -> SetGuidance
2283 (
"Magnifies standard magnification by this factor.");
2284 fpCommandZoomTo -> SetParameterName(
"factor",
2286 currentAsDefault=
true);
2290 delete fpCommandZoom;
2291 delete fpCommandZoomTo;
2296 if (command == fpCommandZoom) {
2297 currentValue = fpCommandZoom->ConvertToString(fZoomMultiplier);
2299 else if (command == fpCommandZoomTo) {
2300 currentValue = fpCommandZoomTo->ConvertToString(fZoomTo);
2302 return currentValue;
2312 if (!currentViewer) {
2315 "ERROR: G4VisCommandsViewerZoom::SetNewValue: no current viewer."
2323 if (command == fpCommandZoom) {
2324 fZoomMultiplier = fpCommandZoom->GetNewDoubleValue(newValue);
2327 else if (command == fpCommandZoomTo) {
2328 fZoomTo = fpCommandZoom->GetNewDoubleValue(newValue);
std::ostringstream G4ExceptionDescription
HepGeom::Normal3D< G4double > G4Normal3D
HepGeom::Plane3D< G4double > G4Plane3D
HepGeom::Point3D< G4double > G4Point3D
CLHEP::Hep3Vector G4ThreeVector
HepGeom::Vector3D< G4double > G4Vector3D
std::vector< G4Plane3D > G4Planes
G4GLOB_DLL std::ostream G4cout
void DescribeYourselfTo(G4VGraphicsScene &)
const std::vector< Findings > & GetFindings() const
G4bool AddRunDurationModel(G4VModel *, G4bool warn=false)
const std::vector< Model > & GetRunDurationModelList() const
const G4VisExtent & GetExtent() const
const G4Point3D & GetStandardTargetPoint() const
const G4String & GetName() const
static G4TransportationManager * GetTransportationManager()
std::vector< G4VPhysicalVolume * >::iterator GetWorldsIterator()
std::size_t GetNoWorlds() const
static G4double ValueOf(const char *unitName)
void CommandFailed(G4int errCode, G4ExceptionDescription &ed)
static G4double ConvertToDimensionedDouble(const char *st)
G4int ApplyCommand(const char *aCommand)
G4int GetVerboseLevel() const
static G4UImanager * GetUIpointer()
void SetVerboseLevel(G4int val)
void SetDefaultValue(const char *theDefaultValue)
void SetGuidance(const char *theGuidance)
const G4String & GetNickname() const
void SetModelingParameters(const G4ModelingParameters *)
virtual void ClearTransientStore()
void SetMarkForClearingTransientStore(G4bool)
G4VGraphicsSystem * GetGraphicsSystem() const
G4Scene * GetScene() const
const G4String & GetName() const
const G4String & GetName() const
virtual void DrawView()=0
const G4ViewParameters & GetViewParameters() const
G4double GetKernelVisitElapsedTimeSeconds() const
G4SceneTreeItem & AccessSceneTree()
virtual const std::vector< G4ModelingParameters::VisAttributesModifier > * GetPrivateVisAttributesModifiers() const
void UpdateGUISceneTree()
const G4ViewParameters & GetDefaultViewParameters() const
virtual void FinishView()
void SetViewParameters(const G4ViewParameters &vp)
virtual void ClearView()=0
G4VSceneHandler * GetSceneHandler() const
static G4ViewParameters fExistingVP
void InterpolateToNewView(G4VViewer *currentViewer, const G4ViewParameters &oldVP, const G4ViewParameters &newVP, const G4int nInterpolationPoints=50, const G4int waitTimePerPointmilliseconds=20, const G4String &exportString="")
void CopyCameraParameters(G4ViewParameters &target, const G4ViewParameters &from)
void InterpolateViews(G4VViewer *currentViewer, const std::vector< G4ViewParameters > &viewVector, const G4int nInterpolationPoints=50, const G4int waitTimePerPointmilliseconds=20, const G4String &exportString="")
void CheckSceneAndNotifyHandlers(G4Scene *=nullptr)
static G4VisManager * fpVisManager
static G4bool ConvertToDoublePair(const G4String ¶mString, G4double &xval, G4double &yval)
void RefreshIfRequired(G4VViewer *viewer)
static G4SceneTreeItem fExistingSceneTree
void SetViewParameters(G4VViewer *viewer, const G4ViewParameters &viewParams)
void CopyParametersFrom(const G4UIcommand *fromCmd, G4UIcommand *toCmd)
G4bool ProvideValueOfUnit(const G4String &where, const G4String &unit, const G4String &category, G4double &value)
static G4bool fThereWasAViewer
void Twinkle(G4VViewer *currentViewer, const G4ViewParameters &baseVP, const std::vector< std::vector< G4PhysicalVolumeModel::G4PhysicalVolumeNodeID > > &paths)
static G4String ConvertToString(G4double x, G4double y, const char *unitName)
void CopyGuidanceFrom(const G4UIcommand *fromCmd, G4UIcommand *toCmd, G4int startLine=0)
void SetCBDParameters(const std::vector< G4double > &)
void SetScaleFactor(const G4Vector3D &scaleFactor)
const G4Vector3D & GetScaleFactor() const
void SetAutoRefresh(G4bool)
const G4String & GetXGeometryString() const
G4String CameraAndLightingCommands(const G4Point3D standardTargetPoint) const
void AddVisAttributesModifier(const G4ModelingParameters::VisAttributesModifier &)
void SetCurrentTargetPoint(const G4Point3D ¤tTargetPoint)
const G4Colour & GetBackgroundColour() const
void ClearCutawayPlanes()
const G4Point3D & GetCurrentTargetPoint() const
void SetCBDAlgorithmNumber(G4int)
void MultiplyScaleFactor(const G4Vector3D &scaleFactorMultiplier)
G4double GetZoomFactor() const
void SetDolly(G4double dolly)
G4String SceneModifyingCommands() const
void IncrementPan(G4double right, G4double up)
G4String TimeWindowCommands() const
G4String TouchableCommands() const
const std::vector< G4double > & GetCBDParameters() const
G4int GetCBDAlgorithmNumber() const
void ChangeCutawayPlane(size_t index, const G4Plane3D &cutawayPlane)
G4double GetGlobalMarkerScale() const
void SetZoomFactor(G4double zoomFactor)
void SetPan(G4double right, G4double up)
const G4Planes & GetCutawayPlanes() const
void MultiplyZoomFactor(G4double zoomFactorMultiplier)
G4String DrawingStyleCommands() const
G4bool IsAutoRefresh() const
void IncrementDolly(G4double dollyIncrement)
void ClearVisAttributesModifiers()
void AddCutawayPlane(const G4Plane3D &cutawayPlane)
G4double GetDolly() const
G4VisCommandViewerAddCutawayPlane()
void SetNewValue(G4UIcommand *command, G4String newValue)
G4String GetCurrentValue(G4UIcommand *command)
virtual ~G4VisCommandViewerAddCutawayPlane()
G4VisCommandViewerCentreOn()
virtual ~G4VisCommandViewerCentreOn()
void SetNewValue(G4UIcommand *command, G4String newValue)
G4String GetCurrentValue(G4UIcommand *command)
G4VisCommandViewerChangeCutawayPlane()
virtual ~G4VisCommandViewerChangeCutawayPlane()
G4String GetCurrentValue(G4UIcommand *command)
void SetNewValue(G4UIcommand *command, G4String newValue)
void SetNewValue(G4UIcommand *command, G4String newValue)
G4VisCommandViewerClearCutawayPlanes()
virtual ~G4VisCommandViewerClearCutawayPlanes()
G4String GetCurrentValue(G4UIcommand *command)
void SetNewValue(G4UIcommand *command, G4String newValue)
G4String GetCurrentValue(G4UIcommand *command)
G4VisCommandViewerClearTransients()
virtual ~G4VisCommandViewerClearTransients()
G4VisCommandViewerClearVisAttributesModifiers()
void SetNewValue(G4UIcommand *command, G4String newValue)
virtual ~G4VisCommandViewerClearVisAttributesModifiers()
G4String GetCurrentValue(G4UIcommand *command)
void SetNewValue(G4UIcommand *command, G4String newValue)
G4VisCommandViewerClear()
virtual ~G4VisCommandViewerClear()
G4String GetCurrentValue(G4UIcommand *command)
G4VisCommandViewerClone()
G4String GetCurrentValue(G4UIcommand *command)
virtual ~G4VisCommandViewerClone()
void SetNewValue(G4UIcommand *command, G4String newValue)
void SetNewValue(G4UIcommand *command, G4String newValue)
virtual ~G4VisCommandViewerColourByDensity()
G4VisCommandViewerColourByDensity()
G4String GetCurrentValue(G4UIcommand *command)
void SetNewValue(G4UIcommand *command, G4String newValue)
G4String GetCurrentValue(G4UIcommand *command)
virtual ~G4VisCommandViewerCopyViewFrom()
G4VisCommandViewerCopyViewFrom()
void SetNewValue(G4UIcommand *command, G4String newValue)
G4String GetCurrentValue(G4UIcommand *command)
G4VisCommandViewerCreate()
virtual ~G4VisCommandViewerCreate()
void SetNewValue(G4UIcommand *command, G4String newValue)
G4VisCommandViewerDolly()
G4String GetCurrentValue(G4UIcommand *command)
virtual ~G4VisCommandViewerDolly()
virtual ~G4VisCommandViewerFlush()
void SetNewValue(G4UIcommand *command, G4String newValue)
G4VisCommandViewerFlush()
G4String GetCurrentValue(G4UIcommand *command)
G4VisCommandViewerInterpolate()
G4String GetCurrentValue(G4UIcommand *command)
void SetNewValue(G4UIcommand *command, G4String newValue)
virtual ~G4VisCommandViewerInterpolate()
G4String GetCurrentValue(G4UIcommand *command)
virtual ~G4VisCommandViewerList()
void SetNewValue(G4UIcommand *command, G4String newValue)
G4String GetCurrentValue(G4UIcommand *command)
virtual ~G4VisCommandViewerPan()
void SetNewValue(G4UIcommand *command, G4String newValue)
G4VisCommandViewerRebuild()
G4String GetCurrentValue(G4UIcommand *command)
virtual ~G4VisCommandViewerRebuild()
void SetNewValue(G4UIcommand *command, G4String newValue)
virtual ~G4VisCommandViewerRefresh()
G4String GetCurrentValue(G4UIcommand *command)
void SetNewValue(G4UIcommand *command, G4String newValue)
G4VisCommandViewerRefresh()
void SetNewValue(G4UIcommand *command, G4String newValue)
G4String GetCurrentValue(G4UIcommand *command)
virtual ~G4VisCommandViewerResetCameraParameters()
G4VisCommandViewerResetCameraParameters()
G4VisCommandViewerReset()
void SetNewValue(G4UIcommand *command, G4String newValue)
virtual ~G4VisCommandViewerReset()
G4String GetCurrentValue(G4UIcommand *command)
G4String GetCurrentValue(G4UIcommand *command)
void SetNewValue(G4UIcommand *command, G4String newValue)
virtual ~G4VisCommandViewerSave()
G4String GetCurrentValue(G4UIcommand *command)
void SetNewValue(G4UIcommand *command, G4String newValue)
virtual ~G4VisCommandViewerScale()
G4VisCommandViewerScale()
G4String GetCurrentValue(G4UIcommand *command)
virtual ~G4VisCommandViewerSelect()
G4VisCommandViewerSelect()
void SetNewValue(G4UIcommand *command, G4String newValue)
G4VisCommandViewerUpdate()
G4String GetCurrentValue(G4UIcommand *command)
virtual ~G4VisCommandViewerUpdate()
void SetNewValue(G4UIcommand *command, G4String newValue)
G4String GetCurrentValue(G4UIcommand *command)
virtual ~G4VisCommandViewerZoom()
void SetNewValue(G4UIcommand *command, G4String newValue)
G4double GetExtentRadius() const
const G4Point3D & GetExtentCentre() const