Geant4 11.3.0
Toolkit for the simulation of the passage of particles through matter
Loading...
Searching...
No Matches
G4VisCommands.cc
Go to the documentation of this file.
1//
2// ********************************************************************
3// * License and Disclaimer *
4// * *
5// * The Geant4 software is copyright of the Copyright Holders of *
6// * the Geant4 Collaboration. It is provided under the terms and *
7// * conditions of the Geant4 Software License, included in the file *
8// * LICENSE and available at http://cern.ch/geant4/license . These *
9// * include a list of copyright holders. *
10// * *
11// * Neither the authors of this software system, nor their employing *
12// * institutes,nor the agencies providing financial support for this *
13// * work make any representation or warranty, express or implied, *
14// * regarding this software system or assume any liability for its *
15// * use. Please see the license in the file LICENSE and URL above *
16// * for the full disclaimer and the limitation of liability. *
17// * *
18// * This code implementation is the result of the scientific and *
19// * technical work of the GEANT4 collaboration. *
20// * By using, copying, modifying or distributing the software (or *
21// * any work based on the software) you agree to acknowledge its *
22// * use in resulting scientific publications, and indicate your *
23// * acceptance of all terms of the Geant4 Software license. *
24// ********************************************************************
25//
26//
27
28// /vis/ top level commands - John Allison 5th February 2001
29
30#include "G4VisCommands.hh"
31
32#include "G4VisManager.hh"
33#include "G4UImanager.hh"
34#include "G4UIcmdWithABool.hh"
35#include "G4UIcmdWithAString.hh"
37#include "G4RunManager.hh"
39#include "G4Run.hh"
40#include "G4UIsession.hh"
41#include "G4Trajectory.hh"
42#include "G4TrajectoryPoint.hh"
43#include "G4RichTrajectory.hh"
45#include "G4SmoothTrajectory.hh"
48#include "G4AttDef.hh"
49
50#define G4warn G4cout
51
52////////////// /vis/abortReviewKeptEvents /////////////////////////////
53
55 G4bool omitable;
56
57 fpCommand = new G4UIcmdWithABool("/vis/abortReviewKeptEvents", this);
58 fpCommand -> SetGuidance("Abort review of kept events.");
59 fpCommand -> SetParameterName("abort", omitable=true);
60 fpCommand -> SetDefaultValue(true);
61}
62
66
70
72 G4String newValue) {
73 fpVisManager->SetAbortReviewKeptEvents(G4UIcommand::ConvertToBool(newValue));
74 G4warn << "Type \"continue\" to complete the abort." << G4endl;
75}
76
77////////////// /vis/abortReviewPlots /////////////////////////////
78
80 G4bool omitable;
81
82 fpCommand = new G4UIcmdWithABool("/vis/abortReviewPlots", this);
83 fpCommand -> SetGuidance("Abort review of plots.");
84 fpCommand -> SetParameterName("abort", omitable=true);
85 fpCommand -> SetDefaultValue(true);
86}
87
91
95
97 G4String newValue) {
98 fpVisManager->SetAbortReviewPlots(G4UIcommand::ConvertToBool(newValue));
99 G4warn << "Type \"continue\" to complete the abort." << G4endl;
100}
101
102////////////// /vis/drawOnlyToBeKeptEvents /////////////////////////////
103
105{
106 G4bool omitable;
107
108 fpCommand = new G4UIcmdWithABool("/vis/drawOnlyToBeKeptEvents", this);
109 fpCommand -> SetGuidance
110 ("DURING A RUN draw only those events that have been \"to be kept\" by the user"
111 "\nwith G4EventManager::GetEventManager()->KeepTheCurrentEvent() or"
112 "\nwith \"/event/keepCurrentEvent\".");
113 fpCommand -> SetGuidance(
114 "To draw selected events the user should set this flag, then in a user action:"
115 "\n if ( some criterion ) {"
116 "\n G4EventManager::GetEventManager()->KeepTheCurrentEvent();"
117 "\n }");
118 fpCommand -> SetParameterName("draw", omitable=true);
119 fpCommand -> SetDefaultValue(true);
120}
121
125
129
131 G4String newValue) {
132 fpVisManager->SetDrawEventOnlyIfToBeKept(G4UIcommand::ConvertToBool(newValue));
133 G4VisManager::Verbosity verbosity = fpVisManager->GetVerbosity();
134 if (verbosity < G4VisManager::warnings) {
135 if (fpVisManager->GetDrawEventOnlyIfToBeKept()) {
136 G4warn << "Only events that have been kept will be drawn." << G4endl;
137 } else {
138 G4warn << "All events will be drawn." << G4endl;
139 }
140 }
141}
142
143////////////// /vis/enable ///////////////////////////////////////
144
146 G4bool omitable;
147
148 fpCommand = new G4UIcmdWithABool("/vis/enable", this);
149 fpCommand -> SetGuidance("Enables/disables visualization system.");
150 fpCommand -> SetParameterName("enabled", omitable=true);
151 fpCommand -> SetDefaultValue(true);
152
153 fpCommand1 = new G4UIcmdWithoutParameter("/vis/disable", this);
154 fpCommand1 -> SetGuidance("Disables visualization system.");
155}
156
158 delete fpCommand;
159 delete fpCommand1;
160}
161
165
167 G4String newValue) {
168 if (command == fpCommand) {
169 G4bool enable = G4UIcommand::ConvertToBool(newValue);
170 if (enable) fpVisManager->Enable(); // Printing is in vis manager.
171 else fpVisManager->Disable(); // Printing is in vis manager.
172 } else fpVisManager->Disable(); // Printing is in vis manager.
173 // Note: Printing is in vis manager.
174}
175
176////////////// /vis/initialize ///////////////////////////////////////
177
179{
180 fpCommand = new G4UIcmdWithoutParameter("/vis/initialize", this);
181 fpCommand -> SetGuidance("Initialise visualisation manager.");
182}
183
187
192
193////////////// /vis/list ///////////////////////////////////////
194
196{
197 G4bool omitable;
198
199 fpCommand = new G4UIcmdWithAString("/vis/list", this);
200 fpCommand -> SetGuidance("Lists visualization parameters.");
201 fpCommand -> SetParameterName("verbosity", omitable=true);
202 fpCommand -> SetDefaultValue("warnings");
203}
204
206{
207 delete fpCommand;
208}
209
214
216{
217 G4VisManager::Verbosity verbosity = fpVisManager->GetVerbosityValue(newValue);
218
220 G4cout << G4endl;
221 fpVisManager->PrintAvailableGraphicsSystems(verbosity);
222 G4cout << G4endl;
223 fpVisManager->PrintAvailableModels(verbosity);
224 G4cout << G4endl;
225 fpVisManager->PrintAvailableUserVisActions(verbosity);
226 G4cout << G4endl;
227 fpVisManager->PrintAvailableColours(verbosity);
228 G4cout << G4endl;
230 UImanager->ApplyCommand("/vis/scene/list ! " + newValue);
231 G4cout << G4endl;
232 UImanager->ApplyCommand("/vis/viewer/list ! " + newValue);
233
234 G4cout <<
235 "\nAttributes available for modeling and filtering with"
236 "\n \"/vis/modeling/trajectories/create/drawByAttribute\" and"
237 "\n \"/vis/filtering/trajectories/create/attributeFilter\" commands"
238 "\nand by picking:"
239 << G4endl;
240 G4cout
242 G4cout
245 G4cout
248 G4cout
251
252 G4cout <<
253 "\nGeometry attributes available for touchables by picking:\n";
254 G4cout
256
257 if (verbosity < G4VisManager::parameters)
258 G4cout <<
259 "\nTo get more information, \"/vis/list all\" or use individual commands"
260 "\n such as (use \"ls\" or \"help\"):"
261 "\n /vis/scene/list all all"
262 "\n /vis/viewer/list all all"
263 "\n /vis/modeling/trajectories/list"
264 "\n /vis/filtering/trajectories/list"
265 << G4endl;
266}
267
268////////////// /vis/reviewKeptEvents ///////////////////////////////////////
269
271{
272 G4bool omitable;
273
274 fpCommand = new G4UIcmdWithAString("/vis/reviewKeptEvents", this);
275 fpCommand -> SetGuidance("Review kept events.");
276 fpCommand -> SetGuidance
277 ("If a macro file is specified, it is executed for each event.");
278 fpCommand -> SetGuidance(
279 "If a macro file is not specified, each event is drawn to the current"
280 "\nviewer. After each event, the session is paused. The user may issue"
281 "\nany allowed command. Then enter \"cont[inue]\" to continue to the next"
282 "\nevent."
283 "\nUseful commands might be:"
284 "\n \"/vis/viewer/...\" to change the view (zoom, set/viewpoint,...)."
285 "\n \"/vis/ogl/export\" to get hard copy."
286 "\n \"/vis/open\" to get alternative viewer."
287 "\n \"/vis/abortReviewKeptEvents\", then \"cont[inue]\", to abort.");
288 fpCommand -> SetParameterName("macro-file-name", omitable=true);
289 fpCommand -> SetDefaultValue("");
290}
291
296
301
303{
304 if (fpVisManager->GetReviewingKeptEvents()) {
305 G4warn <<
306 "\"/vis/reviewKeptEvents\" not allowed within an already started review."
307 "\n No action taken."
308 << G4endl;
309 return;
310 }
311
312 G4String& macroFileName = newValue;
313 G4VisManager::Verbosity verbosity = fpVisManager->GetVerbosity();
314
316 const G4Run* run = runManager ? runManager->GetCurrentRun() : nullptr;
317 const std::vector<const G4Event*>* events =
318 run ? run->GetEventVector() : nullptr;
319 size_t nKeptEvents = events ? events->size() : 0;
320
321 if (!nKeptEvents) {
322 if (verbosity >= G4VisManager::errors) {
323 G4warn <<
324 "ERROR: G4VisCommandReviewKeptEvents::SetNewValue: No kept events,"
325 "\n or kept events not accessible."
326 << G4endl;
327 }
328 return;
329 }
330
331 G4VViewer* viewer = fpVisManager->GetCurrentViewer();
332 if (!viewer) {
333 if (verbosity >= G4VisManager::errors) {
334 G4warn <<
335 "ERROR: No current viewer - \"/vis/viewer/list\" to see possibilities."
336 << G4endl;
337 }
338 return;
339 }
340
341 G4Scene* pScene = fpVisManager->GetCurrentScene();
342 if (!pScene) {
343 if (verbosity >= G4VisManager::errors) {
344 G4warn << "ERROR: No current scene. Please create one." << G4endl;
345 }
346 return;
347 }
348
350 G4int keepControlVerbose = UImanager->GetVerboseLevel();
351 G4int newVerbose(0);
352 if (keepControlVerbose >= 2 || verbosity >= G4VisManager::confirmations)
353 newVerbose = 2;
354 UImanager->SetVerboseLevel(newVerbose);
355
356 G4VVisManager* keepConcreteInstance = fpVisManager->GetConcreteInstance();
357 fpVisManager->Enable();
358
359 // Start on clean view
360 UImanager->ApplyCommand("/vis/viewer/rebuild");
361
362 // Event by event refreshing...
363 fpVisManager->SetReviewingKeptEvents(true);
364 G4bool currentRefreshAtEndOfEvent = pScene->GetRefreshAtEndOfEvent();
365 pScene->SetRefreshAtEndOfEvent(true);
366 if (macroFileName.empty()) {
367
368 // Draw to viewer and pause session...
369 G4UIsession* session = UImanager->GetSession();
370 for (size_t i = 0; i < nKeptEvents; ++i) {
371 const G4Event* event = (*events)[i];
372 if (verbosity >= G4VisManager::warnings) {
373 G4warn << "Drawing event : " << event->GetEventID() <<
374 ". At EndOfEvent, enter any command, then \"cont[inue]\"..."
375 << G4endl;
376 static G4bool first = true;
377 if (first) {
378 first = false;
379 G4warn <<
380 " Useful commands might be:"
381 "\n \"/vis/scene/add/trajectories\" if not already added."
382 "\n \"/vis/viewer/...\" to change the view (zoom, set/viewpoint,...)."
383 "\n \"/vis/ogl/export\" to get hard copy."
384 "\n \"/vis/open\" to get alternative viewer."
385 "\n \"/vis/abortReviewKeptEvents\", then \"cont[inue]\", to abort."
386 << G4endl;
387 }
388 }
389 fpVisManager->SetRequestedEvent(event);
390 UImanager->ApplyCommand("/vis/viewer/rebuild");
391 /* The above command forces a rebuild of the scene, including
392 the detector. This is fine for "immediate" viewers - a
393 refresh requires a rebuild anyway. But for "stored mode"
394 viewers, you could, in principle, avoid a rebuild of the
395 detector with something like the following:
396 sceneHandler->ClearTransientStore();
397 viewer->DrawView();
398 sceneHandler->DrawEvent(event);
399 but this causes mayhem for "immediate" viewers because
400 ClearTransientStore issues a DrawView and some curious sort
401 of recursion takes place. For "stored" viewers, the event
402 gets drawn but not the eventID, so something odd is happening
403 there too. This needs further investigation - enhanced
404 features or a complete re-think.
405 */
406 UImanager->ApplyCommand("/vis/viewer/flush");
407 session->PauseSessionStart("EndOfEvent");
408 fpVisManager->SetRequestedEvent(0);
409 if (fpVisManager->GetAbortReviewKeptEvents()) break;
410 }
411 fpVisManager->SetAbortReviewKeptEvents(false);
412
413 } else {
414
415 // Execute macro file...
416 for (size_t i = 0; i < nKeptEvents; ++i) {
417 const G4Event* event = (*events)[i];
418 if (verbosity >= G4VisManager::warnings) {
419 G4warn << "Drawing event : " << event->GetEventID()
420 << " with macro file \"" << macroFileName << G4endl;
421 }
422 fpVisManager->SetRequestedEvent(event);
423 UImanager->ApplyCommand("/control/execute " + macroFileName);
424 fpVisManager->SetRequestedEvent(0);
425 }
426 }
427 pScene->SetRefreshAtEndOfEvent(currentRefreshAtEndOfEvent);
428 fpVisManager->SetReviewingKeptEvents(false);
429
430 if (keepConcreteInstance) fpVisManager->Enable();
431 else fpVisManager->Disable();
432 UImanager->SetVerboseLevel(keepControlVerbose);
433}
434
435////////////// /vis/reviewPlots ///////////////////////////////////////
436
438{
439 fpCommand = new G4UIcmdWithoutParameter("/vis/reviewPlots", this);
440 fpCommand -> SetGuidance("Review plots.");
441 fpCommand -> SetGuidance
442 ("Each plot is drawn, one by one, to the current viewer. After each"
443 "\nplot the session is paused. The user may issue any allowed command."
444 "\nThen enter \"cont[inue]\" to continue to the next plot."
445 "\nUseful commands might be:"
446 "\n \"/vis/tsg/export\" to get hard copy."
447 "\n \"/vis/abortReviewPlots\", then \"cont[inue]\", to abort.");
448}
449
451{
452 delete fpCommand;
453}
454
459
460#include <tools/histo/h1d>
461#include <tools/histo/h2d>
462
463namespace {
464 template <typename HT> // tools::histo::h1d, etc
465 G4bool ReviewPlots(const G4String& plotType) { // h1, etc.
466 auto visManager = G4VisManager::GetInstance();
467 auto ui = G4UImanager::GetUIpointer();
468 auto session = ui->GetSession();
469 G4bool aborting = false;
470 auto keepControlVerbose = ui->GetVerboseLevel();
471 ui->SetVerboseLevel(0);
472 auto status = ui->ApplyCommand("/analysis/" + plotType + "/getVector");
473 ui->SetVerboseLevel(keepControlVerbose);
475 G4String hexString = ui->GetCurrentValues(G4String("/analysis/" + plotType + "/getVector"));
476 if(hexString.size()) {
477 void* ptr;
478 std::istringstream is(hexString);
479 is >> ptr;
480 auto _v = (const std::vector<HT*>*)ptr;
481 auto _n = _v->size();
482 for (size_t i = 0; i < _n; ++i) {
483 // Draw then pause session...
484 std::ostringstream oss;
485 oss << "/vis/plot " << plotType << ' ' << i;
486 ui->ApplyCommand(oss.str());
487 session->PauseSessionStart("EndOfEvent");
488 if (visManager->GetAbortReviewPlots()) {
489 aborting = true;
490 break;
491 }
492 }
493 }
494 }
495 return aborting;
496 }
497}
498
500{
501 if (fpVisManager->GetReviewingPlots()) {
502 G4warn <<
503 "\"/vis/reviewPlots\" not allowed within an already started review."
504 "\n No action taken."
505 << G4endl;
506 return;
507 }
508
509 auto verbosity = fpVisManager->GetVerbosity();
510
511 auto currentViewer = fpVisManager->GetCurrentViewer();
512 if (!currentViewer) {
513 if (verbosity >= G4VisManager::errors) {
514 G4warn <<
515 "ERROR: No current viewer - \"/vis/viewer/list\" to see possibilities."
516 << G4endl;
517 }
518 return;
519 }
520
521 if (currentViewer->GetName().find("TOOLSSG") == std::string::npos) {
522 G4warn <<
523 "WARNING: Current viewer not able to draw plots."
524 "\n Try \"/vis/open TSG\", then \"/vis/reviewPlots\" again."
525 << G4endl;
526 return;
527 }
528
529 G4Scene* pScene = fpVisManager->GetCurrentScene();
530 if (!pScene) {
531 if (verbosity >= G4VisManager::errors) {
532 G4warn << "ERROR: No current scene. Please create one." << G4endl;
533 }
534 return;
535 }
536
537 auto ui = G4UImanager::GetUIpointer();
538
539 auto keepControlVerbose = ui->GetVerboseLevel();
540 ui->SetVerboseLevel(0);
541 auto keepVisVerbose = fpVisManager->GetVerbosity();
542 fpVisManager->SetVerboseLevel(G4VisManager::errors);
543 auto keepEnable = fpVisManager->IsEnabled();
544 fpVisManager->Enable();
545 fpVisManager->SetReviewingPlots(true);
546
547 if (ReviewPlots<tools::histo::h1d>("h1")) goto finish; // Aborting?
548 if (ReviewPlots<tools::histo::h2d>("h2")) goto finish; // Aborting?
549
550finish:
551 fpVisManager->SetReviewingPlots(false);
552 if (!keepEnable) fpVisManager->Disable();
553 fpVisManager->SetVerboseLevel(keepVisVerbose);
554 ui->SetVerboseLevel(keepControlVerbose);
555}
556
557////////////// /vis/verbose ///////////////////////////////////////
558
560 G4bool omitable;
561
562 fpCommand = new G4UIcmdWithAString("/vis/verbose", this);
563 for (size_t i = 0; i < G4VisManager::VerbosityGuidanceStrings.size(); ++i) {
564 fpCommand -> SetGuidance(G4VisManager::VerbosityGuidanceStrings[i]);
565 }
566 fpCommand -> SetParameterName("verbosity", omitable=true);
567 fpCommand -> SetDefaultValue("");
568}
569
571 delete fpCommand;
572}
573
577
579 G4String newValue) {
580 G4VisManager::Verbosity verbosity =
581 fpVisManager->GetVerbosityValue(newValue);
582 fpVisManager->SetVerboseLevel(verbosity);
583 // Always prints whatever the verbosity...
584 G4cout << "Visualization verbosity is now "
585 << G4VisManager::VerbosityString(verbosity) << G4endl;
586}
#define G4warn
Definition G4Scene.cc:41
bool G4bool
Definition G4Types.hh:86
int G4int
Definition G4Types.hh:85
@ fCommandSucceeded
#define G4endl
Definition G4ios.hh:67
G4GLOB_DLL std::ostream G4cout
const std::map< G4String, G4AttDef > * GetAttDefs() const
const std::map< G4String, G4AttDef > * GetAttDefs() const override
const std::map< G4String, G4AttDef > * GetAttDefs() const override
static G4RunManager * GetMasterRunManager()
const G4Run * GetCurrentRun() const
Definition G4Run.hh:48
std::vector< const G4Event * > * GetEventVector() const
Definition G4Run.hh:100
G4bool GetRefreshAtEndOfEvent() const
void SetRefreshAtEndOfEvent(G4bool)
const std::map< G4String, G4AttDef > * GetAttDefs() const override
const std::map< G4String, G4AttDef > * GetAttDefs() const override
const std::map< G4String, G4AttDef > * GetAttDefs() const
const std::map< G4String, G4AttDef > * GetAttDefs() const override
const std::map< G4String, G4AttDef > * GetAttDefs() const override
static G4bool ConvertToBool(const char *st)
G4int ApplyCommand(const char *aCommand)
G4int GetVerboseLevel() const
G4UIsession * GetSession() const
static G4UImanager * GetUIpointer()
void SetVerboseLevel(G4int val)
static G4VisManager * fpVisManager
void SetNewValue(G4UIcommand *command, G4String newValue)
G4String GetCurrentValue(G4UIcommand *command)
void SetNewValue(G4UIcommand *command, G4String newValue)
G4String GetCurrentValue(G4UIcommand *command)
void SetNewValue(G4UIcommand *command, G4String newValue)
G4String GetCurrentValue(G4UIcommand *command)
virtual ~G4VisCommandEnable()
G4String GetCurrentValue(G4UIcommand *command)
void SetNewValue(G4UIcommand *command, G4String newValue)
void SetNewValue(G4UIcommand *command, G4String newValue)
void SetNewValue(G4UIcommand *command, G4String newValue)
G4String GetCurrentValue(G4UIcommand *command)
virtual ~G4VisCommandList()
void SetNewValue(G4UIcommand *command, G4String newValue)
G4String GetCurrentValue(G4UIcommand *command)
void SetNewValue(G4UIcommand *command, G4String newValue)
G4String GetCurrentValue(G4UIcommand *command)
void SetNewValue(G4UIcommand *command, G4String newValue)
G4String GetCurrentValue(G4UIcommand *command)
virtual ~G4VisCommandVerbose()
static std::vector< G4String > VerbosityGuidanceStrings
static G4String VerbosityString(Verbosity)
static void PrintAvailableVerbosity(std::ostream &os)
static G4VisManager * GetInstance()