59 fpCommandAll->SetGuidance
60 (
"Copies view parameters.");
61 fpCommandAll->SetGuidance
62 (
"Copies ALL view parameters (except the autoRefresh status) from"
63 "\nfrom-viewer to current viewer. You may need \"/vis/viewer/rebuild\".");
64 fpCommandAll->SetGuidance
65 (
"Note: to copy only the camera-specific parameters use"
66 "\n\"/vis/viewer/copyfrom\".");
67 fpCommandAll->SetParameterName (
"from-viewer-name",omitable =
false);
70 (
"/vis/viewer/set/autoRefresh",
this);
71 fpCommandAutoRefresh->SetGuidance(
"Sets auto-refresh.");
72 fpCommandAutoRefresh->SetGuidance
73 (
"If true, view is automatically refreshed after a change of"
74 "\nview parameters.");
75 fpCommandAutoRefresh->SetParameterName(
"auto-refresh",omitable =
true);
76 fpCommandAutoRefresh->SetDefaultValue(
true);
79 (
"/vis/viewer/set/auxiliaryEdge",
this);
80 fpCommandAuxEdge->SetGuidance(
"Sets visibility of auxiliary edges");
81 fpCommandAuxEdge->SetGuidance
82 (
"Auxiliary edges, i.e., those that are part of a curved surface,"
83 "\nsometimes called soft edges, become visible/invisible.");
84 fpCommandAuxEdge->SetParameterName(
"edge",omitable =
true);
85 fpCommandAuxEdge->SetDefaultValue(
true);
88 (
"/vis/viewer/set/background",
this);
89 fpCommandBackground->SetGuidance
90 (
"Set background colour and transparency (default black and opaque).");
92 parameter =
new G4UIparameter(
"red_or_string",
's', omitable =
true);
93 parameter -> SetDefaultValue (
"0.");
94 fpCommandBackground -> SetParameter (parameter);
96 parameter -> SetDefaultValue (0.);
97 fpCommandBackground -> SetParameter (parameter);
99 parameter -> SetDefaultValue (0.);
100 fpCommandBackground -> SetParameter (parameter);
101 parameter =
new G4UIparameter (
"opacity",
'd', omitable =
true);
102 parameter -> SetDefaultValue (1.);
103 fpCommandBackground -> SetParameter (parameter);
105 fpCommandCulling =
new G4UIcommand(
"/vis/viewer/set/culling",
this);
106 fpCommandCulling->SetGuidance (
"Set culling options.");
107 fpCommandCulling->SetGuidance
108 (
"\"global\": enables/disables all other culling options.");
109 fpCommandCulling->SetGuidance
110 (
"\"coveredDaughters\": culls, i.e., eliminates, volumes that would not"
111 "\nbe seen because covered by ancestor volumes in surface drawing mode,"
112 "\nand then only if the ancestors are visible and opaque, and then only"
113 "\nif no sections or cutaways are in operation. Intended solely to"
114 "\nimprove the speed of rendering visible volumes.");
115 fpCommandCulling->SetGuidance
116 (
"\"invisible\": culls objects with the invisible attribute set.");
117 fpCommandCulling->SetGuidance
118 (
"\"density\": culls volumes with density lower than threshold. Useful"
119 "\nfor eliminating \"container volumes\" with no physical correspondence,"
120 "\nwhose material is usually air. If this is selected, provide threshold"
121 "\ndensity and unit (e.g., g/cm3, mg/cm3 or kg/m3)."
123 parameter =
new G4UIparameter(
"culling-option",
's',omitable =
false);
125 (
"global coveredDaughters invisible density");
126 fpCommandCulling->SetParameter(parameter);
129 fpCommandCulling->SetParameter(parameter);
130 parameter =
new G4UIparameter(
"density-threshold",
'd',omitable =
true);
132 fpCommandCulling->SetParameter(parameter);
137 fpCommandCulling->SetParameter(parameter);
139 fpCommandCutawayMode =
141 fpCommandCutawayMode->SetGuidance
142 (
"Sets cutaway mode - add (union) or multiply (intersection).");
143 fpCommandCutawayMode->SetParameterName (
"cutaway-mode",omitable =
false);
144 fpCommandCutawayMode->SetCandidates (
"add union multiply intersection");
145 fpCommandCutawayMode->SetDefaultValue(
"union");
148 (
"/vis/viewer/set/defaultColour",
this);
149 fpCommandDefaultColour->SetGuidance
150 (
"Set defaultColour colour and transparency (default white and opaque).");
152 parameter =
new G4UIparameter(
"red_or_string",
's', omitable =
true);
153 parameter -> SetDefaultValue (
"1.");
154 fpCommandDefaultColour -> SetParameter (parameter);
155 parameter =
new G4UIparameter(
"green",
'd', omitable =
true);
156 parameter -> SetDefaultValue (1.);
157 fpCommandDefaultColour -> SetParameter (parameter);
158 parameter =
new G4UIparameter (
"blue",
'd', omitable =
true);
159 parameter -> SetDefaultValue (1.);
160 fpCommandDefaultColour -> SetParameter (parameter);
161 parameter =
new G4UIparameter (
"opacity",
'd', omitable =
true);
162 parameter -> SetDefaultValue (1.);
163 fpCommandDefaultColour -> SetParameter (parameter);
166 (
"/vis/viewer/set/defaultTextColour",
this);
167 fpCommandDefaultTextColour->SetGuidance
168 (
"Set defaultTextColour colour and transparency (default blue and opaque).");
170 parameter =
new G4UIparameter(
"red_or_string",
's', omitable =
true);
171 parameter -> SetDefaultValue (
"0.");
172 fpCommandDefaultTextColour -> SetParameter (parameter);
173 parameter =
new G4UIparameter(
"green",
'd', omitable =
true);
174 parameter -> SetDefaultValue (0.);
175 fpCommandDefaultTextColour -> SetParameter (parameter);
176 parameter =
new G4UIparameter (
"blue",
'd', omitable =
true);
177 parameter -> SetDefaultValue (1.);
178 fpCommandDefaultTextColour -> SetParameter (parameter);
179 parameter =
new G4UIparameter (
"opacity",
'd', omitable =
true);
180 parameter -> SetDefaultValue (1.);
181 fpCommandDefaultTextColour -> SetParameter (parameter);
184 fpCommandEdge->SetGuidance
185 (
"Edges become visible/invisible in surface mode.");
186 fpCommandEdge->SetParameterName(
"edge",omitable =
true);
187 fpCommandEdge->SetDefaultValue(
true);
190 (
"/vis/viewer/set/explodeFactor",
this);
191 fpCommandExplodeFactor->SetGuidance
192 (
"Moves top-level drawn volumes by this factor from this centre.");
193 parameter =
new G4UIparameter(
"explodeFactor",
'd', omitable=
true);
196 fpCommandExplodeFactor->SetParameter(parameter);
199 parameter->
SetGuidance (
"Coordinate of explode centre.");
200 fpCommandExplodeFactor->SetParameter(parameter);
203 parameter->
SetGuidance (
"Coordinate of explode centre.");
204 fpCommandExplodeFactor->SetParameter(parameter);
207 parameter->
SetGuidance (
"Coordinate of explode centre.");
208 fpCommandExplodeFactor->SetParameter(parameter);
211 parameter->
SetGuidance (
"Unit of explode centre.");
212 fpCommandExplodeFactor->SetParameter(parameter);
215 (
"/vis/viewer/set/globalLineWidthScale",
this);
216 fpCommandGlobalLineWidthScale->SetGuidance
217 (
"Multiplies line widths by this factor.");
218 fpCommandGlobalLineWidthScale->
219 SetParameterName(
"scale-factor", omitable=
true);
220 fpCommandGlobalLineWidthScale->SetDefaultValue(1.);
223 (
"/vis/viewer/set/globalMarkerScale",
this);
224 fpCommandGlobalMarkerScale->SetGuidance
225 (
"Multiplies marker sizes by this factor.");
226 fpCommandGlobalMarkerScale->
227 SetParameterName(
"scale-factor", omitable=
true);
228 fpCommandGlobalMarkerScale->SetDefaultValue(1.);
230 fpCommandHiddenEdge =
232 fpCommandHiddenEdge->SetGuidance
233 (
"Edges become hidden/seen in wireframe or surface mode.");
234 fpCommandHiddenEdge->SetParameterName(
"hidden-edge",omitable =
true);
235 fpCommandHiddenEdge->SetDefaultValue(
true);
237 fpCommandHiddenMarker =
239 fpCommandHiddenMarker->SetGuidance
240 (
"If true, closer objects hide markers. Otherwise, markers always show.");
241 fpCommandHiddenMarker->SetParameterName(
"hidden-marker",omitable =
true);
242 fpCommandHiddenMarker->SetDefaultValue(
true);
245 (
"/vis/viewer/set/lightsMove",
this);
246 fpCommandLightsMove->SetGuidance
247 (
"Lights move with camera or with object");
248 fpCommandLightsMove->SetParameterName(
"lightsMove",omitable =
false);
249 fpCommandLightsMove->SetCandidates
250 (
"cam camera with-camera obj object with-object");
253 (
"/vis/viewer/set/lightsThetaPhi",
this);
254 fpCommandLightsThetaPhi->SetGuidance
255 (
"Set direction from target to lights.");
256 parameter =
new G4UIparameter(
"theta",
'd', omitable =
true);
257 parameter -> SetDefaultValue(60.);
258 fpCommandLightsThetaPhi -> SetParameter (parameter);
260 parameter -> SetDefaultValue(45.);
261 fpCommandLightsThetaPhi -> SetParameter (parameter);
262 parameter =
new G4UIparameter (
"unit",
's', omitable =
true);
263 parameter -> SetDefaultValue (
"deg");
264 fpCommandLightsThetaPhi -> SetParameter (parameter);
267 (
"/vis/viewer/set/lightsVector",
this);
268 fpCommandLightsVector->SetGuidance
269 (
"Set direction from target to lights.");
271 parameter -> SetDefaultValue (1);
272 fpCommandLightsVector -> SetParameter (parameter);
274 parameter -> SetDefaultValue (1);
275 fpCommandLightsVector -> SetParameter (parameter);
277 parameter -> SetDefaultValue (1);
278 fpCommandLightsVector -> SetParameter (parameter);
281 (
"/vis/viewer/set/lineSegmentsPerCircle",
this);
282 fpCommandLineSegments->SetGuidance
283 (
"Set number of sides per circle for polygon/polyhedron drawing.");
284 fpCommandLineSegments->SetGuidance
285 (
"Refers to graphical representation of objects with curved lines/surfaces.");
286 fpCommandLineSegments->SetParameterName(
"line-segments",omitable =
true);
287 fpCommandLineSegments->SetDefaultValue(24);
290 (
"/vis/viewer/set/lineWidth",
this);
291 fpCommandLineWidth->SetGuidance
292 (
"Use \"/vis/viewer/set/globalLineWidthScale\" instead."
293 "\nFor trajectories use \"/vis/modeling/trajectories/*/default/setLineWidth\"."
294 "\nFor volumes use \"/vis/geometry/set/lineWidth\".");
297 (
"/vis/viewer/set/numberOfCloudPoints",
this);
298 fpCommandNumberOfCloudPoints->SetGuidance
299 (
"Set number of points to be used for cloud representation of volumes.");
300 fpCommandNumberOfCloudPoints->SetParameterName(
"points",omitable =
true);
301 fpCommandNumberOfCloudPoints->SetDefaultValue(10000);
304 (
"/vis/viewer/set/picking",
this);
305 fpCommandPicking->SetGuidance(
"Sets picking, if available.");
306 fpCommandPicking->SetGuidance
307 (
"If true, view is set up for picking, if available.");
308 fpCommandPicking->SetGuidance
309 (
"You may need to issue \"/vis/viewer/update\".");
310 fpCommandPicking->SetGuidance
311 (
"For required actions, watch for instructions for viewer.");
312 fpCommandPicking->SetParameterName(
"picking",omitable =
true);
313 fpCommandPicking->SetDefaultValue(
true);
315 fpCommandProjection =
new G4UIcommand(
"/vis/viewer/set/projection",
this);
316 fpCommandProjection->SetGuidance
317 (
"Set projection style - o[rthogonal] or p[erspective]."
318 "\nIf p[erspective], also set field half angle.");
319 parameter =
new G4UIparameter(
"projection",
's',omitable =
true);
322 fpCommandProjection->SetParameter(parameter);
323 parameter =
new G4UIparameter(
"field-half-angle",
'd',omitable =
true);
326 fpCommandProjection->SetParameter(parameter);
330 fpCommandProjection->SetParameter(parameter);
333 (
"/vis/viewer/set/rotationStyle",
this);
334 fpCommandRotationStyle->SetGuidance
335 (
"Set style of rotation - constrainUpDirection or freeRotation.");
336 fpCommandRotationStyle->SetGuidance
337 (
"constrainUpDirection: conventional HEP view.");
338 fpCommandRotationStyle->SetGuidance
339 (
"freeRotation: Google-like rotation, using mouse-grab.");
340 fpCommandRotationStyle->SetParameterName (
"style",omitable =
false);
341 fpCommandRotationStyle->SetCandidates(
"constrainUpDirection freeRotation");
343 fpCommandSectionPlane =
new G4UIcommand(
"/vis/viewer/set/sectionPlane",
this);
344 fpCommandSectionPlane -> SetGuidance
345 (
"Set plane for drawing section (DCUT).");
346 fpCommandSectionPlane -> SetGuidance
347 (
"E.g., for a y-z plane at x = 1 cm:"
348 "\n\"/vis/viewer/set/sectionPlane on 1 0 0 cm 1 0 0\"."
349 "\nTo turn off: /vis/viewer/set/sectionPlane off");
351 parameter -> SetDefaultValue (
"on");
352 fpCommandSectionPlane->SetParameter(parameter);
354 parameter -> SetDefaultValue (0);
355 parameter -> SetGuidance (
"Coordinate of point on the plane.");
356 fpCommandSectionPlane->SetParameter(parameter);
358 parameter -> SetDefaultValue (0);
359 parameter -> SetGuidance (
"Coordinate of point on the plane.");
360 fpCommandSectionPlane->SetParameter(parameter);
362 parameter -> SetDefaultValue (0);
363 parameter -> SetGuidance (
"Coordinate of point on the plane.");
364 fpCommandSectionPlane->SetParameter(parameter);
366 parameter -> SetDefaultValue (
"m");
367 parameter -> SetGuidance (
"Unit of point on the plane.");
368 fpCommandSectionPlane->SetParameter(parameter);
370 parameter -> SetDefaultValue (1);
371 parameter -> SetGuidance (
"Component of plane normal.");
372 fpCommandSectionPlane->SetParameter(parameter);
374 parameter -> SetDefaultValue (0);
375 parameter -> SetGuidance (
"Component of plane normal.");
376 fpCommandSectionPlane->SetParameter(parameter);
378 parameter -> SetDefaultValue (0);
379 parameter -> SetGuidance (
"Component of plane normal.");
380 fpCommandSectionPlane->SetParameter(parameter);
383 (
"/vis/viewer/set/specialMeshRendering",
this);
384 fpCommandSpecialMeshRendering -> SetGuidance
385 (
"Request special rendering of volumes (meshes) that use G4VParameterisation.");
386 fpCommandSpecialMeshRendering->SetParameterName(
"render",omitable =
true);
387 fpCommandSpecialMeshRendering->SetDefaultValue(
true);
390 (
"/vis/viewer/set/specialMeshRenderingOption",
this);
391 fpCommandSpecialMeshRenderingOption->SetGuidance
392 (
"Set special mesh rendering option - \"default\", \"dots\" or \"surfaces\".");
393 fpCommandSpecialMeshRenderingOption->SetParameterName (
"option",omitable =
true);
394 fpCommandSpecialMeshRenderingOption->SetCandidates(
"default dots surfaces");
395 fpCommandSpecialMeshRenderingOption->SetDefaultValue(
"default");
398 (
"/vis/viewer/set/specialMeshVolumes",
this);
399 fpCommandSpecialMeshVolumes -> SetGuidance
400 (
"Specify the volumes for special rendering. No arguments resets the list"
401 "\nand is interpreted to mean \"all found meshes\".");
402 fpCommandSpecialMeshVolumes->SetGuidance
403 (
"Please provide a list of space-separated physical volume names and copy"
404 "\nnumber pairs. Negative copy number means \"all volumes of that name\".");
405 parameter =
new G4UIparameter(
"volumes",
's',omitable =
true);
407 (
"List of physical volume names and copy number pairs");
408 fpCommandSpecialMeshVolumes->SetParameter(parameter);
411 fpCommandStyle->SetGuidance
412 (
"Set style of drawing - w[ireframe] or s[urface] or c[loud].");
413 fpCommandStyle->SetGuidance
414 (
"(Hidden line drawing is controlled by \"/vis/viewer/set/hiddenEdge\".)");
415 fpCommandStyle->SetParameterName (
"style",omitable =
false);
416 fpCommandStyle->SetCandidates(
"w wireframe s surface c cloud");
419 (
"/vis/viewer/set/targetPoint",
this);
420 fpCommandTargetPoint->SetGuidance
421 (
"Set target point.");
422 fpCommandTargetPoint->SetGuidance
423 (
"This sets the \"Current Target Point\" relative to the \"Standard");
424 fpCommandTargetPoint->SetGuidance
425 (
"Target Point\" so that the actual target point is as requested.");
426 fpCommandTargetPoint->SetGuidance
427 (
"(See G4ViewParameters.hh for an explanation of target points.)");
428 fpCommandTargetPoint->SetParameterName(
"x",
"y",
"z", omitable =
false);
429 fpCommandTargetPoint->SetUnitCategory(
"Length");
432 (
"/vis/viewer/set/upThetaPhi",
this);
433 fpCommandUpThetaPhi -> SetGuidance (
"Set up vector.");
434 fpCommandUpThetaPhi -> SetGuidance
435 (
"Viewer will attempt always to show this direction upwards.");
436 parameter =
new G4UIparameter(
"theta",
'd', omitable =
true);
437 parameter -> SetDefaultValue (90.);
438 fpCommandUpThetaPhi -> SetParameter (parameter);
440 parameter -> SetDefaultValue (90.);
441 fpCommandUpThetaPhi -> SetParameter (parameter);
442 parameter =
new G4UIparameter (
"unit",
's', omitable =
true);
443 parameter -> SetDefaultValue (
"deg");
444 fpCommandUpThetaPhi -> SetParameter (parameter);
447 (
"/vis/viewer/set/upVector",
this);
448 fpCommandUpVector -> SetGuidance (
"Set up vector.");
449 fpCommandUpVector -> SetGuidance
450 (
"Viewer will attempt always to show this direction upwards.");
452 parameter -> SetDefaultValue (0.);
453 fpCommandUpVector -> SetParameter (parameter);
455 parameter -> SetDefaultValue (1.);
456 fpCommandUpVector -> SetParameter (parameter);
458 parameter -> SetDefaultValue (0.);
459 fpCommandUpVector -> SetParameter (parameter);
462 (
"/vis/viewer/set/viewpointThetaPhi",
this);
463 fpCommandViewpointThetaPhi -> SetGuidance
464 (
"Set direction from target to camera.");
465 fpCommandViewpointThetaPhi -> SetGuidance
466 (
"Also changes lightpoint direction if lights are set to move with camera.");
467 parameter =
new G4UIparameter(
"theta",
'd', omitable =
true);
468 parameter -> SetDefaultValue (60.);
469 fpCommandViewpointThetaPhi -> SetParameter (parameter);
471 parameter -> SetDefaultValue (45.);
472 fpCommandViewpointThetaPhi -> SetParameter (parameter);
473 parameter =
new G4UIparameter (
"unit",
's', omitable =
true);
474 parameter -> SetDefaultValue (
"deg");
475 fpCommandViewpointThetaPhi -> SetParameter (parameter);
478 (
"/vis/viewer/set/viewpointVector",
this);
479 fpCommandViewpointVector -> SetGuidance
480 (
"Set direction from target to camera.");
481 fpCommandViewpointVector -> SetGuidance
482 (
"Also changes lightpoint direction if lights are set to move with camera.");
484 parameter -> SetDefaultValue (1.);
485 fpCommandViewpointVector -> SetParameter (parameter);
487 parameter -> SetDefaultValue (1.);
488 fpCommandViewpointVector -> SetParameter (parameter);
490 parameter -> SetDefaultValue (1.);
491 fpCommandViewpointVector -> SetParameter (parameter);
493 fpTimeWindowDirectory =
new G4UIdirectory (
"/vis/viewer/set/timeWindow/");
494 fpTimeWindowDirectory -> SetGuidance (
"Set time window parameters of current viewer.");
496 "For these commands use"
497 "\n /vis/scene/add/trajectories rich"
498 "\n /vis/modeling/trajectories/drawByCharge-0/default/setTimeSliceInterval 0.01 ns"
500 "\n /vis/viewer/set/timeWindow/displayLightFront true 0 0 -50 cm -0.5 ns"
501 "\n /vis/viewer/set/timeWindow/displayHeadTime true"
502 "\n /vis/viewer/set/timeWindow/fadeFactor 1"
503 "\n /run/beamOn # or several until you get a good event or events"
504 "\n /vis/viewer/set/timeWindow/startTime 0 ns 1 ns"
505 "\n /vis/viewer/save"
506 "\n /vis/viewer/set/timeWindow/startTime 1 ns 1 ns"
507 "\nthen zoom, pan etc to a view of interest and"
508 "\n /vis/viewer/save"
509 "\nthen repeat with next start time, another view and a save, then try"
510 "\n /vis/viewer/interpolate";
512 fpCommandTimeWindowDisplayHeadTime =
513 new G4UIcommand(
"/vis/viewer/set/timeWindow/displayHeadTime",
this);
514 fpCommandTimeWindowDisplayHeadTime->SetGuidance
515 (
"Display head time of range in 2D text.");
516 fpCommandTimeWindowDisplayHeadTime->SetGuidance(timeWindowGuidance);
517 parameter =
new G4UIparameter (
"displayHeadTime",
'b', omitable =
false);
519 fpCommandTimeWindowDisplayHeadTime->SetParameter(parameter);
520 parameter =
new G4UIparameter (
"screenX",
'd', omitable =
true);
524 fpCommandTimeWindowDisplayHeadTime->SetParameter(parameter);
525 parameter =
new G4UIparameter (
"screenY",
'd', omitable =
true);
529 fpCommandTimeWindowDisplayHeadTime->SetParameter(parameter);
530 parameter =
new G4UIparameter (
"screenSize",
'd', omitable =
true);
532 fpCommandTimeWindowDisplayHeadTime->SetParameter(parameter);
536 fpCommandTimeWindowDisplayHeadTime->SetParameter(parameter);
537 parameter =
new G4UIparameter (
"green",
'd', omitable =
true);
540 fpCommandTimeWindowDisplayHeadTime->SetParameter(parameter);
541 parameter =
new G4UIparameter (
"blue",
'd', omitable =
true);
544 fpCommandTimeWindowDisplayHeadTime->SetParameter(parameter);
546 fpCommandTimeWindowDisplayLightFront =
547 new G4UIcommand(
"/vis/viewer/set/timeWindow/displayLightFront",
this);
548 fpCommandTimeWindowDisplayLightFront->SetGuidance
549 (
"Display the light front at head time.");
550 fpCommandTimeWindowDisplayLightFront->SetGuidance
551 (
"Tip: The trajectories can appear of jump ahead of the light front"
552 "\nbecause their time range overlaps the viewer's time range. To"
553 "\naverage out this discrete time effect, advance the light front by"
554 "\nhalf the trajectories interval. E.g., if the trajectory time slice"
555 "\ninterval is 0.01 ns:"
556 "\n /vis/viewer/set/timeWindow/displayLightFront true -90 0 0 mm -0.005 ns"
557 "\nTo prevent them beating the light front at all:"
558 "\n /vis/viewer/set/timeWindow/displayLightFront true -90 0 0 mm -0.01 ns");
559 fpCommandTimeWindowDisplayLightFront->SetGuidance(timeWindowGuidance);
560 parameter =
new G4UIparameter (
"displayLightFront",
'b', omitable =
true);
562 fpCommandTimeWindowDisplayLightFront->SetParameter(parameter);
563 parameter =
new G4UIparameter (
"originX",
'd', omitable =
true);
565 fpCommandTimeWindowDisplayLightFront->SetParameter(parameter);
566 parameter =
new G4UIparameter (
"originY",
'd', omitable =
true);
568 fpCommandTimeWindowDisplayLightFront->SetParameter(parameter);
569 parameter =
new G4UIparameter (
"originZ",
'd', omitable =
true);
571 fpCommandTimeWindowDisplayLightFront->SetParameter(parameter);
572 parameter =
new G4UIparameter (
"space_unit",
's', omitable =
true);
574 fpCommandTimeWindowDisplayLightFront->SetParameter(parameter);
575 parameter =
new G4UIparameter (
"originT",
'd', omitable =
true);
577 fpCommandTimeWindowDisplayLightFront->SetParameter(parameter);
578 parameter =
new G4UIparameter (
"time_unit",
's', omitable =
true);
580 fpCommandTimeWindowDisplayLightFront->SetParameter(parameter);
584 fpCommandTimeWindowDisplayLightFront->SetParameter(parameter);
585 parameter =
new G4UIparameter (
"green",
'd', omitable =
true);
588 fpCommandTimeWindowDisplayLightFront->SetParameter(parameter);
589 parameter =
new G4UIparameter (
"blue",
'd', omitable =
true);
592 fpCommandTimeWindowDisplayLightFront->SetParameter(parameter);
594 fpCommandTimeWindowEndTime =
595 new G4UIcommand(
"/vis/viewer/set/timeWindow/endTime",
this);
596 fpCommandTimeWindowEndTime->SetGuidance(
"Set end and range of track time.");
597 fpCommandTimeWindowEndTime->SetGuidance(timeWindowGuidance);
598 parameter =
new G4UIparameter (
"end-time",
'd', omitable =
false);
600 fpCommandTimeWindowEndTime->SetParameter(parameter);
601 parameter =
new G4UIparameter (
"end-time-unit",
's', omitable =
false);
603 fpCommandTimeWindowEndTime->SetParameter(parameter);
604 parameter =
new G4UIparameter (
"time-range",
'd', omitable =
true);
606 fpCommandTimeWindowEndTime->SetParameter(parameter);
607 parameter =
new G4UIparameter (
"time-range-unit",
's', omitable =
true);
609 fpCommandTimeWindowEndTime->SetParameter(parameter);
611 fpCommandTimeWindowFadeFactor =
613 fpCommandTimeWindowFadeFactor->SetGuidance
614 (
"0: no fade; 1: maximum fade with time window.");
615 fpCommandTimeWindowFadeFactor->SetGuidance(timeWindowGuidance);
616 fpCommandTimeWindowFadeFactor->SetParameterName(
"fade_factor", omitable =
false);
617 fpCommandTimeWindowFadeFactor->SetRange(
"fade_factor>=0.&&fade_factor<=1.");
618 fpCommandTimeWindowFadeFactor->SetDefaultValue(0.);
620 fpCommandTimeWindowStartTime =
621 new G4UIcommand(
"/vis/viewer/set/timeWindow/startTime",
this);
622 fpCommandTimeWindowStartTime->SetGuidance(
"Set start and range of track time.");
623 fpCommandTimeWindowStartTime->SetGuidance(timeWindowGuidance);
624 parameter =
new G4UIparameter (
"start-time",
'd', omitable =
false);
626 fpCommandTimeWindowStartTime->SetParameter(parameter);
627 parameter =
new G4UIparameter (
"start-time-unit",
's', omitable =
false);
629 fpCommandTimeWindowStartTime->SetParameter(parameter);
630 parameter =
new G4UIparameter (
"time-range",
'd', omitable =
true);
632 fpCommandTimeWindowStartTime->SetParameter(parameter);
633 parameter =
new G4UIparameter (
"time-range-unit",
's', omitable =
true);
635 fpCommandTimeWindowStartTime->SetParameter(parameter);
690 if (!currentViewer) {
693 "ERROR: G4VisCommandsViewerSet::SetNewValue: no current viewer."
701 if (command == fpCommandAll) {
706 "ERROR: G4VisCommandsViewerSet::SetNewValue: all:"
707 "\n unrecognised from-viewer."
712 if (fromViewer == currentViewer) {
715 "WARNING: G4VisCommandsViewerSet::SetNewValue: all:"
716 "\n from-viewer and current viewer are identical."
728 const std::vector<G4ModelingParameters::VisAttributesModifier>*
731 std::vector<G4ModelingParameters::VisAttributesModifier>::const_iterator i;
732 for (i = privateVAMs->begin(); i != privateVAMs->end(); ++i) {
737 G4cout <<
"View parameters of viewer \"" << currentViewer->
GetName()
738 <<
"\"\n set to those of viewer \"" << fromViewer->
GetName()
743 G4warn <<
"You may need \"/vis/viewer/rebuild\"."
748 else if (command == fpCommandAutoRefresh) {
756 << currentViewer->
GetName() <<
" is NOT auto-refesh by default"
757 <<
"\n so cannot be set to auto-refresh."
766 G4cout <<
"be automatically refreshed after a change of view parameters."
775 else if (command == fpCommandAuxEdge) {
778 G4cout <<
"Auxiliary edges will ";
784 else if (command == fpCommandBackground) {
787 std::istringstream iss(newValue);
788 iss >> redOrString >> green >> blue >> opacity;
793 G4cout <<
"Background colour "
800 else if (command == fpCommandCulling) {
801 G4String cullingOption, stringFlag, unit;
803 std::istringstream is (newValue);
804 is >> cullingOption >> stringFlag >> density >> unit;
806 if (cullingOption ==
"global") {
810 "G4VisCommandsViewerSet::SetNewValue: culling: global culling flag"
812 ".\n Does not change specific culling flags."
816 else if (cullingOption ==
"coveredDaughters") {
820 "G4VisCommandsViewerSet::SetNewValue: culling: culling covered"
821 "\n daughters flag set to "
823 ". Daughters covered by opaque mothers"
824 "\n will be culled, i.e., not drawn, if this flag is true."
825 "\n Note: this is only effective in surface drawing style,"
826 "\n and then only if the volumes are visible and opaque, and then"
827 "\n only if no sections or cutaways are in operation."
831 else if (cullingOption ==
"invisible") {
835 "G4VisCommandsViewerSet::SetNewValue: culling: culling invisible"
838 ". Volumes marked invisible will be culled,"
839 "\n i.e., not drawn, if this flag is true."
843 else if (cullingOption ==
"density") {
845 "G4VisCommandsViewerSet::SetNewValue: culling: culling by density";
852 density *= valueOfUnit;
866 <<
". Volumes with density less than "
868 <<
"\n will be culled, i.e., not drawn, if this flag is true."
875 "ERROR: G4VisCommandsViewerSet::SetNewValue: culling:"
876 "\n option not recognised."
882 else if (command == fpCommandCutawayMode) {
883 if (newValue ==
"add" || newValue ==
"union")
885 if (newValue ==
"multiply" || newValue ==
"intersection")
889 G4cout <<
"Cutaway mode set to ";
893 G4cout <<
"cutawayIntersection";
898 else if (command == fpCommandDefaultColour) {
901 std::istringstream iss(newValue);
902 iss >> redOrString >> green >> blue >> opacity;
909 G4cout <<
"Default colour "
916 else if (command == fpCommandDefaultTextColour) {
919 std::istringstream iss(newValue);
920 iss >> redOrString >> green >> blue >> opacity;
927 G4cout <<
"Default colour "
934 else if (command == fpCommandEdge) {
937 switch (existingStyle) {
952 switch (existingStyle) {
967 G4cout <<
"Drawing style of viewer \"" << currentViewer->
GetName()
973 else if (command == fpCommandExplodeFactor) {
976 std::istringstream is (newValue);
977 is >> explodeFactor >> x >> y >> z >> unitString;
988 else if (command == fpCommandGlobalLineWidthScale) {
990 = fpCommandGlobalLineWidthScale->GetNewDoubleValue(newValue);
993 G4cout <<
"Global Line Width Scale changed to "
998 else if (command == fpCommandGlobalMarkerScale) {
1000 = fpCommandGlobalMarkerScale->GetNewDoubleValue(newValue);
1003 G4cout <<
"Global Marker Scale changed to "
1008 else if (command == fpCommandHiddenEdge) {
1011 switch (existingStyle) {
1027 switch (existingStyle) {
1043 G4cout <<
"Drawing style of viewer \"" << currentViewer->
GetName()
1049 else if (command == fpCommandHiddenMarker) {
1054 G4cout <<
"Markers will ";
1060 else if (command == fpCommandLightsMove) {
1061 if (newValue.find(
"cam") != G4String::npos)
1063 else if(newValue.find(
"obj") != G4String::npos)
1067 G4warn <<
"ERROR: \"" << newValue <<
"\" not recognised."
1068 " Looking for \"cam\" or \"obj\" in string." <<
G4endl;
1072 G4cout <<
"Lights move with ";
1074 G4cout <<
"camera (object appears to rotate).";
1075 else G4cout <<
"object (the viewer appears to be moving).";
1080 else if (command == fpCommandLightsThetaPhi) {
1083 G4double x = std::sin (theta) * std::cos (phi);
1084 G4double y = std::sin (theta) * std::sin (phi);
1089 G4cout <<
"Lights direction set to "
1095 else if (command == fpCommandLightsVector) {
1099 G4cout <<
"Lights direction set to "
1104 else if (command == fpCommandLineWidth) {
1111 else if (command == fpCommandLineSegments) {
1116 "Number of line segments per circle in polygon approximation is "
1121 else if (command == fpCommandNumberOfCloudPoints) {
1126 "Number of points to be used in cloud representation of volumes is "
1131 else if (command == fpCommandPicking) {
1136 else G4cout <<
"inhibited.";
1140 G4warn <<
"You may need to issue \"/vis/viewer/update\"."
1145 else if (command == fpCommandProjection) {
1147 const size_t iPos0 = 0;
1148 if (newValue[iPos0] ==
'o') {
1149 fieldHalfAngle = 0.;
1151 else if (newValue[iPos0] ==
'p') {
1154 std::istringstream is (newValue);
1155 is >> dummy >> fieldHalfAngle >> unit;
1157 if (fieldHalfAngle > 89.5 * deg || fieldHalfAngle <= 0.0) {
1160 "ERROR: Field half angle should be 0 < angle <= 89.5 degrees.";
1168 G4warn <<
"ERROR: \"" << newValue <<
"\" not recognised."
1169 " Looking for 'o' or 'p' first character." <<
G4endl;
1175 G4cout <<
"Projection style of viewer \"" << currentViewer->
GetName()
1177 if (fieldHalfAngle == 0.) {
1181 G4cout <<
"perspective\n with half angle " << fieldHalfAngle / deg
1188 else if (command == fpCommandRotationStyle) {
1190 if (newValue ==
"constrainUpDirection")
1192 else if (newValue ==
"freeRotation")
1196 G4warn <<
"ERROR: \"" << newValue <<
"\" not recognised." <<
G4endl;
1202 G4cout <<
"Rotation style of viewer \"" << currentViewer->
GetName()
1208 else if (command == fpCommandSectionPlane) {
1210 G4double x, y, z, nx, ny, nz, F = 1.;
1211 std::istringstream is (newValue);
1212 is >> choice >> x >> y >> z >> unit >> nx >> ny >> nz;
1213 G4int iSelector = -1;
1214 if (G4StrUtil::icompare(choice,
"off") == 0 ||
1216 if (G4StrUtil::icompare(choice,
"on") == 0 ||
1218 if (iSelector < 0) {
1220 G4warn <<
"Choice not recognised (on/true or off/false)." <<
G4endl;
1225 switch (iSelector) {
1231 x *= F; y *= F; z *= F;
1232 if (nx == 0. && ny == 0. && nz == 0.) {
1246 G4cout <<
"Section drawing is: ";
1249 G4cout <<
".\nSection plane is now: "
1255 else if (command == fpCommandSpecialMeshRendering) {
1258 G4cout <<
"Special mesh rendering";
1260 G4cout <<
" requested. Current option is \""
1265 G4cout <<
"selected volumes:";
1267 G4cout <<
"\n " << pvNameCopyNo.GetName();
1268 if (pvNameCopyNo.GetCopyNo() >= 0)
G4cout <<
':' << pvNameCopyNo.GetCopyNo();
1277 else if (command == fpCommandSpecialMeshRenderingOption) {
1279 if (newValue ==
"dots") {
1282 else if(newValue ==
"surfaces") {
1287 G4cout <<
"Special mesh rendering option set to \""
1293 else if (command == fpCommandSpecialMeshVolumes) {
1294 std::vector<G4ModelingParameters::PVNameCopyNo> requestedMeshes;
1295 if (newValue.empty()) {
1299 G4String::size_type iBegin, iEnd;
1300 iBegin = newValue.find_first_not_of(
' ');
1301 while (iBegin != G4String::npos) {
1302 iEnd = newValue.find_first_of(
' ',iBegin);
1303 if (iEnd == G4String::npos) {
1304 iEnd = newValue.length();
1306 const G4String& name(newValue.substr(iBegin,iEnd-iBegin));
1307 iBegin = newValue.find_first_not_of(
' ',iEnd);
1308 if (iBegin == G4String::npos) {
1311 "WARNING: G4VisCommandsViewerSet::SetNewValue: /vis/viewer/set/specialMeshVolumes"
1312 "\n A pair not found. (There should be an even number of parameters.)"
1313 "\n Command ignored."
1318 iEnd = newValue.find_first_of(
' ',iBegin);
1319 if (iEnd == G4String::npos) {
1320 iEnd = newValue.length();
1323 std::istringstream iss(newValue.substr(iBegin,iEnd-iBegin));
1324 if (!(iss >> copyNo)) {
1327 "WARNING: G4VisCommandsViewerSet::SetNewValue: /vis/viewer/set/specialMeshVolumes"
1328 "\n Error reading copy number - it was not numeric?"
1329 "\n Command ignored."
1335 iBegin = newValue.find_first_not_of(
' ',iEnd);
1342 "Special mesh list empty, which means \"all meshes\"."
1345 G4cout <<
"Selected special mesh volumes are:";
1347 G4cout <<
"\n " << pvNameCopyNo.GetName();
1348 if (pvNameCopyNo.GetCopyNo() >= 0)
G4cout <<
':' << pvNameCopyNo.GetCopyNo();
1355 else if (command == fpCommandStyle) {
1357 const size_t iPos0 = 0;
1358 if (newValue[iPos0] ==
'w') {
1359 switch (existingStyle) {
1375 else if (newValue[iPos0] ==
's') {
1376 switch (existingStyle) {
1392 else if (newValue[iPos0] ==
'c') {
1393 switch (existingStyle) {
1412 G4warn <<
"ERROR: \"" << newValue <<
"\" not recognised."
1413 " Looking for 'w' or 's' or 'c' first character." <<
G4endl;
1418 G4cout <<
"Drawing style of viewer \"" << currentViewer->
GetName()
1424 else if (command == fpCommandTargetPoint) {
1426 fpCommandTargetPoint->GetNew3VectorValue(newValue);
1431 G4cout <<
"Target point set to "
1432 << fpCommandTargetPoint->ConvertToStringWithBestUnit
1434 <<
"\n\"Current Target Point\" set to "
1435 << fpCommandTargetPoint->ConvertToStringWithBestUnit
1437 <<
"\n\"Standard Target Point\" is "
1438 << fpCommandTargetPoint->ConvertToStringWithBestUnit
1439 (standardTargetPoint)
1444 else if (command == fpCommandUpThetaPhi) {
1447 G4double x = std::sin (theta) * std::cos (phi);
1448 G4double y = std::sin (theta) * std::sin (phi);
1458 else if (command == fpCommandUpVector) {
1466 else if (command == fpCommandViewpointThetaPhi) {
1469 G4double x = std::sin (theta) * std::cos (phi);
1470 G4double y = std::sin (theta) * std::sin (phi);
1475 G4cout <<
"Viewpoint direction set to "
1478 G4cout <<
"Lightpoint direction set to "
1485 else if (command == fpCommandViewpointVector) {
1487 if (viewpointVector.
mag2() <= 0.) {
1489 G4warn <<
"ERROR: Null viewpoint vector. No action taken." <<
G4endl;
1492 fViewpointVector = viewpointVector.
unit();
1495 G4cout <<
"Viewpoint direction set to "
1498 G4cout <<
"Lightpoint direction set to "
1505 else if (command == fpCommandTimeWindowDisplayHeadTime)
1508 G4double screenX, screenY, screenSize, red, green, blue;
1509 std::istringstream iss(newValue);
1510 iss >> display >> screenX >> screenY
1511 >> screenSize >> red >> green >> blue;
1520 G4cout <<
"Display head time flag set: "
1526 else if (command == fpCommandTimeWindowDisplayLightFront)
1528 G4String display, originX, originY, originZ, unitS, originT, unitT;
1530 std::istringstream iss(newValue);
1532 >> originX >> originY >> originZ >> unitS
1534 >> red >> green >> blue;
1548 G4cout <<
"Display light front flag set: "
1554 else if (command == fpCommandTimeWindowEndTime)
1556 G4String end_time_string, end_time_unit,
1557 time_range_string, time_range_unit;
1558 std::istringstream iss(newValue);
1559 iss >> end_time_string >> end_time_unit
1560 >> time_range_string >> time_range_unit;
1563 (
G4String(end_time_string +
' ' + end_time_unit)));
1565 (
G4String(time_range_string +
' ' + time_range_unit));
1566 if (timeRange > 0.) {
1573 <<
", time window end time: " << vp.
GetEndTime()/
ns <<
" ns";
1574 if (timeRange > 0.) {
1575 G4cout <<
"\n (time range: " << timeRange/
ns <<
" ns)";
1581 else if (command == fpCommandTimeWindowFadeFactor) {
1589 else if (command == fpCommandTimeWindowStartTime)
1591 G4String start_time_string, start_time_unit,
1592 time_range_string, time_range_unit;
1593 std::istringstream iss(newValue);
1594 iss >> start_time_string >> start_time_unit
1595 >> time_range_string >> time_range_unit;
1598 (
G4String(start_time_string +
' ' + start_time_unit)));
1600 (
G4String(time_range_string +
' ' + time_range_unit));
1601 if (timeRange > 0.) {
1608 <<
", time window end time: " << vp.
GetEndTime()/
ns <<
" ns";
1609 if (timeRange > 0.) {
1610 G4cout <<
"\n (time range: " << timeRange/
ns <<
" ns)";
1619 "ERROR: G4VisCommandsViewerSet::SetNewValue: unrecognised command."