45#include <qapplication.h>
52#include <qmessagebox.h>
53#include <qpushbutton.h>
54#include <qscrollbar.h>
56#include <qtextbrowser.h>
61#include <qboxlayout.h>
62#include <qbuttongroup.h>
63#include <qcolordialog.h>
65#include <qcompleter.h>
66#include <qfiledialog.h>
68#include <qheaderview.h>
69#include <qlistwidget.h>
70#include <qmainwindow.h>
73#include <qradiobutton.h>
74#include <qscrollarea.h>
75#include <qstandarditemmodel.h>
76#include <qstringlist.h>
78#include <qtablewidget.h>
79#include <qtabwidget.h>
80#include <qtextstream.h>
84#include <QInputDialog>
91# include "moc_G4UIQt.cpp"
95static G4bool exitSession =
true;
96static G4bool exitPause =
true;
119 : fMainWindow(nullptr),
120 fCommandLabel(nullptr),
121 fCommandArea(nullptr),
122 fCoutTBTextArea(nullptr),
123 fUITabWidget(nullptr),
124 fCoutFilter(nullptr),
127 fHistoryTBTableList(nullptr),
128 fHelpTreeWidget(nullptr),
129 fHelpTBWidget(nullptr),
130 fHistoryTBWidget(nullptr),
131 fCoutDockWidget(nullptr),
132 fUIDockWidget(nullptr),
133 fSceneTreeWidget(nullptr),
134 fNewSceneTreeWidget(nullptr),
135 fNewSceneTreeItemTreeWidget(nullptr),
136 fViewerPropertiesWidget(nullptr),
137 fPickInfosWidget(nullptr),
139 fViewerTabWidget(nullptr),
142 fHelpVSplitter(nullptr),
143 fParameterHelpLabel(nullptr),
144 fParameterHelpTable(nullptr),
145 fToolbarApp(nullptr),
146 fToolbarUser(nullptr),
147 fStringSeparator(
"__$$$@%%###__"),
149 fSearchIcon(nullptr),
154 fRotateIcon(nullptr),
156 fZoomInIcon(nullptr),
157 fZoomOutIcon(nullptr),
158 fWireframeIcon(nullptr),
160 fHiddenLineRemovalIcon(nullptr),
161 fHiddenLineAndSurfaceRemovalIcon(nullptr),
162 fPerspectiveIcon(nullptr),
164 fCommandIcon(nullptr),
168 fPickTargetIcon(nullptr),
170#ifdef G4MULTITHREADED
172 fThreadsFilterComboBox(nullptr)
175 fDefaultViewerFirstPageHTMLText(
""),
176 fViewerPropertiesDialog(nullptr),
177 fPickInfosDialog(nullptr),
178 fLastCompleteCommand(
""),
179 fMoveSelected(false),
180 fRotateSelected(true),
181 fPickSelected(false),
182 fZoomInSelected(false),
183 fZoomOutSelected(false)
191 G4cout <<
"G4UIQt : Unable to init Qt. Aborted" <<
G4endl;
201 Q_FOREACH (QWidget* widget, QApplication::allWidgets()) {
202 if ((!found) && (widget->inherits(
"QMainWindow"))) {
212 G4cout <<
"G4UIQt : Found an external App with a QMainWindow already defined. Aborted"
219 fMainWindow =
new QMainWindow();
220 fMainWindow->setAttribute(Qt::WA_DeleteOnClose);
222 fMainWindow->setCorner(Qt::TopLeftCorner, Qt::LeftDockWidgetArea);
223 fMainWindow->setCorner(Qt::TopRightCorner, Qt::RightDockWidgetArea);
224 fMainWindow->setCorner(Qt::BottomLeftCorner, Qt::LeftDockWidgetArea);
225 fMainWindow->setCorner(Qt::BottomRightCorner, Qt::RightDockWidgetArea);
227 CreateViewerWidget();
228 fMainWindow->addDockWidget(Qt::LeftDockWidgetArea, CreateUITabWidget());
229 fMainWindow->addDockWidget(Qt::BottomDockWidgetArea, CreateCoutTBWidget());
232 fNewSceneTreeWidget =
new QWidget;
233 fNewSceneTreeWidget->setStyleSheet (
"padding: 0px ");
234 fNewSceneTreeWidget->setLayout(
new QVBoxLayout);
235 fNewSceneTreeWidget->layout()->setContentsMargins(5,5,5,5);
236 fNewSceneTreeWidget->setWindowTitle(
"some name");
238 fSceneTreeWidget->layout()->addWidget(fNewSceneTreeWidget);
239 CreateNewSceneTreeWidget();
242 SetDefaultIconsToolbar();
246#ifdef G4MULTITHREADED
251 fMainWindow->setWindowTitle(QFileInfo(QCoreApplication::applicationFilePath()).fileName());
252 fMainWindow->move(QPoint(50, 50));
257 fMainWindow->resize(fUIDockWidget->width() + fCoutDockWidget->width() + 20,
258 fUIDockWidget->height() + fCoutDockWidget->height() + 20);
261 fCommandArea->setFocus(Qt::TabFocusReason);
265 qRegisterMetaType<QTextCursor>(
"QTextCursor");
271 fMainWindow->setVisible(
false);
281#ifdef G4MULTITHREADED
289 fDefaultIcons = aVal;
291 if (! fMainWindow->isVisible()) {
295 if (fToolbarApp !=
nullptr) {
297 fToolbarApp->setVisible(
true);
301 fToolbarApp->setVisible(
false);
306void G4UIQt::SetDefaultIconsToolbar()
309 if (fToolbarApp ==
nullptr) {
310 fToolbarApp =
new QToolBar();
311 fToolbarApp->setIconSize(QSize(20, 20));
312 fMainWindow->addToolBar(Qt::TopToolBarArea, fToolbarApp);
316 AddIcon(
"Open macro file",
"open",
"/control/execute");
317 AddIcon(
"Save viewer state",
"save",
"/vis/viewer/save");
320 fToolbarApp->addAction(QIcon(*fParamIcon),
"Viewer properties",
this,
321 [
this]() { this->ViewerPropertiesIconCallback(0); });
326 AddIcon(
"Zoom out",
"zoom_out",
"");
327 AddIcon(
"Zoom in",
"zoom_in",
"");
328 AddIcon(
"Rotate",
"rotate",
"");
331 AddIcon(
"Hidden line removal",
"hidden_line_removal",
"");
332 AddIcon(
"Hidden line and hidden surface removal",
"hidden_line_and_surface_removal",
"");
333 AddIcon(
"Surfaces",
"solid",
"");
334 AddIcon(
"Wireframe",
"wireframe",
"");
337 AddIcon(
"Perspective",
"perspective",
"");
338 AddIcon(
"Orthographic",
"ortho",
"");
339 AddIcon(
"Run beam on",
"runBeamOn",
"/run/beamOn 1");
340 AddIcon(
"Exit Application",
"exit",
"exit");
345void G4UIQt::CreateIcons()
347 const char *
const save[]={
375 " +++++++++++++++++++++++++ ",
376 " +@##+$%%%%%%%%%%%%%%%&*$%&+ ",
377 " +=-;@>,,''',,,,,,,',,)&!,)+ ",
378 " +;-~@>,,,,,,,,,,,,,,,>$!,)+ ",
379 " +=-~@>,,,,,{]]]]]^,,,>*&$&+ ",
380 " +=-~@>,,,,,'{^{^^{,,,>*#=#+ ",
381 " +=-~@>,,,,,,,,,,,,,,,>@~/=+ ",
382 " +=-~@>,,,{{{''''{',,,>@~-=+ ",
383 " +=-~@>,,'^]]]]]]({,,,>@~-=+ ",
384 " +=-~@>,,,{{{{{{{{{,,,>@~-=+ ",
385 " +=-~@>,,,,,'{^{{^{,,,>@~-=+ ",
386 " +=-~@>,,,,,]]]]]]],,,>@~-=+ ",
387 " +=-~*>,,,,,,,,,,,,,,,>@~-=+ ",
388 " +=-~@>,,,,,,,,,,,,,,,>@~-=+ ",
389 " +=-/=$%%%%%%%%%%%%%%%$=/-=+ ",
390 " +=---;###############;---=+ ",
391 " +=---////////////////----=+ ",
392 " +=----------------///----=+ ",
393 " +=---=@##############@#--=+ ",
394 " +=---@+++++++++++*%))_+~-=+ ",
395 " +=---#+++++++++++&:,,>@~-=+ ",
396 " +=---#+++++++++++$',,>@~-=+ ",
397 " +=---#+++++++++++&!,,>@~-=+ ",
398 " +=/--#+++++++++++&',,>@~-=+ ",
399 " @;--#+++++++++++$',,>@~-=+ ",
400 " @;;@+++++++++++*)!>%@=;#+ ",
401 " @++++++++++++++*&**++@++ ",
406 fSaveIcon =
new QPixmap(save);
408 const char *
const search[] = {
420 "OOOOOOOOOOOOOOOOOOO",
421 "OOOOOOOOOOOOOOOOOOO",
422 "OOOOOOOo. .oOOOOOO",
425 "OOOOO. XOOOOX .OOOO",
428 "OOOOO. XOOOOo .OOOO",
432 "OOOOOOOOOOOOO. XOO",
433 "OOOOOOOOOOOOOO. XOO",
434 "OOOOOOOOOOOOOOOoOOO",
435 "OOOOOOOOOOOOOOOOOOO",
436 "OOOOOOOOOOOOOOOOOOO",
437 "OOOOOOOOOOOOOOOOOOO",
438 "OOOOOOOOOOOOOOOOOOO"
440 fSearchIcon =
new QPixmap(search);
442 const char *
const clear[] = {
454 "OOOOOOOOOOOOOOOOOOOO",
457 "OOOOOOOOOOOOOOOOOOOO",
458 "OOOOOOOOOOOOOOOOOOOO",
459 "OOOO XXXXXXXXXX OOOO",
460 "OOO XOOOOOOOOOO OOO",
461 "OOOOXOooOooOooO OOOO",
462 "OOOOXOooOooOooO OOOO",
463 "OOOOXOooOooOooO OOOO",
464 "OOOOXOooOooOooO OOOO",
465 "OOOOXOooOooOooO OOOO",
466 "OOOOXOooOooOooO OOOO",
467 "OOOOXOooOooOooO OOOO",
468 "OOOOXOooOooOooO OOOO",
469 "OOOOXOooOooOooO OOOO",
470 "OOOOXOooOooOooO OOOO",
471 "OOOOXOOOOOOOOOO OOOO",
472 "OOOOOooooooooooOOOOO",
473 "OOOOOO........OOOOOO"
476 fClearIcon =
new QPixmap(clear);
479 const char *
const open[]={
523 " {]^/((_({- %%%%%%%%%%% ",
524 " {(^_^^^^:<{{{{{{{{{{{{{[& ",
525 " {/_/(((((/]]]]]]]]]]]/]!# ",
526 " {/^(((((_^^^^^^^^^^^^^^:# ",
527 " {/^(((_^^____________^^}$ ",
528 " {/^(((((/////////////((!# ",
529 " {/^/^_:<|||||||||||||||@@****1 ",
530 " {/^/^(<[)||||||||||||||))!!}<; ",
531 " {/^_(:|234444444444444444432)1 ",
532 " {/_^/<)34444444444444444443}, ",
533 " {/^(2{:41111111111111111142|5 ",
534 " {3^3<:31111111111111111143}- ",
535 " {/^2<:31111111111111111441|' ",
536 " {_/<:41111111111111111143}, ",
537 " {(4<:31111111111111111144!# ",
538 " )4))44111111111111111144}, ",
539 " )2<:31111111111111111144{# ",
540 " @|:14444444444444444444}* ",
541 " ;@434444444444444444434<# ",
542 " ;[))))))))))))))))))))!~ ",
543 " ++++++++++++++++++++++;% ",
547 fOpenIcon =
new QPixmap(open);
550 const char *
const move[]={
583 " ')&$$$$*@@ @@*$$$$&)' ",
584 " ')&$$$$*@@ @@*$$$$&+' ",
601 fMoveIcon =
new QPixmap(move);
603 const char *
const rotate[]={
639 " --------!*{{{*&, ",
640 " -------=){*{{{>>{) ",
641 " ,!-----= ){& ,&{{@",
649 " !-!!======!!(((---! ",
650 " ='--------------! ",
665 fRotateIcon =
new QPixmap(rotate);
667 const char *
const pick[]={
683 "*********oo*********",
684 "*********oo*********",
685 "******$O. .O%******",
686 "****&o .O..O O*****",
687 "***&X @**oo**@ X****",
688 "***o $***oo***$ O***",
689 "**% @**********@ %**",
690 "**O.***********& +**",
691 "**.O*****@@*****o.**",
692 "oo .oo**@ #*&XX. oo",
693 "oo .oo**@ #*&oo. oO",
694 "**.O*****##*****oX**",
695 "**O ***********& +**",
696 "**% @****&&****+ &**",
697 "***O $***Xo***# +***",
698 "****X @&*Xo*&+ o****",
699 "*****O o..o +*****",
700 "******%+. X+&******",
701 "*********oo*********",
702 "*********oO*********"
704 fPickIcon =
new QPixmap(pick);
706 const char *
const zoom_in[]={
728 " ++.%%%+&&&*%%.++ ",
729 " .+#%%%%+&&&*%%.#+ ",
730 " ++..%%%+&&&*%%%.++ ",
731 " +#.+++++&&&*++++.+ ",
732 " @.+&&&&&&&&&&&&&+@ ",
733 " @#+&&&&&&&&&&&&&+@ ",
734 " @.+&&&&&&&&&&&&&+. ",
735 " +++@***+&&&****@+. ",
736 " ....++++&&&*++++.. ",
737 " ++.===+&&&*%=.++ ",
738 " @..==+&&&*=..@#& ",
739 " .@+#.+&&&@-+@@*@ ",
752 fZoomInIcon =
new QPixmap(zoom_in);
754 const char *
const zoom_out[]={
776 " ++.$$$$$$$$$$.++ ",
777 " .+#$$$$$$$$$$$.#+ ",
778 " ++..$$$$$$$$$$$.++ ",
779 " +#.+++++++++++++.+ ",
780 " @.+&&&&&&&&&&&&&+@ ",
781 " @#+&&&&&&&&&&&&&+@ ",
782 " @.+&&&&&&&&&&&&&+. ",
783 " +++@***********@+. ",
784 " ....++++++++++++.. ",
785 " ++.===$$$$$$=.++ ",
786 " @..===$$$$=..@#& ",
787 " .@+#.$$$..-+@@*@ ",
800 fZoomOutIcon =
new QPixmap(zoom_out);
802 const char *
const wireframe[]={
831 " +&********&@-***; ",
832 " +@@@&**&@@@@@@$ @*-&>&+ ",
833 " +*****&+ %*@ ,**'# ",
834 " @***)!~ @*{&*****+ ",
835 " @*!]***&+ +-*^**'~!*@ ",
836 " @*~ +@&**&@@@@@@&****&+ ~*@ ",
837 " @*@ +&********&-*= @*@ ",
838 " @*@ $%@-*-@$ @*@ @*@ ",
846 " @*@ =*-+ @*@ @*@ ",
847 " @*@ $%@@&****&@-*-+ @*@ ",
848 " @*@ $@&*****&@@&******&~~!*@ ",
849 " @*{/***&@@%$ $@-*-&*****+ ",
850 " @*)*)(-~ @*@ ~)**] ",
851 " +*******&@@@@+ %*_+]**] ",
852 " +@@@@@&******&@%+_*^**]# ",
861 fWireframeIcon =
new QPixmap(wireframe);
863 const char *
const solid[]={
901 " +-;>>>>>>>>>,')!~ ",
902 " {]@@-;>>>>>>>>>>>>^/(_= ",
903 " {:>>>>>>>>>>>>>>>>><//[)!= ",
904 " ]>>>>>>>>>>>>>>>>>><////[)} ",
905 " @>>>>>>>>>>>>>>>>>><//////| ",
906 " @>>>>>>>>>>>>>>>>>><//////| ",
907 " @>>>>>>>>>>>>>>>>>><//////| ",
908 " @>>>>>>>>>>>>>>>>>><//////| ",
909 " @>>>>>>>>>>>>>>>>>><//////| ",
910 " @>>>>>>>>>>>>>>>>>><//////| ",
911 " @>>>>>>>>>>>>>>>>>><//////| ",
912 " @>>>>>>>>>>>>>>>>>><//////| ",
913 " @>>>>>>>>>>>>>>>>>><//////| ",
914 " @>>>>>>>>>>>>>>>>>><//////| ",
915 " @>>>>>>>>>>>>>>>>>><//////| ",
916 " @>>>>>>>>>>>>>>>>>><//////| ",
917 " @>>>>>>>>>>>>>>>>>><//////| ",
918 " @>>>>>>>>>>>>>>>>>><//////| ",
919 " @>>>>>>>>>>>>>>>>>></////[1 ",
920 " @>>>>>>>>>>>>>>>>>><////[*2 ",
921 " {:>>>>>>>>>>>>>>>>><//[)12 ",
922 " +@@@@@-;>>>>>>>>>><[)13 ",
931 fSolidIcon =
new QPixmap(solid);
933 const char *
const hidden_line_removal[]={
953 " +#$$$$$$$$#@&$$$* ",
954 " =-@@#$$#@@@@@-= @$&#;>= ",
955 " =$$$$$#+ -$@ *$$%+ ",
956 " -$&@-= -$- #$$$= ",
972 " -$&@@@-= -$- =>;, ",
973 " =$$$$$$$#@@@-= -$'+#$$, ",
974 " =-@@@@#$$$$$$#@-+'$)$$#+ ",
983 fHiddenLineRemovalIcon =
new QPixmap(hidden_line_removal);
985 const char *
const hidden_line_and_surface_removal[]={
1031 " ++@%####&*=-#+;>, ",
1032 " +++++@'=)))))))!)~+{]^++ ",
1033 " +$%&*=)!!!!!!!!!)~+/(]_+++ ",
1034 " +#-))!!!!!!!!!!!)~+/(::<[+ ",
1035 " +#)!!!!!!!!!!!!!!}+/::::{+ ",
1036 " +#)!!!!!!!!!!!!!!}+/::::{+ ",
1037 " +#)!!!!!!!!!!!!!!}+/::::{+ ",
1038 " +#)!!!!!!!!!!!!!!}+/::::{+ ",
1039 " +#)!!!!!!!!!!!!!!}+/::::{+ ",
1040 " +#)!!!!!!!!!!!!!!}+/::::{+ ",
1041 " +#)!!!!!!!!!!!!!!}+/::::{+ ",
1042 " +#)!!!!!!!!!!!!!!}+/::::{+ ",
1043 " +#)!!!!!!!!!!!!!!}+/::::{+ ",
1044 " +#)!!!!!!!!!!!!!!}+/::::{+ ",
1045 " +#)!!!!!!!!!!!!!!}+/::::{+ ",
1046 " +#)!!!!!!!!!!!!!!}+/::::{+ ",
1047 " +#)!!!!!!!!!!!!!!}+/::::{+ ",
1048 " +#)!!!!!!!!!!!!!!}+/:::|1+ ",
1049 " +$#}}~23!!!!!!!!)~+/(]45, ",
1050 " +++++++@#}}~23!!)~+678++ ",
1051 " ++++++@#~90+a++ ",
1060 fHiddenLineAndSurfaceRemovalIcon =
new QPixmap(hidden_line_and_surface_removal);
1062 const char *
const perspective[]={
1072 " ................ ",
1073 " ....+++++++++++++++. ",
1074 " ...++++..+.........+++. ",
1075 " ..++..............++..+. ",
1076 " .+++++++++++++++++.. .+. ",
1077 " .+...............+. .+. ",
1078 " .+. .+. .+. .+. ",
1079 " .+. .+. .+. .+. ",
1080 " .+. .+. .+. .+. ",
1081 " .+. .+. .+. .+. ",
1082 " .+. .+. .+. .+. ",
1083 " .+. .+. .+. .+. ",
1084 " .+. .+. .+. .+. ",
1085 " .+. .+. .+. .+. ",
1086 " .+. .+......+....+. ",
1087 " .+. ..++++++.+.++++. ",
1088 " .+. .++.......+...+.. ",
1089 " .+. .++. .+..++. ",
1090 " .+. ..+.. .+..+. ",
1093 " .+++.............++. ",
1094 " .+++++++++++++++++. ",
1095 " ................... ",
1100 fPerspectiveIcon =
new QPixmap(perspective);
1102 const char *
const ortho[]={
1110 " ................... ",
1111 " ..@@@@@@@@@@@@@@@@@. ",
1112 " ..@@@.............@@@. ",
1113 " ..@@.@. ..@..@. ",
1114 " ..@@ ..@. .@@...@. ",
1115 " ..@@..............@@.. .@. ",
1116 " .@@@@@@@@@@@@@@@@@.. .@. ",
1117 " .@...............@. .@. ",
1118 " .@. .@. .@. .@. ",
1119 " .@. .@. .@. .@. ",
1120 " .@. .@. .@. .@. ",
1121 " .@. .@. .@. .@. ",
1122 " .@. .@. .@. .@. ",
1123 " .@. .@. .@. .@. ",
1124 " .@. .@. .@. .@. ",
1125 " .@. .@. .@. .@. ",
1126 " .@. .@. .@. .@. ",
1127 " .@. .@. .@. .@. ",
1128 " .@. .@........@......@. ",
1129 " .@. .@@@@@@@@@.@.@@@@@@. ",
1130 " .@. .@@+........@....@@.. ",
1131 " .@...@. .@...@... ",
1133 " .@@@.............@@@.. ",
1134 " .@@@@@@@@@@@@@@@@@... ",
1135 " ................... ",
1140 fOrthoIcon =
new QPixmap(ortho);
1142 const char *
const commandIcon[]={
1170 "66666666666666666666",
1171 "66%++++++++++++++&56",
1172 "6$ o..o......o..o *6",
1173 "6+o...o*<441;@.o..+6",
1174 "6+..o@1553<354$..o+6",
1175 "6+..o<5<@ .*54#o.+6",
1184 "6+..O25<@ X=54#o.+6",
1185 "6+.o.@1553<354$...@6",
1186 "6+o..oo*<44<;@o..o+6",
1187 "6$ .o..o.....o..o *6",
1188 "66%+++++OOOO+++++*66",
1189 "66666666666666666666"
1191 fCommandIcon =
new QPixmap(commandIcon);
1193 const char *
const dirIcon[]={
1221 "66666666666666666666",
1222 "66$oOOOOOOOOOOOOo%66",
1225 "6o =635533666$ o6",
1226 "6o -65:+ +165X o6",
1235 "6o -65:+ @265X o6",
1236 "6o =635543665# O6",
1239 "66$OOOoo....OOOOo%66",
1240 "66666666666666666666"}
1242 fDirIcon =
new QPixmap(dirIcon);
1245 const char *
const runIcon[]={
1282 "rrrrrrrr%<<2rrrrrrrr",
1283 "rrrrr5=$$$$===rrrrrr",
1284 "rrrr<##$$$$$---&rrrr",
1285 "rrr=###$$$$-----%rrr",
1286 "rr=####$$$$------&rr",
1287 "r2@####7##$-------rr",
1288 "r.@####048$-------Or",
1290 " .@@###w4eee5%$#@@@X",
1291 " .@@@..w4eeeeqo..@@X",
1293 " ..oooOe2eee6OOOooo ",
1294 "rOooOO+e2ew2+++++O+r",
1295 "r:oO+++e30,;;;;;++Or",
1296 "r :++;:9,>,,>>:;;1rr",
1297 "rr*1;:>,333333,>32rr",
1298 "rrr66,1367777637<rrr",
1299 "rrrr509799999905rrrr",
1300 "rrrrr=8wqwwww8-rrrrr",
1301 "rrrrrrrr4444rrrrrrrr"
1303 fRunIcon =
new QPixmap(runIcon);
1305 const char *
const paramIcon[]={
1344 "wwwwwwww5 5wwwwwwww",
1345 "wwwwwwww, ,wwwwwwww",
1346 "www&;ww7+ +9ww=-www",
1352 "5<+ .wwwwwww0. +<5",
1355 "5<+ .wwwwwww0X +<5",
1361 "www*>ww7+ +7ww=:www",
1362 "wwwwwwww1 1wwwwwwww",
1363 "wwwwwwww5 5wwwwwwww"
1365 fParamIcon =
new QPixmap(paramIcon);
1367 const char *
const exitIcon[]={
1433 " rMMMM# jMMM MMMMx ",
1434 " OMMMMk jMMM 8MMMM9 ",
1435 " xMMMM jMMM pMMMM ",
1436 " MMMM jMMM xMMM8 ",
1447 " <MMMMMp: $rMMMMMp ",
1448 " yMMMMMMMMMMMMMMk ",
1455 fExitIcon=
new QPixmap(exitIcon);
1462 auto qVariant = item->data(0, Qt::UserRole);
1463 std::istringstream iss(qVariant.toString().toStdString());
1464 void* itemAddress; iss >> itemAddress;
1468 QColor ConvertG4ColourToQColor(
const G4Colour& g4Colour)
1470 return QColor((
int)(g4Colour.
GetRed()*255),
1472 (
int)(g4Colour.
GetBlue()*255),
1476 G4Colour ConvertQColorToG4Colour(
const QColor& qColor)
1478 return G4Color(qColor.red()/255.,
1479 qColor.green()/255.,
1481 qColor.alpha()/255.);
1485void G4UIQt::CreateNewSceneTreeWidget()
1487 auto vLayout = fNewSceneTreeWidget->layout();
1489 vLayout->setContentsMargins(0,0,0,0);
1491 fNewSceneTreeItemTreeWidget =
new NewSceneTreeItemTreeWidget;
1492 fNewSceneTreeItemTreeWidget->setSelectionMode(QAbstractItemView::SingleSelection);
1493 vLayout->addWidget(fNewSceneTreeItemTreeWidget);
1497 connect(fNewSceneTreeItemTreeWidget, &QTreeWidget::itemClicked,
1498 [&](QTreeWidgetItem* item){SceneTreeItemClicked(item);});
1500 connect(fNewSceneTreeItemTreeWidget, &QTreeWidget::itemDoubleClicked,
1501 [&](QTreeWidgetItem* item){SceneTreeItemDoubleClicked(item);});
1504 connect(fNewSceneTreeItemTreeWidget, &QTreeWidget::itemExpanded,
1505 [&](QTreeWidgetItem* item){SceneTreeItemExpanded(item);});
1506 connect(fNewSceneTreeItemTreeWidget, &QTreeWidget::itemCollapsed,
1507 [&](QTreeWidgetItem* item){SceneTreeItemCollapsed(item);});
1518 fNewSceneTreeItemTreeWidget->clear();
1522 fNewSceneTreeItemTreeWidget->setHeaderLabel (root.
GetDescription().c_str());
1525 auto item =
new QTreeWidgetItem(fNewSceneTreeItemTreeWidget);
1528 fNewSceneTreeItemTreeWidget->insertTopLevelItem(0,item);
1531 item->setText(0, model.GetModelType().c_str());
1537 std::ostringstream oss; oss << std::hex << &model;
1538 auto data = QVariant(oss.str().c_str());
1539 item->setData(0, Qt::UserRole, data);
1542 G4String toolTipMessage = model.GetModelDescription();
1543 if (!model.GetFurtherInfo().empty()) {
1544 toolTipMessage +=
"\n " + model.GetFurtherInfo();
1546 item->setToolTip(0, toolTipMessage.c_str());
1550 (0, model.GetVisAttributes().IsVisible()? Qt::Checked: Qt::Unchecked);
1553 item->setExpanded(model.IsExpanded());
1556 BuildPVQTree(model,item);
1562void G4UIQt::BuildPVQTree(
const G4SceneTreeItem& g4stItem, QTreeWidgetItem* qtwItem)
1564 const auto& g4stChildren = g4stItem.
GetChildren();
1565 for (
const auto& g4stChild: g4stChildren) {
1566 QStringList qStringList;
1567 qStringList.append(g4stChild.GetDescription().c_str());
1568 auto newQTWItem =
new QTreeWidgetItem(qStringList);
1571 qtwItem->addChild(newQTWItem);
1577 std::ostringstream oss; oss << std::hex << &g4stChild;
1578 auto data = QVariant(oss.str().c_str());
1579 newQTWItem->setData(0, Qt::UserRole, data);
1583 auto& nameCopyNo = g4stChild.GetDescription();
1584 auto name = nameCopyNo.substr(0,nameCopyNo.find(
':'));
1585 oss.str(
""); oss << nameCopyNo <<
1586 ": Click to make visible and get more information."
1587 "\n This may not work if the volume is in the \"base path\". (Hover on"
1588 "\n the model to see base path.) If this is the case,"
1589 "\n \"/vis/scene/add/volume " << name <<
"\" to bring into the displayed tree.)";
1590 newQTWItem->setToolTip(0, oss.str().c_str());
1592 oss.str(
""); oss << g4stChild.GetPVPath() <<
1593 "\nTo see properties, right-click/dump.";
1594 newQTWItem->setToolTip(0, oss.str().c_str());
1598 newQTWItem->setCheckState
1599 (0, g4stChild.GetVisAttributes().IsVisible()? Qt::Checked: Qt::Unchecked);
1602 newQTWItem->setExpanded(g4stChild.IsExpanded());
1605 QPixmap pixmap = QPixmap(QSize(16, 16));
1606 pixmap.fill(ConvertG4ColourToQColor(g4stChild.GetVisAttributes().GetColour()));
1607 QPainter painter(&pixmap);
1608 painter.setPen(Qt::black);
1609 painter.drawRect(0,0,15,15);
1610 newQTWItem->setIcon(0,pixmap);
1613 BuildPVQTree(g4stChild,newQTWItem);
1617void G4UIQt::SceneTreeItemClicked(QTreeWidgetItem* item)
1619 if (item ==
nullptr)
return;
1620 auto sceneTreeItem = ConvertToG4SceneTreeItem(item);
1621 if (sceneTreeItem ==
nullptr)
return;
1626 G4String argument =
"false", inverse =
"true";
1627 auto newCheckState = item->checkState(0);
1629 = sceneTreeItem->GetVisAttributes().IsVisible()? Qt::Checked: Qt::Unchecked;
1630 switch (sceneTreeItem->GetType()) {
1639 if (newCheckState != oldCheckState) {
1640 if (newCheckState == Qt::Checked) argument =
"true";
1642 (
"/vis/scene/activateModel \"" + sceneTreeItem->GetModelDescription() +
"\" " + argument);
1650 if (newCheckState != oldCheckState) {
1651 if (newCheckState == Qt::Checked) {
1652 argument =
"true"; inverse =
"false";
1654 uiMan->ApplyCommand(
"/vis/set/touchable" + sceneTreeItem->GetPVPath());
1655 uiMan->ApplyCommand(
"/vis/touchable/set/visibility " + argument);
1657 if (sceneTreeItem->GetChildren().size() > 0 ) {
1658 uiMan->ApplyCommand(
"/vis/touchable/set/daughtersInvisible " + inverse);
1661 static G4bool wanted =
true;
1662 if (wanted && sceneTreeItem->GetChildren().size() > 0 && argument ==
"false") {
1665 (
"This action makes this volume and all descendants invisible."
1666 " To see descendants, right-click and select daughtersInvisible/false"
1667 " and check visibility of descendants individually.");
1668 msgBox.setInformativeText
1669 (
"To suppress this message click \"Discard\" or \"Don't Save\"");
1670 msgBox.setStandardButtons(QMessageBox::Discard | QMessageBox::Ok);
1671 msgBox.setDefaultButton(QMessageBox::Ok);
1672 auto action = msgBox.exec();
1673 if (action == QMessageBox::Discard) {
1682void G4UIQt::SceneTreeItemDoubleClicked(QTreeWidgetItem* item)
1684 if (item ==
nullptr)
return;
1685 auto sceneTreeItem = ConvertToG4SceneTreeItem(item);
1686 if (sceneTreeItem ==
nullptr)
return;
1689 auto oldQColor = ConvertG4ColourToQColor(sceneTreeItem->GetVisAttributes().GetColour());
1690 auto newQColor = QColorDialog::getColor
1691 (oldQColor, fNewSceneTreeItemTreeWidget,
"", QColorDialog::ShowAlphaChannel);
1692 if (!newQColor.isValid())
return;
1693 if (newQColor == oldQColor)
return;
1695 auto newColour = ConvertQColorToG4Colour(newQColor);
1696 std::ostringstream oss; oss << std::setprecision(2)
1697 << newColour.GetRed() <<
' ' << newColour.GetGreen()
1698 <<
' ' << newColour.GetBlue() <<
' ' << newColour.GetAlpha();
1700 uiMan->ApplyCommand(
"/vis/set/touchable" + sceneTreeItem->GetPVPath());
1701 uiMan->ApplyCommand(
"/vis/touchable/set/colour " + oss.str());
1709 if (newColour.GetAlpha() == 0.) {
1710 sceneTreeItem->AccessVisAttributes().SetColour(newColour);
1714void G4UIQt::SceneTreeItemExpanded(QTreeWidgetItem* item)
1716 if (item ==
nullptr)
return;
1717 auto sceneTreeItem = ConvertToG4SceneTreeItem(item);
1718 if (sceneTreeItem ==
nullptr)
return;
1722 sceneTreeItem->SetExpanded(
true);
1726void G4UIQt::SceneTreeItemCollapsed(QTreeWidgetItem* item)
1728 if (item ==
nullptr)
return;
1729 auto sceneTreeItem = ConvertToG4SceneTreeItem(item);
1730 if (sceneTreeItem ==
nullptr)
return;
1734 sceneTreeItem->SetExpanded(
false);
1738void G4UIQt::NewSceneTreeItemTreeWidget::mousePressEvent(QMouseEvent* ev)
1740#if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0))
1741 auto currentMousePressPosition = ev->globalPos();
1743 auto currentMousePressPosition = ev->globalPosition().toPoint();
1746 if (ev->button() == Qt::RightButton) {
1747 auto item = currentItem();
1749 auto sceneTreeItem = ConvertToG4SceneTreeItem(item);
1750 if (sceneTreeItem) {
1758 enum CommandType {withoutParameter, withABool, withAnInteger, withADouble, withAString};
1759 static std::map<G4String,CommandType> alphabetical;
1760 static G4bool first =
true;
1767 alphabetical[
"centreAndZoomInOn"] = withoutParameter;
1768 alphabetical[
"centreOn"] = withoutParameter;
1769 alphabetical[
"dump"] = withoutParameter;
1770 alphabetical[
"extentForField"] = withoutParameter;
1771 alphabetical[
"localAxes"] = withoutParameter;
1772 alphabetical[
"showExtent"] = withoutParameter;
1773 alphabetical[
"twinkle"] = withoutParameter;
1774 alphabetical[
"volumeForField"] = withoutParameter;
1777 alphabetical[
"daughtersInvisible"] = withABool;
1778 alphabetical[
"forceAuxEdgeVisible"] = withABool;
1779 alphabetical[
"forceCloud"] = withABool;
1780 alphabetical[
"forceSolid"] = withABool;
1781 alphabetical[
"forceWireframe"] = withABool;
1782 alphabetical[
"visibility"] = withABool;
1784 alphabetical[
"lineSegmentsPerCircle"] = withAnInteger;
1785 alphabetical[
"numberOfCloudPoints"] = withAnInteger;
1787 alphabetical[
"lineWidth"] = withADouble;
1789 alphabetical[
"lineStyle"] = withAString;
1793 std::vector<QAction*> actions;
1794 std::vector<QMenu*> menus;
1796 for (
const auto& action : alphabetical) {
1797 const auto& af = action.first;
1799 if (action.second == withoutParameter) {
1801 auto qAction =
new QAction(af.c_str(),
this);
1802 actions.push_back(qAction);
1803 topMenu.addAction(qAction);
1804 connect(qAction, &QAction::triggered,
this,
1805 [
this, &af, &sceneTreeItem]{ActWithoutParameter(af, sceneTreeItem);});
1807 }
else if (action.second == withABool) {
1809 auto menu =
new QMenu(af.c_str());
1810 menus.push_back(menu);
1811 topMenu.addMenu(menu);
1812 auto qActionTrue =
new QAction(
"true",
this);
1813 actions.push_back(qActionTrue);
1814 menu->addAction(qActionTrue);
1815 connect(qActionTrue, &QAction::triggered,
this,
1816 [
this, &af, &sceneTreeItem]{ActWithABool(af, sceneTreeItem,
true);});
1817 auto qActionFalse =
new QAction(
"false",
this);
1818 actions.push_back(qActionFalse);
1819 menu->addAction(qActionFalse);
1820 connect(qActionFalse, &QAction::triggered,
this,
1821 [
this, &af, &sceneTreeItem]{ActWithABool(af, sceneTreeItem,
false);});
1823 }
else if (action.second == withAnInteger) {
1825 auto qAction =
new QAction(af.c_str(),
this);
1826 actions.push_back(qAction);
1827 topMenu.addAction(qAction);
1828 connect(qAction, &QAction::triggered,
this,
1829 [
this, &af, &sceneTreeItem]{ActWithAnInteger(af, sceneTreeItem);});
1831 }
else if (action.second == withADouble) {
1833 auto qAction =
new QAction(af.c_str(),
this);
1834 actions.push_back(qAction);
1835 topMenu.addAction(qAction);
1836 connect(qAction, &QAction::triggered,
this,
1837 [
this, &af, &sceneTreeItem]{ActWithADouble(af, sceneTreeItem);});
1839 }
else if (action.second == withAString) {
1841 auto qAction =
new QAction(af.c_str(),
this);
1842 actions.push_back(qAction);
1843 topMenu.addAction(qAction);
1844 connect(qAction, &QAction::triggered,
this,
1845 [
this, &af, &sceneTreeItem]{ActWithAString(af, sceneTreeItem);});
1849 topMenu.exec(currentMousePressPosition);
1852 for (
auto action : actions) {
1857 for (
auto menu : menus) {
1866 QTreeWidget::mousePressEvent(ev);
1869void G4UIQt::NewSceneTreeItemTreeWidget::ActWithoutParameter
1870 (
const G4String& action, G4SceneTreeItem* sceneTreeItem)
1873 if (action ==
"dump") {
1874 static G4bool wanted =
true;
1877 std::ostringstream oss;
1880 msgBox.setText((oss.str().substr(0,1000)+
"...").c_str());
1881 msgBox.setInformativeText
1882 (
"To suppress this message click \"Discard\" or \"Don't Save\"."
1883 "\nTo get a complete dump to session output click \"Ok\","
1884 "\nElse click \"Close\".");
1885 msgBox.setStandardButtons
1886 (QMessageBox::Discard | QMessageBox::Close | QMessageBox::Ok);
1887 msgBox.setDefaultButton(QMessageBox::Ok);
1888 auto result = msgBox.exec();
1889 if (result == QMessageBox::Discard) {
1891 }
else if (result == QMessageBox::Close) {
1897 uiMan->ApplyCommand(
"/vis/set/touchable" + sceneTreeItem->
GetPVPath());
1898 uiMan->ApplyCommand(
"/vis/touchable/" + action);
1901void G4UIQt::NewSceneTreeItemTreeWidget::ActWithABool
1902 (
const G4String& action, G4SceneTreeItem* sceneTreeItem,
G4bool whatever)
1905 uiMan->ApplyCommand(
"/vis/set/touchable" + sceneTreeItem->
GetPVPath());
1906 G4String which = whatever?
"true":
"false";
1907 uiMan->ApplyCommand(
"/vis/touchable/set/" + action +
' ' + which);
1910void G4UIQt::NewSceneTreeItemTreeWidget::ActWithAnInteger
1911(
const G4String& action, G4SceneTreeItem* sceneTreeItem)
1914 auto newValue = QInputDialog::getInt(
this, action.c_str(), action.c_str(),
1915 0, 0, 9999999, 1, &ok);
1918 uiMan->ApplyCommand(
"/vis/set/touchable" + sceneTreeItem->
GetPVPath());
1919 uiMan->ApplyCommand(
"/vis/touchable/set/" + action +
' '
1924void G4UIQt::NewSceneTreeItemTreeWidget::ActWithADouble
1925 (
const G4String& action, G4SceneTreeItem* sceneTreeItem)
1928 auto newValue = QInputDialog::getDouble(
this, action.c_str(), action.c_str(),
1932 uiMan->ApplyCommand(
"/vis/set/touchable" + sceneTreeItem->
GetPVPath());
1933 uiMan->ApplyCommand(
"/vis/touchable/set/" + action +
' '
1938void G4UIQt::NewSceneTreeItemTreeWidget::ActWithAString
1939 (
const G4String& action, G4SceneTreeItem* sceneTreeItem)
1942 auto command = uiMan->FindCommand(
"/vis/touchable/set/" + action);
1944 QStringList qStringList;
1945 const auto& candidates = command->GetParameter(0)->GetParameterCandidates();
1946 std::istringstream iss(candidates);
1948 while (iss >> candidate) qStringList.append(candidate.c_str());
1950 auto chosenValue = QInputDialog::getItem(
this, action.c_str(), action.c_str(), qStringList,
1953 uiMan->ApplyCommand(
"/vis/set/touchable" + sceneTreeItem->
GetPVPath());
1954 G4String g4ChosenValue = chosenValue.toStdString();
1955 uiMan->ApplyCommand(
"/vis/touchable/set/" + action +
' ' + g4ChosenValue);
1963QWidget* G4UIQt::CreateHistoryTBWidget()
1965 fHistoryTBWidget =
new QWidget();
1967 auto layoutHistoryTB =
new QVBoxLayout();
1968 fHistoryTBTableList =
new QListWidget();
1969 fHistoryTBTableList->setSelectionMode(QAbstractItemView::SingleSelection);
1970 connect(fHistoryTBTableList, SIGNAL(itemSelectionChanged()), SLOT(CommandHistoryCallback()));
1972 layoutHistoryTB->addWidget(fHistoryTBTableList);
1974 fHistoryTBWidget->setLayout(layoutHistoryTB);
1975 return fHistoryTBWidget;
1980QWidget* G4UIQt::CreateHelpTBWidget()
1982 fHelpTBWidget =
new QWidget();
1984 auto helpWidget =
new QWidget();
1985 auto helpLayout =
new QHBoxLayout();
1986 auto vLayout =
new QVBoxLayout();
1987 fHelpVSplitter =
new QSplitter(Qt::Vertical);
1988 fHelpLine =
new QLineEdit();
1989 helpLayout->addWidget(
new QLabel(
"Search :"));
1990 helpLayout->addWidget(fHelpLine);
1991 connect(fHelpLine, SIGNAL(editingFinished()),
this, SLOT(LookForHelpStringCallback()));
1996 fParameterHelpLabel =
new QTextEdit();
1997 fParameterHelpLabel->setReadOnly(
true);
1998 fParameterHelpTable =
new QTableWidget();
2002 if (fHelpTreeWidget !=
nullptr) {
2003 fHelpVSplitter->addWidget(fHelpTreeWidget);
2004 fHelpVSplitter->setStretchFactor(0,4);
2006 fHelpVSplitter->addWidget(fParameterHelpLabel);
2007 fHelpVSplitter->addWidget(fParameterHelpTable);
2009 fParameterHelpLabel->setVisible(
false);
2010 fParameterHelpTable->setVisible(
false);
2011 QSizePolicy policy = QSizePolicy(QSizePolicy::Minimum, QSizePolicy::Preferred);
2012 policy.setVerticalStretch(1);
2013 fParameterHelpLabel->setSizePolicy(policy);
2014 fParameterHelpTable->setSizePolicy(policy);
2016 vLayout->addWidget(helpWidget);
2017 vLayout->addWidget(fHelpVSplitter, 1);
2018 vLayout->setContentsMargins(5, 5, 5, 5);
2020 helpWidget->setLayout(helpLayout);
2021 fHelpTBWidget->setLayout(vLayout);
2023 return fHelpTBWidget;
2028G4UIDockWidget* G4UIQt::CreateCoutTBWidget()
2030 auto coutTBWidget =
new QWidget();
2032 auto layoutCoutTB =
new QVBoxLayout();
2034 fCoutTBTextArea =
new QTextEdit();
2036 fCoutFilter =
new QLineEdit();
2037 fCoutFilter->setToolTip(
"Filter output by...");
2039 fCoutFilter->addAction(*fSearchIcon, QLineEdit::TrailingPosition);
2040 fCoutFilter->setStyleSheet(
"border-radius:7px;");
2042 auto coutTBClearButton =
new QPushButton();
2043 coutTBClearButton->setIcon(*fClearIcon);
2044 coutTBClearButton->setToolTip(
"Clear console output");
2045 coutTBClearButton->setStyleSheet(
"border-radius:7px;");
2046 connect(coutTBClearButton, SIGNAL(clicked()), SLOT(ClearButtonCallback()));
2048 fCoutFilter, SIGNAL(textEdited(
const QString&)), SLOT(CoutFilterCallback(
const QString&)));
2050 auto coutTBSaveOutputButton =
new QPushButton();
2051 coutTBSaveOutputButton->setIcon(*fSaveIcon);
2052 coutTBSaveOutputButton->setToolTip(
"Save console output");
2053 coutTBSaveOutputButton->setStyleSheet(
"border-radius:7px;");
2054 connect(coutTBSaveOutputButton, SIGNAL(clicked()), SLOT(SaveOutputCallback()));
2056 fCoutTBTextArea->setReadOnly(
true);
2058 auto coutButtonWidget =
new QWidget();
2059 auto layoutCoutTBButtons =
new QHBoxLayout();
2061#ifdef G4MULTITHREADED
2063 fThreadsFilterComboBox =
new QComboBox();
2064 fThreadsFilterComboBox->setInsertPolicy(QComboBox::InsertAlphabetically);
2066 fThreadsFilterComboBox, SIGNAL(activated(
int)),
this, SLOT(ThreadComboBoxCallback(
int)));
2068 UpdateCoutThreadFilter();
2070 fThreadsFilterComboBox->setToolTip(
"Thread selection in output");
2071 layoutCoutTBButtons->addWidget(
new QLabel(
" Threads:"));
2072 layoutCoutTBButtons->addWidget(fThreadsFilterComboBox);
2075 layoutCoutTBButtons->addWidget(fCoutFilter);
2076 layoutCoutTBButtons->addWidget(coutTBClearButton);
2077 layoutCoutTBButtons->addWidget(coutTBSaveOutputButton);
2078 coutButtonWidget->setLayout(layoutCoutTBButtons);
2081 layoutCoutTBButtons->setContentsMargins(3, 3, 3, 0);
2083 layoutCoutTB->addWidget(coutButtonWidget);
2084 layoutCoutTB->addWidget(fCoutTBTextArea);
2086 coutTBWidget->setLayout(layoutCoutTB);
2088 fCoutTBTextArea->setMinimumSize(100, 100);
2091 auto commandLineWidget =
new QWidget();
2092 auto layoutCommandLine =
new QHBoxLayout();
2096 fCommandLabel =
new QLabel(
"");
2097 fCommandArea =
new QLineEdit();
2101 fCommandArea->activateWindow();
2103 fCommandArea->setFocusPolicy(Qt::StrongFocus);
2104 fCommandArea->setFocus(Qt::TabFocusReason);
2105 fCommandArea->setToolTip(
"Apply command");
2107 layoutCommandLine->addWidget(fCommandLabel);
2108 layoutCommandLine->addWidget(fCommandArea);
2111 connect(fCommandArea, SIGNAL(returnPressed()), SLOT(CommandEnteredCallback()));
2113 fCommandArea, SIGNAL(textEdited(
const QString&)), SLOT(CommandEditedCallback(
const QString&)));
2115 commandLineWidget->setLayout(layoutCommandLine);
2116 commandLineWidget->setMinimumSize(50, 50);
2118 layoutCoutTB->addWidget(commandLineWidget);
2120 fCoutDockWidget =
new G4UIDockWidget(
"Output");
2121 fCoutDockWidget->setAllowedAreas(Qt::TopDockWidgetArea | Qt::BottomDockWidgetArea);
2123 fCoutDockWidget->setWidget(coutTBWidget);
2124 return fCoutDockWidget;
2129QWidget* G4UIQt::CreateVisParametersTBWidget() {
return nullptr; }
2133G4UIDockWidget* G4UIQt::CreateUITabWidget()
2135 fUITabWidget =
new QTabWidget();
2138 fUITabWidget->addTab(CreateSceneTreeWidget(),
"Scene tree");
2139 fUITabWidget->addTab(CreateHelpTBWidget(),
"Help");
2140 fUITabWidget->addTab(CreateHistoryTBWidget(),
"History");
2141 fUITabWidget->setCurrentWidget(fHelpTBWidget);
2143 fUITabWidget->setTabToolTip(0,
"Tree of scene items");
2144 fUITabWidget->setTabToolTip(1,
"Help widget");
2145 fUITabWidget->setTabToolTip(2,
"All commands history");
2146 connect(fUITabWidget, SIGNAL(currentChanged(
int)), SLOT(ToolBoxActivated(
int)));
2148 fUIDockWidget =
new G4UIDockWidget(
"");
2149 fUIDockWidget->setAllowedAreas(Qt::LeftDockWidgetArea | Qt::RightDockWidgetArea);
2151 fUIDockWidget->setWidget(fUITabWidget);
2153 return fUIDockWidget;
2156QWidget* G4UIQt::CreateSceneTreeWidget()
2158 fSceneTreeWidget =
new QWidget();
2159 auto layout =
new QVBoxLayout();
2160 fSceneTreeWidget->setLayout(layout);
2162 fSceneTreeWidget->setVisible(
false);
2164 return fSceneTreeWidget;
2167void G4UIQt::CreateViewerWidget()
2172 SetStartPage(std::string(
"<table width='100%'><tr><td width='30%'></td><td><div ")+
2173 "style='color: rgb(140, 31, 31); font-size: xx-large; font-family: Garamond, serif; padding-bottom: 0px; font-weight: normal'>Geant4: "+
2174 QApplication::applicationName ().toStdString()+
2175 "</div></td><td width='40%'> <br/><i>http://cern.ch/geant4/</i></td></tr></table>"+
2177 "<div style='background:#EEEEEE;'><b>Tooltips :</b><ul>"+
2178 "<li><b>Start a new viewer :</b><br />"+
2179 "<i>'/vis/open/...'<br />"+
2180 "For example '/vis/open OGL'</i></li>"+
2181 "<li><b>Execute a macro file :</b><br />"+
2182 "<i>'/control/execute my_macro_file'</i></li>"+
2185 "<div style='background:#EEEEEE;'><b>Documentation :</b><ul>"+
2186 "<li><b>Visualisation publication :</b><br />"+
2187 "<i><a href='http://www.worldscientific.com/doi/abs/10.1142/S1793962313400011'>The Geant4 Visualization System - A Multi-Driver Graphics System</b><br />, Allison, J. et al., International Journal of Modeling, Simulation, and Scientific Computing, Vol. 4, Suppl. 1 (2013) 1340001</a>:<br/> http://www.worldscientific.com/doi/abs/10.1142/S1793962313400011</i></li>"+
2190 "<div style='background:#EEEEEE;'><b>Getting Help :</b><ul>"+
2191 "<li><b>If problems arise, try <a href='https://cern.ch/geant4-forum'>browsing the user forum</a> to see whether or not your problem has already been encountered.<br /> If it hasn't, you can post it and Geant4 developers will do their best to find a solution. This is also a good place to<br /> discuss Geant4 topics in general.</b> https://cern.ch/geant4-forum"+
2192 "<li><b>Get a look at <a href='http://cern.ch/geant4/support'>Geant4 User support pages</a>: <i>http://cern.ch/geant4/support</i></b></li>"+
2198 if (fViewerTabWidget ==
nullptr) {
2199#if QT_VERSION < 0x060000
2200 fViewerTabWidget =
new G4QTabWidget();
2202 fViewerTabWidget =
new QTabWidget();
2204 fMainWindow->setCentralWidget(fViewerTabWidget);
2205 fViewerTabWidget->setTabsClosable(
true);
2207 fViewerTabWidget->setUsesScrollButtons(
true);
2209 connect(fViewerTabWidget, SIGNAL(tabCloseRequested(
int)),
this, SLOT(TabCloseCallback(
int)));
2210#if QT_VERSION < 0x060000
2211 connect(fViewerTabWidget, SIGNAL(currentChanged(
int)), SLOT(UpdateTabWidget(
int)));
2213 connect(fViewerTabWidget, SIGNAL(currentChanged(
int)),
this, SLOT(UpdateTabWidget(
int)));
2218 QSizePolicy policy = QSizePolicy(QSizePolicy::Preferred, QSizePolicy::Preferred);
2219 policy.setVerticalStretch(4);
2220 fViewerTabWidget->setSizePolicy(policy);
2222 fViewerTabWidget->setMinimumSize(40, 40);
2233 if (fViewerPropertiesDialog ==
nullptr) {
2234 CreateViewerPropertiesDialog();
2236 return fViewerPropertiesWidget;
2243 if (fPickInfosDialog ==
nullptr) {
2244 CreatePickInfosDialog();
2246 return fPickInfosWidget;
2253 if (fViewerTabWidget ==
nullptr) {
2256 fViewerTabWidget->addTab(aWidget, title.c_str());
2265 if (fViewerTabWidget ==
nullptr) {
2270 if (UI ==
nullptr)
return false;
2271 std::ifstream file(UI->
FindMacroPath(fileName.c_str()).data());
2273 std::string content((std::istreambuf_iterator<char>(file)), (std::istreambuf_iterator<char>()));
2275 auto text =
new QTextEdit();
2276 text->setAcceptRichText(
true);
2277 text->setContentsMargins(5, 5, 5, 5);
2278 text->setText(QString(
"<pre>") + content.c_str() +
"</pre>");
2279 text->setReadOnly(
true);
2280 fViewerTabWidget->addTab(text, title.c_str());
2293#if QT_VERSION < 0x060000
2294 if (fViewerTabWidget ==
nullptr) {
2295 CreateViewerWidget();
2299 if (aWidget ==
nullptr) {
2302#if QT_VERSION < 0x060000
2304 aWidget->setParent(fViewerTabWidget);
2307 fViewerTabWidget->addTab(aWidget, name);
2309 fViewerTabWidget->setCurrentIndex(fViewerTabWidget->count() - 1);
2312 fViewerTabWidget->setLastTabCreated(fViewerTabWidget->currentIndex());
2318 QObject::disconnect(fViewerTabWidget, SIGNAL(currentChanged(
int)),
this, SLOT(UpdateTabWidget(
int)));
2319 fViewerTabWidget->addTab(aWidget, name);
2320 fViewerTabWidget->setCurrentIndex(fViewerTabWidget->count() - 1);
2321 QObject::connect(fViewerTabWidget, SIGNAL(currentChanged(
int)),
this, SLOT(UpdateTabWidget(
int)));
2334 if (! text.empty()) {
2335 fDefaultViewerFirstPageHTMLText = text;
2337 if (fStartPage ==
nullptr) {
2338 fStartPage =
new QTextBrowser();
2339 fStartPage->setContentsMargins(5, 5, 5, 5);
2340 fStartPage->setReadOnly(
true);
2342 fStartPage->setOpenExternalLinks(
true);
2343 fStartPage->setHtml(fDefaultViewerFirstPageHTMLText.c_str());
2346#if QT_VERSION < 0x060000
2347void G4UIQt::UpdateTabWidget(
int tabNumber)
2349 if (fViewerTabWidget ==
nullptr) {
2353 fViewerTabWidget->setCurrentIndex(tabNumber);
2356 fViewerTabWidget->setTabSelected(
false);
2358 fViewerTabWidget->setVisible(
true);
2361 fViewerTabWidget->setTabSelected(
true);
2364void G4UIQt::UpdateTabWidget(
int)
2369 if (fViewerTabWidget->currentWidget() !=
nullptr) {
2370 auto edit =
dynamic_cast<QTextEdit*
>(fViewerTabWidget->currentWidget());
2371 if (edit ==
nullptr) {
2372 QString text = fViewerTabWidget->tabText(fViewerTabWidget->currentIndex());
2373 QString paramSelect = QString(
"/vis/viewer/select ") + text;
2382void G4UIQt::ResizeTabWidget(QResizeEvent* e)
2384 if (fViewerTabWidget !=
nullptr) {
2385 for (
G4int a = 0; a < fViewerTabWidget->count(); a++) {
2386 fViewerTabWidget->widget(a)->resize(e->size());
2397 exitSession =
false;
2399 QCoreApplication::sendPostedEvents();
2401 fMainWindow->setVisible(
true);
2403 if (fDefaultIcons) {
2404 fToolbarApp->setVisible(
true);
2408 fToolbarApp->setVisible(
false);
2414 UpdateCommandCompleter();
2417 fHistoryTBTableList->installEventFilter(
this);
2418 fCommandArea->installEventFilter(
this);
2421 fCommandArea->setFocus();
2436 if (aPrompt ==
nullptr)
return;
2438 fCommandLabel->setText((
char*)aPrompt.data());
2444 fMainWindow->close();
2458 if (aState ==
nullptr)
return;
2460 if (aState ==
"G4_pause> ") {
2461 SecondaryLoop(
"Pause, type continue to exit this state");
2464 if (aState ==
"EndOfEvent") {
2466 SecondaryLoop(
"End of event, type continue to exit this state");
2474void G4UIQt::SecondaryLoop(
const G4String& aPrompt)
2476 if (aPrompt ==
nullptr)
return;
2482 ((QApplication*)interactorManager)->processEvents(QEventLoop::WaitForMoreEvents);
2483 if (exitPause)
break;
2488#ifdef G4MULTITHREADED
2504 if (aString.empty())
return 0;
2506#ifdef G4MULTITHREADED
2516#ifdef G4MULTITHREADED
2519 std::cout << aString << std::flush;
2530 for (
G4int i = 0; i < (
G4int)aString.length() - 1; ++i) {
2531 if (aString[i] ==
'\n') {
2532 aStringWithStyle +=
"<br>";
2534 else if (aString[i] ==
' ') {
2535 aStringWithStyle +=
" ";
2537 else if (aString[i] ==
'\t') {
2538 aStringWithStyle +=
" ";
2540 else if (aString[i] ==
'<') {
2541 aStringWithStyle +=
"<";
2544 aStringWithStyle += aString[i];
2548 aStringWithStyle =
"<span style='font-family:courier;'>" + aStringWithStyle +
"</span>";
2551 aStringWithStyle =
"<span>" + aStringWithStyle +
"</span>";
2556 G4UIOutputString(QString((
char*)aStringWithStyle.data()), GetThreadPrefix());
2557 fG4OutputString.push_back(txt);
2559#ifdef G4MULTITHREADED
2560 QString result = FilterOutput(txt, fThreadsFilterComboBox->currentText(), fCoutFilter->text());
2562 QString result = FilterOutput(txt,
"", fCoutFilter->text());
2565 if (result.isEmpty()) {
2571 result = QString(
"<span style='background:") + pal.link().color().name() +
";'> </span>" +
2572 "<span style='background: Pink;'> " + result +
"</span>";
2574 result = QString(
"<font color=\"Green\">") + result + QString(
"</font>");
2576 fCoutTBTextArea->append(result);
2577 fCoutTBTextArea->ensureCursorVisible();
2579#ifdef G4MULTITHREADED
2580 UpdateCoutThreadFilter();
2593 if (aString.empty())
return 0;
2597 if (G4StrUtil::contains(aString,
"*** This is just a warning message. ***")) {
2601#ifdef G4MULTITHREADED
2611#ifdef G4MULTITHREADED
2614 std::cout << aString << std::flush;
2625 for (
G4int i = 0; i < (
G4int)aString.length() - 1; ++i) {
2626 if (aString[i] ==
'\n') {
2627 aStringWithStyle +=
"<br>";
2629 else if (aString[i] ==
' ') {
2630 aStringWithStyle +=
" ";
2632 else if (aString[i] ==
'\t') {
2633 aStringWithStyle +=
" ";
2635 else if (aString[i] ==
'<') {
2636 aStringWithStyle +=
"<";
2639 aStringWithStyle += aString[i];
2643 aStringWithStyle =
"<span style='font-family:courier;'>" + aStringWithStyle +
"</span>";
2646 aStringWithStyle =
"<span>" + aStringWithStyle +
"</span>";
2651 G4UIOutputString(QString((
char*)aStringWithStyle.data()), GetThreadPrefix());
2652 fG4OutputString.push_back(txt);
2654#ifdef G4MULTITHREADED
2655 QString result = FilterOutput(txt, fThreadsFilterComboBox->currentText(), fCoutFilter->text());
2657 QString result = FilterOutput(txt,
"", fCoutFilter->text());
2660 if (result.isEmpty()) {
2668 result = QString(
"<span style='background:") + pal.link().color().name() +
2669 ";'> </span>" +
"<span style='background:" + pal.highlight().color().name() +
2670 ";'> " + result +
"</span>";
2675 fCoutTBTextArea->append(result);
2676 fCoutTBTextArea->ensureCursorVisible();
2678#ifdef G4MULTITHREADED
2679 UpdateCoutThreadFilter();
2683 fLastErrMessage = aString;
2694 if (aString.empty())
return 0;
2696#ifdef G4MULTITHREADED
2706#ifdef G4MULTITHREADED
2709 std::cerr << aString << std::flush;
2720 for (
G4int i = 0; i < (
G4int)aString.length() - 1; ++i) {
2721 if (aString[i] ==
'\n') {
2722 aStringWithStyle +=
"<br>";
2724 else if (aString[i] ==
' ') {
2725 aStringWithStyle +=
" ";
2727 else if (aString[i] ==
'\t') {
2728 aStringWithStyle +=
" ";
2730 else if (aString[i] ==
'<') {
2731 aStringWithStyle +=
"<";
2734 aStringWithStyle += aString[i];
2738 aStringWithStyle =
"<span style='font-family:courier;'>" + aStringWithStyle +
"</span>";
2741 aStringWithStyle =
"<span>" + aStringWithStyle +
"</span>";
2747 G4UIOutputString(QString((
char*)aStringWithStyle.data()).trimmed(), GetThreadPrefix(),
"error");
2748 fG4OutputString.push_back(txt);
2750#ifdef G4MULTITHREADED
2751 QString result = FilterOutput(txt, fThreadsFilterComboBox->currentText(), fCoutFilter->text());
2753 QString result = FilterOutput(txt,
"", fCoutFilter->text());
2755 if (result.isEmpty()) {
2760 if (QString(aString.data()).trimmed() !=
"") {
2765 fLastErrMessage +=
"\n" + aString;
2766 QString criticalMessage = fLastErrMessage.data();
2767 criticalMessage = criticalMessage.toHtmlEscaped();
2768 QMessageBox::critical(fMainWindow,
"Error", QString(fLastErrMessage));
2771 fCoutTBTextArea->append(QString(
"<font color=\"Red\">") + result + QString(
"</font>"));
2772 fCoutTBTextArea->ensureCursorVisible();
2774 if (QString(aString.data()).trimmed() !=
"") {
2775 fLastErrMessage += aString;
2777#ifdef G4MULTITHREADED
2778 UpdateCoutThreadFilter();
2786#ifdef G4MULTITHREADED
2788 if (UI ==
nullptr)
return "";
2796 return threadPrefix;
2799#ifdef G4MULTITHREADED
2800void G4UIQt::UpdateCoutThreadFilter()
2803 if (UI ==
nullptr)
return;
2806 if (fThreadsFilterComboBox->count() < 2) {
2807 if (fThreadsFilterComboBox->findText(
"All", Qt::MatchExactly) == -1) {
2808 fThreadsFilterComboBox->addItem(
"All");
2811 if (fThreadsFilterComboBox->count() < 2) {
2812 if (fThreadsFilterComboBox->findText(
"Master", Qt::MatchExactly) == -1) {
2813 fThreadsFilterComboBox->addItem(
"Master");
2817 G4String prefix = GetThreadPrefix();
2818 if (! prefix.empty()) {
2819 if (fThreadsFilterComboBox->findText(prefix.data(), Qt::MatchExactly) == -1) {
2820 fThreadsFilterComboBox->addItem(prefix.data());
2833 if (aName ==
nullptr)
return;
2834 if (aLabel ==
nullptr)
return;
2836 auto fileMenu =
new QMenu(aLabel);
2837 fMainWindow->menuBar()->addMenu(fileMenu);
2850 if (aMenu ==
nullptr)
return;
2851 if (aLabel ==
nullptr)
return;
2852 if (aCommand ==
nullptr)
return;
2856 if (parentTmp ==
nullptr) {
2861 G4cout <<
"Menu name " << aMenu <<
" does not exist, please define it before using it."
2869 if (UI ==
nullptr)
return;
2873 std::size_t cmdEndPos = cmd.find_first_of(
" \t");
2874 if (cmdEndPos != std::string::npos) {
2875 cmd.erase(cmdEndPos);
2878 if (treeTop->
FindPath(cmd) ==
nullptr) {
2879 if (cmd !=
"ls" && cmd.substr(0, 3) !=
"ls " && cmd !=
"pwd" && cmd !=
"cd" &&
2880 cmd.substr(0, 3) !=
"cd " && cmd !=
"help" && cmd.substr(0, 5) !=
"help " &&
2881 cmd[0] !=
'?' && cmd !=
"hist" && cmd !=
"history" && cmd[0] !=
'!' && cmd !=
"exit" &&
2882 cmd !=
"cont" && cmd !=
"continue")
2888 G4cout <<
"Warning: command '" << cmd
2889 <<
"' does not exist, please define it before using it." <<
G4endl;
2894 QString cmd_tmp = QString(aCommand);
2895 parentTmp->addAction(aLabel,
this, [
this, cmd_tmp]() { this->ButtonCallback(cmd_tmp); });
2903 const char* aLabel,
const char* aIconFile,
const char* aCommand,
const char* aFileName)
2905 if (aLabel ==
nullptr)
return;
2907 if (aCommand ==
nullptr) {
2908 if (std::string(aIconFile) ==
"user_icon") {
2913 G4bool userToolBar =
false;
2915 if (! fDefaultIcons) {
2918 if (std::string(aIconFile) ==
"user_icon") {
2921 pix =
new QPixmap(UImanager->
FindMacroPath(aFileName).data());
2922 if (pix->isNull()) {
2926 G4cout <<
"Warning: file '" << aFileName
2927 <<
"' is incorrect or does not exist, this command will not be build" <<
G4endl;
2932 else if (std::string(aIconFile) ==
"open") {
2935 else if (std::string(aIconFile) ==
"save") {
2938 else if (std::string(aIconFile) ==
"move") {
2941 else if (std::string(aIconFile) ==
"rotate") {
2944 else if (std::string(aIconFile) ==
"pick") {
2947 else if (std::string(aIconFile) ==
"zoom_in") {
2950 else if (std::string(aIconFile) ==
"zoom_out") {
2953 else if (std::string(aIconFile) ==
"wireframe") {
2954 pix = fWireframeIcon;
2956 else if (std::string(aIconFile) ==
"solid") {
2959 else if (std::string(aIconFile) ==
"hidden_line_removal") {
2960 pix = fHiddenLineRemovalIcon;
2962 else if (std::string(aIconFile) ==
"hidden_line_and_surface_removal") {
2963 pix = fHiddenLineAndSurfaceRemovalIcon;
2965 else if (std::string(aIconFile) ==
"perspective") {
2966 pix = fPerspectiveIcon;
2968 else if (std::string(aIconFile) ==
"ortho") {
2971 else if (std::string(aIconFile) ==
"runBeamOn") {
2974 else if (std::string(aIconFile) ==
"exit") {
2982 G4cout <<
"Parameter" << aIconFile <<
" not defined" <<
G4endl;
2986 QToolBar* currentToolbar =
nullptr;
2988 if (fToolbarUser ==
nullptr) {
2989 fToolbarUser =
new QToolBar();
2990 fToolbarUser->setIconSize(QSize(20, 20));
2991 fMainWindow->addToolBar(Qt::TopToolBarArea, fToolbarUser);
2993 currentToolbar = fToolbarUser;
2996 if (fToolbarApp ==
nullptr) {
2997 fToolbarApp =
new QToolBar();
2998 fToolbarApp->setIconSize(QSize(20, 20));
2999 fMainWindow->addToolBar(Qt::TopToolBarArea, fToolbarApp);
3001 currentToolbar = fToolbarApp;
3006 QList<QAction*> list = currentToolbar->actions();
3008 for (
auto i : list) {
3009 if (i->text() == QString(aLabel)) {
3011 if (UI ==
nullptr)
return;
3014 G4cout <<
"Warning: A toolBar icon \"" << aLabel <<
"\" already exists with the same name!"
3021 if (std::string(aIconFile) ==
"open") {
3022 QString txt = aCommand + fStringSeparator + aLabel;
3023 currentToolbar->addAction(
3024 QIcon(*pix), aIconFile,
this, [
this, txt]() { this->OpenIconCallback(txt); });
3028 else if (std::string(aIconFile) ==
"save") {
3029 QString txt = aCommand + fStringSeparator + aLabel;
3030 currentToolbar->addAction(
3031 QIcon(*pix), aIconFile,
this, [
this, txt]() { this->SaveIconCallback(txt); });
3034 else if ((std::string(aIconFile) ==
"move") || (std::string(aIconFile) ==
"rotate") ||
3035 (std::string(aIconFile) ==
"pick") || (std::string(aIconFile) ==
"zoom_out") ||
3036 (std::string(aIconFile) ==
"zoom_in"))
3038 QString txt = QString(aIconFile);
3039 QAction* action = currentToolbar->addAction(
3040 QIcon(*pix), aIconFile,
this, [
this, txt]() { this->ChangeCursorAction(txt); });
3041 action->setCheckable(
true);
3042 action->setChecked(
true);
3043 action->setData(aIconFile);
3045 if (std::string(aIconFile) ==
"move") {
3048 if (std::string(aIconFile) ==
"rotate") {
3051 if (std::string(aIconFile) ==
"pick") {
3054 if (std::string(aIconFile) ==
"zoom_in") {
3057 if (std::string(aIconFile) ==
"zoom_out") {
3063 else if ((std::string(aIconFile) ==
"hidden_line_removal") ||
3064 (std::string(aIconFile) ==
"hidden_line_and_surface_removal") ||
3065 (std::string(aIconFile) ==
"solid") || (std::string(aIconFile) ==
"wireframe"))
3067 QString txt = QString(aIconFile);
3068 QAction* action = currentToolbar->addAction(
3069 QIcon(*pix), aIconFile,
this, [
this, txt]() { this->ChangeSurfaceStyle(txt); });
3070 action->setCheckable(
true);
3071 action->setChecked(
true);
3072 action->setData(aIconFile);
3074 if (std::string(aIconFile) ==
"hidden_line_removal") {
3077 if (std::string(aIconFile) ==
"hidden_line_and_surface_removal") {
3080 if (std::string(aIconFile) ==
"solid") {
3083 if (std::string(aIconFile) ==
"wireframe") {
3089 else if ((std::string(aIconFile) ==
"perspective") || (std::string(aIconFile) ==
"ortho")) {
3090 QString txt = QString(aIconFile);
3091 QAction* action = currentToolbar->addAction(
3092 QIcon(*pix), aIconFile,
this, [
this, txt]() { this->ChangePerspectiveOrtho(txt); });
3093 action->setCheckable(
true);
3094 action->setChecked(
true);
3095 action->setData(aIconFile);
3097 if (std::string(aIconFile) ==
"perspective") {
3100 if (std::string(aIconFile) ==
"ortho") {
3107 if (UI ==
nullptr)
return;
3109 if (aCommand !=
nullptr) {
3110 std::string str = aCommand;
3111 std::string::size_type pos = str.find(
' ');
3112 if (pos != std::string::npos) {
3113 str = str.substr(0, pos).c_str();
3115 if (treeTop->
FindPath(str.c_str()) ==
nullptr) {
3120 G4cout <<
"Warning: command '" << aCommand
3121 <<
"' does not exist, please define it before using it." <<
G4endl;
3125 QString txt = QString(aCommand);
3126 currentToolbar->addAction(
3127 QIcon(*pix), aCommand,
this, [
this, txt]() { this->ButtonCallback(txt); });
3142 if (fMainWindow->menuBar()->isNativeMenuBar() == aVal)
return;
3145 fMainWindow->menuBar()->setNativeMenuBar(aVal);
3150void G4UIQt::ActivateCommand(
G4String newCommand)
3152 if (fHelpTreeWidget ==
nullptr) {
3156 std::size_t i = newCommand.find(
' ');
3157 G4String targetCom =
"";
3158 if (i != std::string::npos) {
3159 G4String newValue = newCommand.substr(i + 1, newCommand.length() - (i + 1));
3160 G4StrUtil::strip(newValue);
3163 if (! targetCom.empty()) {
3164 OpenHelpTreeOnCommand(targetCom.data());
3167 fUITabWidget->setCurrentWidget(fHelpTBWidget);
3176void G4UIQt::InitHelpTreeAndVisParametersWidget()
3178 if (fHelpTreeWidget ==
nullptr) {
3179 fHelpTreeWidget =
new QTreeWidget();
3183 fHelpTreeWidget->setSelectionMode(QAbstractItemView::SingleSelection);
3185 labels << QString(
"Command");
3186 fHelpTreeWidget->setHeaderLabels(labels);
3188 connect(fHelpTreeWidget, SIGNAL(itemSelectionChanged()),
this, SLOT(HelpTreeClicCallback()));
3189 connect(fHelpTreeWidget, SIGNAL(itemDoubleClicked(QTreeWidgetItem*,
int)),
this,
3190 SLOT(HelpTreeDoubleClicCallback()));
3198void G4UIQt::FillHelpTree()
3200 if (fHelpTreeWidget ==
nullptr) {
3201 InitHelpTreeAndVisParametersWidget();
3204 QString searchText = fHelpLine->text();
3206 if (searchText ==
"") {
3214 if (fParameterHelpLabel !=
nullptr) {
3215 fParameterHelpLabel->setText(
"Choose a command in the command tree");
3216 fParameterHelpTable->setVisible(
false);
3219 if (fHelpLine !=
nullptr) {
3220 fHelpLine->setText(
"");
3224 if (UI ==
nullptr)
return;
3225 G4UIcommandTree* treeTop = UI->
GetTree();
3228 QTreeWidgetItem* newItem =
nullptr;
3229 QString commandText =
"";
3230 for (
G4int a = 0; a < treeSize; ++a) {
3234 commandText = QString((
char*)(treeTop->
GetTree(a + 1)->
GetPathName()).data()).trimmed();
3237 for (
G4int b = 0; b < fHelpTreeWidget->topLevelItemCount(); ++b) {
3238 if (newItem ==
nullptr) newItem = FindTreeItem(fHelpTreeWidget->topLevelItem(b), commandText);
3241 if (newItem ==
nullptr) {
3242 newItem =
new QTreeWidgetItem();
3243 newItem->setText(0, GetShortCommandPath(commandText));
3244 fHelpTreeWidget->addTopLevelItem(newItem);
3248 CreateHelpTree(newItem, treeTop->
GetTree(a + 1));
3256void G4UIQt::CreateHelpTree(QTreeWidgetItem* aParent, G4UIcommandTree* aCommandTree)
3258 if (aParent ==
nullptr)
return;
3259 if (aCommandTree ==
nullptr)
return;
3262 QTreeWidgetItem* newItem;
3264 QString commandText =
"";
3267 commandText = QString((
char*)(aCommandTree->
GetTree(a + 1)->
GetPathName()).data()).trimmed();
3270 newItem = FindTreeItem(aParent, commandText);
3271 if (newItem ==
nullptr) {
3272 newItem =
new QTreeWidgetItem();
3273 newItem->setText(0, GetShortCommandPath(commandText));
3274 aParent->addChild(newItem);
3276 CreateHelpTree(newItem, aCommandTree->
GetTree(a + 1));
3282 QStringList stringList;
3287 newItem = FindTreeItem(aParent, commandText);
3288 if (newItem ==
nullptr) {
3289 newItem =
new QTreeWidgetItem();
3290 newItem->setText(0, GetShortCommandPath(commandText));
3291 aParent->addChild(newItem);
3292 newItem->setExpanded(
false);
3302G4bool G4UIQt::CreateVisCommandGroupAndToolBox(
3303 G4UIcommand* aCommand, QWidget* aParent,
G4int aDepthLevel,
G4bool isDialog)
3305 QString commandText =
3306 QString((
char*)(aCommand->
GetCommandPath().data())).section(
"/", -aDepthLevel);
3308 if (commandText ==
nullptr) {
3314 QWidget* newParentWidget =
nullptr;
3316 QString commandSection = commandText.left(commandText.indexOf(
"/"));
3318 if (aDepthLevel == 1) {
3319 auto currentParent =
dynamic_cast<QToolBox*
>(aParent);
3320 if (currentParent !=
nullptr) {
3322 for (
G4int a = 0; a < currentParent->count(); ++a) {
3323 if (currentParent->itemText(a) == commandSection) {
3325 newParentWidget = currentParent->widget(a);
3331 newParentWidget =
new QGroupBox();
3332 newParentWidget->setLayout(
new QVBoxLayout());
3333 if (currentParent !=
nullptr) {
3334 currentParent->addItem(newParentWidget, commandSection);
3337 if (aParent->layout() ==
nullptr) {
3338 aParent->setLayout(
new QVBoxLayout());
3340 aParent->layout()->addWidget(newParentWidget);
3343 if (commandText.indexOf(
"/") == -1) {
3347 for (
G4int i_thGuidance = 0; i_thGuidance < n_guidanceEntry; i_thGuidance++) {
3348 guidance += QString((
char*)(aCommand->
GetGuidanceLine(i_thGuidance)).data()) +
"\n";
3350 newParentWidget->setToolTip(guidance);
3353 auto sc =
dynamic_cast<QScrollArea*
>(newParentWidget->parent()->parent());
3354 if (sc !=
nullptr) {
3355 sc->ensureWidgetVisible(newParentWidget);
3361 auto currentParent =
dynamic_cast<QGroupBox*
>(aParent);
3362 if (currentParent !=
nullptr) {
3365 if (aDepthLevel == 2) {
3366 auto parentToolBox =
dynamic_cast<QToolBox*
>(currentParent->parent()->parent()->parent());
3367 if (parentToolBox !=
nullptr) {
3372 for (
G4int a = 0; a < aParent->layout()->count(); ++a) {
3373 auto gb =
dynamic_cast<QGroupBox*
>(aParent->layout()->itemAt(a)->widget());
3374 if (gb !=
nullptr) {
3375 if (gb->title() == commandSection) {
3377 newParentWidget = gb;
3385 newParentWidget =
new QGroupBox();
3386 newParentWidget->setLayout(
new QVBoxLayout());
3387 if (aParent->layout() ==
nullptr) {
3388 aParent->setLayout(
new QVBoxLayout());
3390 aParent->layout()->addWidget(newParentWidget);
3396 for (
G4int i_thGuidance = 0; i_thGuidance < n_guidanceEntry; i_thGuidance++) {
3397 guidance += QString((
char*)(aCommand->
GetGuidanceLine(i_thGuidance)).data()) +
"\n";
3399 newParentWidget->setToolTip(guidance);
3404 if (commandText.indexOf(
"/") == -1) {
3405 if (CreateCommandWidget(aCommand, newParentWidget, isDialog)) {
3410 CreateVisCommandGroupAndToolBox(aCommand, newParentWidget, aDepthLevel - 1, isDialog);
3421G4bool G4UIQt::CreateCommandWidget(G4UIcommand* aCommand, QWidget* aParent,
G4bool isDialog)
3423 if (aCommand ==
nullptr) {
3429 if (n_parameterEntry > 0) {
3430 G4UIparameter* param;
3433 auto paramWidget =
new QWidget();
3434 auto gridLayout =
new QGridLayout();
3435 paramWidget->setLayout(gridLayout);
3438 unsigned int nbColorParameter = 0;
3439 G4bool isStillColorParameter =
false;
3440 G4bool isColorDialogAdded =
false;
3441 QLabel* redLabel =
nullptr;
3442 QLabel* greenLabel =
nullptr;
3443 QString redDefaultStr =
"";
3444 QString greenDefaultStr =
"";
3445 QString blueDefaultStr =
"";
3446 QWidget* redInput =
nullptr;
3447 QWidget* greenInput =
nullptr;
3449 for (
G4int i_thParameter = 0; i_thParameter < n_parameterEntry; i_thParameter++) {
3452 auto label =
new QLabel(QString((
char*)(param->
GetParameterName()).data()));
3454 if ((label->text() ==
"red") || (label->text() ==
"red_or_string")) {
3456 isStillColorParameter =
true;
3458 else if ((label->text() ==
"green") && isStillColorParameter) {
3461 else if ((label->text() ==
"blue") && isStillColorParameter) {
3464 else if (! isColorDialogAdded) {
3466 if (nbColorParameter == 1) {
3467 gridLayout->addWidget(redLabel, i_thParameter - 1, 0);
3468 gridLayout->addWidget(redInput, i_thParameter - 1, 1);
3470 else if (nbColorParameter == 2) {
3471 gridLayout->addWidget(redLabel, i_thParameter - 2, 0);
3472 gridLayout->addWidget(redInput, i_thParameter - 2, 1);
3473 gridLayout->addWidget(greenLabel, i_thParameter - 1, 0);
3474 gridLayout->addWidget(greenInput, i_thParameter - 1, 1);
3476 nbColorParameter = 0;
3479 QWidget* input =
nullptr;
3483 input =
new QLineEdit();
3485 dynamic_cast<QLineEdit*
>(input)->setText(QString((
char*)(param->
GetDefaultValue()).data()));
3487 if (((label->text() ==
"red") || (label->text() ==
"red_or_string")) &&
3488 isStillColorParameter)
3492 else if ((label->text() ==
"green") && isStillColorParameter) {
3495 else if ((label->text() ==
"blue") && isStillColorParameter) {
3500 input =
new QWidget();
3501 auto layout =
new QHBoxLayout();
3502 input->setLayout(layout);
3504 auto buttons =
new QButtonGroup();
3505 auto radioOff =
new QRadioButton(
"0");
3506 auto radioOn =
new QRadioButton(
"1");
3507 buttons->addButton(radioOn);
3508 buttons->addButton(radioOff);
3509 layout->addWidget(radioOn);
3510 layout->addWidget(radioOff);
3513 QString defaultValue = QString((
char*)(param->
GetDefaultValue()).data());
3514 if (defaultValue ==
"0") {
3515 radioOff->setChecked(
true);
3517 else if (defaultValue ==
"1") {
3518 radioOn->setChecked(
true);
3524 input =
new QComboBox();
3526 QStringList list = candidates.split(
" ");
3529 QString defaultValue = QString((
char*)(param->
GetDefaultValue()).data());
3530 for (
int a = 0; a < list.size(); a++) {
3531 dynamic_cast<QComboBox*
>(input)->addItem(list.at(a));
3532 if (list.at(a) == defaultValue) {
3533 dynamic_cast<QComboBox*
>(input)->setCurrentIndex(a);
3538 input =
new QLineEdit();
3540 dynamic_cast<QLineEdit*
>(input)->setText(QString((
char*)(param->
GetDefaultValue()).data()));
3543 input =
new QWidget();
3544 auto layout =
new QHBoxLayout();
3545 input->setLayout(layout);
3547 auto buttons =
new QButtonGroup();
3548 auto radioOff =
new QRadioButton(
"off");
3549 auto radioOn =
new QRadioButton(
"on");
3550 buttons->addButton(radioOn);
3551 buttons->addButton(radioOff);
3552 layout->addWidget(radioOn);
3553 layout->addWidget(radioOff);
3556 QString defaultValue = QString((
char*)(param->
GetDefaultValue()).data());
3557 if (defaultValue ==
"off") {
3558 radioOff->setChecked(
true);
3560 else if (defaultValue ==
"on") {
3561 radioOn->setChecked(
true);
3565 input =
new QLineEdit();
3566 dynamic_cast<QLineEdit*
>(input)->setText(QString((
char*)(param->
GetDefaultValue()).data()));
3569 txt +=
"\nParameter : " + QString((
char*)(param->
GetParameterName()).data()) +
"\n";
3573 txt +=
" Parameter type : " + QString(QChar(param->
GetParameterType())) +
"\n";
3575 txt +=
" Omittable : True\n";
3578 txt +=
" Omittable : False\n";
3581 txt +=
" Default value : taken from the current value\n";
3584 txt +=
" Default value : " + QString((
char*)(param->
GetDefaultValue()).data()) +
"\n";
3587 txt +=
" Parameter range : " + QString((
char*)(param->
GetParameterRange()).data()) +
"\n";
3594 if (isStillColorParameter && (nbColorParameter != 0)) {
3595 if ((label->text() ==
"red") || (label->text() ==
"red_or_string")) {
3599 else if (label->text() ==
"green") {
3603 else if (label->text() ==
"blue") {
3608 if ((redDefaultStr !=
"") && (redDefaultStr !=
"") && (redDefaultStr !=
"")) {
3610 redDefaultStr.toDouble(), greenDefaultStr.toDouble(), blueDefaultStr.toDouble());
3612 QPixmap pixmap = QPixmap(QSize(16, 16));
3614 QPainter painter(&pixmap);
3615 painter.setPen(Qt::black);
3616 painter.drawRect(0, 0, 15, 15);
3618 input =
new QPushButton(
"Change color");
3619 dynamic_cast<QPushButton*
>(input)->setIcon(pixmap);
3620 dynamic_cast<QPushButton*
>(input)->setAccessibleName(
3621 redDefaultStr +
" " + greenDefaultStr +
" " + blueDefaultStr);
3622 label =
new QLabel(
"Choose color");
3626 gridLayout->addWidget(label, i_thParameter - nbColorParameter, 0);
3627 input->setToolTip(
"Select the current color");
3628 gridLayout->addWidget(input, i_thParameter - nbColorParameter, 1);
3631 connect(
dynamic_cast<QPushButton*
>(input), &QPushButton::clicked,
3632 [
this, input]() { this->ChangeColorCallback(input); });
3633 isColorDialogAdded =
true;
3634 isStillColorParameter =
false;
3638 gridLayout->addWidget(label, i_thParameter - nbColorParameter, 0);
3639 input->setToolTip(txt);
3640 gridLayout->addWidget(input, i_thParameter - nbColorParameter, 1);
3646 gridLayout->addWidget(name, n_parameterEntry - nbColorParameter, 0);
3648 auto applyButton =
new QPushButton(
"Apply");
3650 gridLayout->addWidget(applyButton, n_parameterEntry - nbColorParameter, 1);
3651 connect(applyButton, &QPushButton::clicked,
3652 [
this, paramWidget]() { this->VisParameterCallback(paramWidget); });
3657 applyButton->setAutoDefault(
true);
3658 applyButton->setDefault(
true);
3660 auto cancelButton =
new QPushButton(tr(
"&Cancel"));
3661 cancelButton->setAutoDefault(
true);
3662 gridLayout->addWidget(cancelButton, n_parameterEntry - nbColorParameter, 1);
3663 gridLayout->addWidget(applyButton, n_parameterEntry - nbColorParameter, 0);
3665 connect(applyButton, &QPushButton::clicked,
3666 [
this, paramWidget]() { this->VisParameterCallback(paramWidget); });
3668 QWidget* parentCheck = aParent;
3669 QDialog* parentDialog =
nullptr;
3671 while ((parentCheck->parentWidget()) !=
nullptr) {
3672 parentCheck = parentCheck->parentWidget();
3673 parentDialog =
dynamic_cast<QDialog*
>(parentCheck);
3674 if (parentDialog !=
nullptr) {
3675 connect(applyButton, SIGNAL(clicked()), parentDialog, SLOT(accept()));
3676 connect(cancelButton, SIGNAL(clicked()), parentDialog, SLOT(reject()));
3685 if (aParent->layout() ==
nullptr) {
3686 aParent->setLayout(
new QVBoxLayout());
3688 aParent->layout()->addWidget(paramWidget);
3698QTreeWidgetItem* G4UIQt::FindTreeItem(QTreeWidgetItem* aParent,
const QString& aCommand)
3700 if (aParent ==
nullptr)
return nullptr;
3703 QString myCommand = aCommand;
3705 if (myCommand.lastIndexOf(
"/") == (myCommand.size() - 1)) {
3706 myCommand = myCommand.left(myCommand.size() - 1);
3709 if (GetLongCommandPath(aParent) == myCommand)
return aParent;
3711 QTreeWidgetItem* tmp =
nullptr;
3712 for (
G4int a = 0; a < aParent->childCount(); ++a) {
3713 if (tmp ==
nullptr) tmp = FindTreeItem(aParent->child(a), myCommand);
3725QString G4UIQt::GetCommandList(
const G4UIcommand* aCommand)
3728 if (aCommand ==
nullptr)
return txt;
3731 G4String rangeString = aCommand->
GetRange();
3735 if ((commandPath.empty()) && (rangeString.empty()) && (n_guidanceEntry == 0) &&
3736 (n_parameterEntry == 0))
3741 if ((commandPath.length() - 1) !=
'/') {
3742 txt +=
"Command " + QString((
char*)(commandPath).data()) +
"\n";
3744 txt +=
"Guidance :\n";
3746 for (
G4int i_thGuidance = 0; i_thGuidance < n_guidanceEntry; i_thGuidance++) {
3747 txt += QString((
char*)(aCommand->
GetGuidanceLine(i_thGuidance)).data()) +
"\n";
3749 if (! rangeString.empty()) {
3750 txt +=
" Range of parameters : " + QString((
char*)(rangeString).data()) +
"\n";
3752 if (n_parameterEntry > 0) {
3753 G4UIparameter* param;
3757 for (
G4int i_thParameter = 0; i_thParameter < n_parameterEntry; i_thParameter++) {
3759 txt +=
"\nParameter : " + QString((
char*)(param->
GetParameterName()).data()) +
"\n";
3762 txt +=
" Parameter type : " + QString(QChar(param->
GetParameterType())) +
"\n";
3764 txt +=
" Omittable : True\n";
3767 txt +=
" Omittable : False\n";
3770 txt +=
" Default value : taken from the current value\n";
3773 txt +=
" Default value : " + QString((
char*)(param->
GetDefaultValue()).data()) +
"\n";
3776 txt +=
" Parameter range : " + QString((
char*)(param->
GetParameterRange()).data()) +
"\n";
3794void G4UIQt::updateHelpArea(
const G4UIcommand* aCommand)
3796 if (fParameterHelpLabel ==
nullptr)
return;
3797 if (fParameterHelpTable ==
nullptr)
return;
3799 fParameterHelpLabel->setTextInteractionFlags(Qt::NoTextInteraction);
3801 if (aCommand ==
nullptr)
return;
3804 G4String rangeString = aCommand->
GetRange();
3808 if ((commandPath.empty()) && (rangeString.empty()) && (n_guidanceEntry == 0) &&
3809 (n_parameterEntry == 0))
3814 if ((commandPath.length() - 1) !=
'/') {
3815 txt +=
"<b>Command </b> " + QString((
char*)(commandPath).data()) +
"<br />";
3817 txt +=
"<b>Guidance :</b> ";
3818 QString tmpGuidance =
"";
3819 for (
G4int i_thGuidance = 0; i_thGuidance < n_guidanceEntry; i_thGuidance++) {
3820 tmpGuidance = QString((
char*)(aCommand->
GetGuidanceLine(i_thGuidance)).data());
3821 tmpGuidance = tmpGuidance.toHtmlEscaped();
3822 tmpGuidance.replace(
"\n",
"<br />");
3823 txt += tmpGuidance +
"<br />";
3825 if (! rangeString.empty()) {
3826 QString range = QString((
char*)(rangeString).data());
3827 range = range.toHtmlEscaped();
3828 txt +=
"<b>Range of parameters : </b> " + range +
"<br />";
3833 fParameterHelpLabel->setHtml(txt);
3835 if (n_parameterEntry > 0) {
3836 G4UIparameter* param;
3840 fParameterHelpTable->clear();
3841 fParameterHelpTable->setRowCount(n_parameterEntry);
3842 fParameterHelpTable->setColumnCount(8);
3843 fParameterHelpTable->setHorizontalHeaderLabels(
3844 QStringList() << tr(
"") << tr(
"Parameter") << tr(
"Guidance") << tr(
"Type") << tr(
"Ommitable")
3845 << tr(
"Default") << tr(
"Range") << tr(
"Candidate"));
3846 fParameterHelpTable->setColumnWidth(2, 60);
3848 fParameterHelpTable->verticalHeader()->setVisible(
false);
3849 fParameterHelpTable->setAlternatingRowColors(
true);
3850 fParameterHelpTable->verticalHeader()->setSectionResizeMode(QHeaderView::ResizeToContents);
3851 fParameterHelpTable->horizontalHeader()->setSectionResizeMode(2, QHeaderView::Stretch);
3852 fParameterHelpTable->setWordWrap(
true);
3854 QTableWidgetItem* t = fParameterHelpTable->horizontalHeaderItem(1);
3855 QFont fnt = t->font();
3856 G4int size = fnt.pointSize();
3857 fnt.setPointSize(size - 2);
3859 for (
G4int a = 0; a < n_parameterEntry; a++) {
3861 fParameterHelpTable->setItem(a, 0,
new QTableWidgetItem(QString::number(a + 1)));
3863 fParameterHelpTable->setItem(
3864 a, 1,
new QTableWidgetItem(QString((
char*)(param->
GetParameterName()).data())));
3866 fParameterHelpTable->setItem(
3869 fParameterHelpTable->setItem(
3873 fParameterHelpTable->setItem(a, 4,
new QTableWidgetItem(QString(
"True")));
3876 fParameterHelpTable->setItem(a, 4,
new QTableWidgetItem(QString(
"False")));
3879 fParameterHelpTable->setItem(
3880 a, 5,
new QTableWidgetItem(QString(
"taken from the current value")));
3883 fParameterHelpTable->setItem(
3884 a, 5,
new QTableWidgetItem(QString((
char*)(param->
GetDefaultValue()).data())));
3887 fParameterHelpTable->setItem(
3888 a, 6,
new QTableWidgetItem(QString((
char*)(param->
GetParameterRange()).data())));
3891 fParameterHelpTable->setItem(
3895 for (
G4int b = 0; b < 8; ++b) {
3896 QTableWidgetItem* tmp = fParameterHelpTable->item(a, b);
3897 if (tmp !=
nullptr) {
3898 tmp->setToolTip(tmp->text());
3899 tmp->setFlags(Qt::NoItemFlags);
3902 fParameterHelpTable->resizeRowToContents(a);
3904 for (
G4int c = 0; c < 8; ++c) {
3906 fParameterHelpTable->resizeColumnToContents(c);
3909 fParameterHelpLabel->setVisible(
true);
3910 fParameterHelpTable->setVisible(
true);
3919G4bool G4UIQt::IsGUICommand(
const G4UIcommand* aCommand)
3921 if (aCommand ==
nullptr)
return false;
3925 if (n_parameterEntry > 0) {
3926 G4UIparameter* param;
3930 for (
G4int i_thParameter = 0; i_thParameter < n_parameterEntry; i_thParameter++) {
3951G4bool G4UIQt::GetHelpChoice(
G4int&) {
return true; }
3960G4bool G4UIQt::eventFilter(
3961 QObject* aObj, QEvent* aEvent)
3963 G4bool tabKeyPress =
false;
3964 G4bool moveCommandCursor =
false;
3965 if (aObj ==
nullptr)
return false;
3966 if (aEvent ==
nullptr)
return false;
3968 if (aObj == fHistoryTBTableList) {
3969 if (aEvent->type() == QEvent::KeyPress) {
3970 fCommandArea->setFocus();
3974 if (aObj == fCompleter->popup()) {
3975 if (aEvent->type() == QEvent::KeyPress) {
3976 auto e =
static_cast<QKeyEvent*
>(aEvent);
3977 if (e->key() == (Qt::Key_Tab)) {
3981 else if (aEvent->type() == QEvent::Hide) {
3983 QString c = fCommandArea->text();
3984 fLastCompleteCommand = c.left(c.indexOf(
"<"));
3988 if (aObj == fCommandArea) {
3989 if (aEvent->type() == QEvent::KeyPress) {
3990 auto e =
static_cast<QKeyEvent*
>(aEvent);
3991 if ((e->key() == (Qt::Key_Down)) || (e->key() == (Qt::Key_PageDown)) ||
3992 (e->key() == (Qt::Key_Up)) || (e->key() == (Qt::Key_PageUp)))
3994 G4int selection = fHistoryTBTableList->currentRow();
3995 if (fHistoryTBTableList->count() != 0) {
3996 if (selection == -1) {
3997 selection = fHistoryTBTableList->count() - 1;
4000 if (e->key() == (Qt::Key_Down)) {
4001 if (selection < (fHistoryTBTableList->count() - 1)) selection++;
4003 else if (e->key() == (Qt::Key_PageDown)) {
4004 selection = fHistoryTBTableList->count() - 1;
4006 else if (e->key() == (Qt::Key_Up)) {
4007 if (selection > 0) selection--;
4009 else if (e->key() == (Qt::Key_PageUp)) {
4013 fHistoryTBTableList->clearSelection();
4014 fHistoryTBTableList->item(selection)->setSelected(
true);
4015 fHistoryTBTableList->setCurrentItem(fHistoryTBTableList->item(selection));
4017 moveCommandCursor =
true;
4019 else if (e->key() == (Qt::Key_Tab)) {
4022 else if (((e->modifiers() == Qt::ControlModifier) || (e->modifiers() == Qt::MetaModifier)) &&
4023 (e->key() == Qt::Key_A))
4025 fCommandArea->home(
false);
4028 else if (((e->modifiers() == Qt::ControlModifier) || (e->modifiers() == Qt::MetaModifier)) &&
4029 (e->key() == Qt::Key_E))
4031 fCommandArea->end(
false);
4035 else if (aEvent->type() == QEvent::Paint) {
4036 if (fLastCompleteCommand !=
"") {
4037 fCommandArea->setText(fLastCompleteCommand);
4038 fLastCompleteCommand =
"";
4043 G4String ss =
Complete(fCommandArea->text().toStdString().c_str());
4044 fCommandArea->setText((
char*)(ss.data()));
4045 fCommandArea->setFocus();
4054 if (moveCommandCursor) {
4055 fCommandArea->setCursorPosition((
int)fCommandArea->text().length());
4056 fCommandArea->setCursorPosition(4);
4060 res = QObject::eventFilter(aObj, aEvent);
4065void G4UIQt::UpdateCommandCompleter()
4067 if (fCommandArea ==
nullptr)
return;
4070 fCommandArea->setCompleter(
nullptr);
4071 if (fCompleter !=
nullptr) {
4072 if (fCompleter->popup() !=
nullptr) {
4073 fCompleter->popup()->removeEventFilter(
this);
4077 QStandardItemModel* model = CreateCompleterModel(
"/");
4078 fCompleter =
new QCompleter(model);
4082 G4UIcommandTree* commandTreeTop = UI->
GetTree();
4084 if (aTree !=
nullptr) {
4086 fCompleter->setMaxVisibleItems(Ndir);
4088 fCommandArea->setCompleter(fCompleter);
4089 fCompleter->popup()->installEventFilter(
this);
4092QStandardItemModel* G4UIQt::CreateCompleterModel(
const G4String& aCmd)
4094 QList<QStandardItem*> dirModelList;
4095 QList<QStandardItem*> commandModelList;
4096 QList<QStandardItem*> subDirModelList;
4097 QList<QStandardItem*> subCommandModelList;
4102 G4String pName = aCmd;
4103 G4String remainingPath = aCmd;
4104 G4String empty =
"";
4105 G4String matchingPath = empty;
4108 auto jpre = pName.rfind(
'/');
4109 if (jpre != G4String::npos) pName.erase(jpre + 1);
4111 G4UIcommandTree* commandTreeTop = UI->
GetTree();
4113 if (aTree !=
nullptr) {
4118 for (
G4int idir = 1; idir <= Ndir; ++idir) {
4121 if (fpdir.find(remainingPath, 0) == 0) {
4123 matchingPath = fpdir;
4131 auto item1 =
new QStandardItem(fpdir.data());
4132 QIcon i = QIcon(*fDirIcon);
4134 item1->setIcon(QIcon(*fDirIcon));
4135 dirModelList.append(item1);
4138 QStandardItemModel* subModel = CreateCompleterModel(fpdir.data());
4139 for (
G4int a = 0; a < subModel->rowCount(); ++a) {
4141 auto tempItem =
new QStandardItem(subModel->item(a)->text());
4142 tempItem->setIcon(subModel->item(a)->icon());
4143 tempItem->setToolTip(subModel->item(a)->toolTip());
4144 tempItem->setData(subModel->item(a)->data());
4147 if (tempItem->data() == 1) {
4149 subDirModelList.append(tempItem);
4152 else if (tempItem->data() == 0) {
4153 subCommandModelList.append(tempItem);
4160 G4int n_parameterEntry;
4161 G4String rangeString;
4162 G4int n_guidanceEntry;
4163 G4UIcommand* command;
4164 G4UIparameter* param;
4165 std::string tooltip;
4168 for (
G4int icmd = 1; icmd <= Ncmd; ++icmd) {
4178 if (longCommandName.find(remainingPath, 0) == 0) {
4180 matchingPath = longCommandName +
" ";
4183 strtmp = longCommandName +
" ";
4188 for (
G4int i_thGuidance = 0; i_thGuidance < n_guidanceEntry; i_thGuidance++) {
4189 tooltip += std::string((command->
GetGuidanceLine(i_thGuidance)).data());
4190 if (i_thGuidance < n_guidanceEntry - 1) {
4196 for (
G4int a = 0; a < n_parameterEntry; a++) {
4208 auto item =
new QStandardItem(G4String(longCommandName + params).data());
4210 item->setIcon(QIcon(*fCommandIcon));
4211 item->setToolTip(tooltip.c_str());
4213 commandModelList.append(item);
4218 auto model =
new QStandardItemModel();
4220 model->setColumnCount(1);
4223 for (
auto a : dirModelList) {
4224 model->appendRow(a);
4226 for (
auto a : subDirModelList) {
4227 model->appendRow(a);
4229 for (
auto a : commandModelList) {
4230 model->appendRow(a);
4232 for (
auto a : subCommandModelList) {
4233 model->appendRow(a);
4251void G4UIQt::ClearButtonCallback()
4253 fCoutTBTextArea->clear();
4254 fG4OutputString.clear();
4261void G4UIQt::ExitHelp()
const {}
4266void G4UIQt::CommandEnteredCallback()
4269 fCommandArea->setText(fCommandArea->text().trimmed());
4270#if (QT_VERSION < QT_VERSION_CHECK(5, 15, 0))
4271 QStringList list = fCommandArea->text().split(QRegularExpression(
"[\r\n]"),QString::SkipEmptyParts);
4273 QStringList list = fCommandArea->text().split(QRegularExpression(
"[\r\n]"),Qt::SkipEmptyParts);
4277 for (
G4int a = 0; a < list.size(); ++a) {
4278 QString txt(list[a].trimmed());
4280 fHistoryTBTableList->addItem(txt);
4281 fHistoryTBTableList->clearSelection();
4282 fHistoryTBTableList->setCurrentItem(
nullptr);
4283 fCommandArea->setText(
"");
4285 if (interactorManager !=
nullptr) {
4289 G4String command = txt.toStdString().c_str();
4290 if (command.substr(0, 4) !=
"help") {
4294 ActivateCommand(command);
4299 fCommandArea->setFocus();
4305 UpdateCommandCompleter();
4314void G4UIQt::CommandEditedCallback(
const QString&)
4316#if (QT_VERSION < QT_VERSION_CHECK(5, 15, 0))
4317 QStringList list = fCommandArea->text().split(QRegularExpression(
"[\r\n]"), QString::SkipEmptyParts);
4319 QStringList list = fCommandArea->text().split(QRegularExpression(
"[\r\n]"), Qt::SkipEmptyParts);
4322 if (list.size() > 1) {
4323 for (
G4int a = 0; a < list.size() - 1; ++a) {
4325 fCommandArea->setText(list[a]);
4327 CommandEnteredCallback();
4330 fCommandArea->setText(list[list.size() - 1]);
4336void G4UIQt::VisParameterCallback(QWidget* widget)
4338 if (widget ==
nullptr) {
4343 auto grid =
dynamic_cast<QGridLayout*
>(widget->layout());
4344 if (grid ==
nullptr) {
4348 QWidget*
name = grid->itemAtPosition(grid->rowCount() - 1, 0)->widget();
4349 if (
dynamic_cast<QLabel*
>(name) ==
nullptr) {
4352 command += (
dynamic_cast<QLabel*
>(
name))->text() +
" ";
4354 for (
G4int a = 0; a < grid->rowCount() - 1; ++a) {
4355 QWidget* widgetTmp = grid->itemAtPosition(a, 1)->widget();
4358 if (widgetTmp !=
nullptr) {
4359 if (
dynamic_cast<QLineEdit*
>(widgetTmp) !=
nullptr) {
4360 command += (
dynamic_cast<QLineEdit*
>(widgetTmp))->text() +
" ";
4362 else if (
dynamic_cast<QComboBox*
>(widgetTmp) !=
nullptr) {
4363 command += (
dynamic_cast<QComboBox*
>(widgetTmp))
4364 ->itemText((
dynamic_cast<QComboBox*
>(widgetTmp))->currentIndex()) +
4369 else if (
dynamic_cast<QPushButton*
>(widgetTmp) !=
nullptr) {
4370 command += widgetTmp->accessibleName() +
" ";
4374 else if (
dynamic_cast<QWidget*
>(widgetTmp) !=
nullptr) {
4375 if (widgetTmp->layout()->count() > 0) {
4376 if (
dynamic_cast<QRadioButton*
>(widgetTmp->layout()->itemAt(0)->widget()) !=
nullptr) {
4377 QAbstractButton* checked =
4378 (
dynamic_cast<QRadioButton*
>(widgetTmp->layout()->itemAt(0)->widget()))
4381 if (checked !=
nullptr) {
4382 command += (
dynamic_cast<QRadioButton*
>(widgetTmp->layout()->itemAt(0)->widget()))
4393 if (command !=
"") {
4395 if (UI !=
nullptr) {
4406void G4UIQt::ButtonCallback(
const QString& aCommand)
4408 G4String ss = G4StrUtil::lstrip_copy(G4String(aCommand.toStdString().c_str()));
4411 if (UI ==
nullptr)
return;
4412 G4UIcommandTree* treeTop = UI->
GetTree();
4414 G4UIcommand* command = treeTop->
FindPath(ss);
4416 if (command !=
nullptr) {
4418 if (IsGUICommand(command)) {
4419 auto menuParameterDialog =
new QDialog();
4421 if (CreateVisCommandGroupAndToolBox(command, menuParameterDialog, 1,
true)) {
4422 menuParameterDialog->setWindowTitle(aCommand);
4423 menuParameterDialog->setSizePolicy(QSizePolicy(QSizePolicy::Minimum, QSizePolicy::Minimum));
4426 menuParameterDialog->exec();
4429 delete menuParameterDialog;
4443void G4UIQt::HelpTreeClicCallback()
4445 QTreeWidgetItem* item =
nullptr;
4446 if (fHelpTreeWidget ==
nullptr)
return;
4448 QList<QTreeWidgetItem*> list = fHelpTreeWidget->selectedItems();
4449 if (list.isEmpty())
return;
4450 item = list.first();
4451 if (item ==
nullptr)
return;
4454 if (UI ==
nullptr)
return;
4455 G4UIcommandTree* treeTop = UI->
GetTree();
4457 std::string itemText = GetLongCommandPath(item).toStdString();
4460 if (item->childCount() > 0) {
4463 G4UIcommand* command = treeTop->
FindPath(itemText.c_str());
4465 if (command !=
nullptr) {
4466 updateHelpArea(command);
4470 if (path !=
nullptr) {
4473 fParameterHelpLabel->setVisible(
true);
4474 fParameterHelpLabel->setText(path->
GetTitle().data());
4475 fParameterHelpTable->setVisible(
false);
4482void G4UIQt::HelpTreeDoubleClicCallback()
4484 HelpTreeClicCallback();
4486 QTreeWidgetItem* item =
nullptr;
4487 if (fHelpTreeWidget ==
nullptr)
return;
4489 QList<QTreeWidgetItem*> list = fHelpTreeWidget->selectedItems();
4490 if (list.isEmpty())
return;
4491 item = list.first();
4492 if (item ==
nullptr)
return;
4494 fCommandArea->clear();
4495 fCommandArea->setText(GetLongCommandPath(item));
4501void G4UIQt::CommandHistoryCallback()
4503 QListWidgetItem* item =
nullptr;
4504 if (fHistoryTBTableList ==
nullptr)
return;
4506 QList<QListWidgetItem*> list = fHistoryTBTableList->selectedItems();
4507 if (list.isEmpty())
return;
4508 item = list.first();
4509 if (item ==
nullptr)
return;
4510 fCommandArea->setText(item->text());
4513void G4UIQt::ThreadComboBoxCallback(
int) { CoutFilterCallback(
""); }
4515void G4UIQt::CoutFilterCallback(
const QString&)
4517 FilterAllOutputTextArea();
4519 fCoutTBTextArea->repaint();
4520 fCoutTBTextArea->verticalScrollBar()->setSliderPosition(
4521 fCoutTBTextArea->verticalScrollBar()->maximum());
4524void G4UIQt::SaveOutputCallback()
4526 QString fileName = QFileDialog::getSaveFileName(
4527 fMainWindow,
"Save console output as...", fLastOpenPath,
"Save output as...");
4528 if (fileName !=
"") {
4529 QFile data(fileName);
4530 if (data.open(QFile::WriteOnly | QFile::Truncate)) {
4531 QTextStream out(&data);
4532 out << fCoutTBTextArea->toPlainText();
4539QString G4UIQt::FilterOutput(
4540 const G4UIOutputString& output,
const QString& currentThread,
const QString& filter)
4542#ifdef G4MULTITHREADED
4543 if ((currentThread ==
"All") || (currentThread == output.
fThread.data())) {
4545 if (currentThread ==
"") {
4547 if (output.
fText.contains(QRegularExpression(filter))) {
4548 return output.
fText;
4554void G4UIQt::FilterAllOutputTextArea()
4556 QString currentThread =
"";
4557#ifdef G4MULTITHREADED
4558 currentThread = fThreadsFilterComboBox->currentText();
4559 if (currentThread ==
"Master") {
4563 QString filter = fCoutFilter->text();
4564 G4String previousOutputStream =
"";
4569 fCoutTBTextArea->clear();
4571 for (
auto& out : fG4OutputString) {
4572 if (FilterOutput(out, currentThread, filter) !=
"") {
4574 if (out.fOutputStream != previousOutputStream) {
4575 previousOutputStream = out.fOutputStream;
4576 if (out.fOutputStream ==
"info") {
4580 else if (out.fOutputStream ==
"warning") {
4581 pref =
"<font color=\"DarkYellow\">";
4585 pref =
"<font color=\"Red\">";
4589 fCoutTBTextArea->append(pref + out.fText + post);
4598void G4UIQt::LookForHelpStringCallback()
4600 fHelpLine->setText(fHelpLine->text().trimmed());
4601 QString searchText = fHelpLine->text();
4603 fParameterHelpLabel->setText(
"");
4604 fParameterHelpTable->setVisible(
false);
4605 if (searchText ==
"") {
4607 fHelpTreeWidget->clear();
4613 OpenHelpTreeOnCommand(searchText);
4616void G4UIQt::OpenHelpTreeOnCommand(
const QString& searchText)
4620 if (UI ==
nullptr)
return;
4621 G4UIcommandTree* treeTop = UI->
GetTree();
4626 fHelpTreeWidget->clear();
4632#if (QT_VERSION < QT_VERSION_CHECK(5, 15, 0))
4634 QMap<G4int, QString> commandResultMap;
4635 QMap<G4int, QString> commandChildResultMap;
4636 for (
G4int a = 0; a < treeSize; ++a) {
4638 tmp = GetCommandList(command).count(searchText, Qt::CaseInsensitive);
4640 commandResultMap.insertMulti(
4644 commandChildResultMap = LookForHelpStringInChildTree(treeTop->
GetTree(a + 1), searchText);
4646 if (! commandChildResultMap.empty()) {
4647 QMap<int, QString>::const_iterator i = commandChildResultMap.constBegin();
4648 while (i != commandChildResultMap.constEnd()) {
4649 commandResultMap.insertMulti(i.key(), i.value());
4652 commandChildResultMap.clear();
4657 QMultiMap<G4int, QString> commandResultMap;
4658 QMultiMap<G4int, QString> commandChildResultMap;
4659 for (
G4int a = 0; a < treeSize; ++a) {
4661 tmp = (int)GetCommandList(command).count(searchText, Qt::CaseInsensitive);
4663 commandResultMap.insert(tmp, QString((
char*)(treeTop->
GetTree(a + 1)->
GetPathName()).data()));
4666 commandChildResultMap = LookForHelpStringInChildTree(treeTop->
GetTree(a + 1), searchText);
4668 if (! commandChildResultMap.empty()) {
4669 auto i = commandChildResultMap.constBegin();
4670 while (i != commandChildResultMap.constEnd()) {
4671 commandResultMap.insert(i.key(), i.value());
4674 commandChildResultMap.clear();
4680 fHelpTreeWidget->setSelectionMode(QAbstractItemView::SingleSelection);
4681 fHelpTreeWidget->setColumnCount(2);
4683 labels << QString(
"Command") << QString(
"Match");
4684 fHelpTreeWidget->setHeaderLabels(labels);
4686 if (commandResultMap.empty()) {
4687 fParameterHelpLabel->setText(
"No match found");
4688 fParameterHelpTable->setVisible(
false);
4692 auto i = commandResultMap.constEnd();
4696 QString progressChar =
"|";
4697 QString progressStr =
"|";
4699 QTreeWidgetItem* newItem;
4702 if (i == commandResultMap.constBegin()) {
4705 for (
G4int a = 0; a <
G4int(i.key() * multValue); ++a) {
4706 progressStr += progressChar;
4708 newItem =
new QTreeWidgetItem();
4709 QString commandStr = i.value().trimmed();
4711 if (commandStr.indexOf(
"/") == 0) {
4712 commandStr = commandStr.right(commandStr.size() - 1);
4715 newItem->setText(0, commandStr);
4716 newItem->setText(1, progressStr);
4717 fHelpTreeWidget->addTopLevelItem(newItem);
4718 newItem->setForeground(1, QBrush(Qt::blue));
4722 fHelpTreeWidget->resizeColumnToContents(0);
4723 fHelpTreeWidget->sortItems(1, Qt::DescendingOrder);
4727#if (QT_VERSION < QT_VERSION_CHECK(5, 15, 0))
4729QMap<G4int, QString> G4UIQt::LookForHelpStringInChildTree(
4730 G4UIcommandTree* aCommandTree,
const QString& text)
4732 QMap<G4int, QString> commandResultMap;
4733 if (aCommandTree == NULL)
return commandResultMap;
4736 QMap<G4int, QString> commandChildResultMap;
4738 const G4UIcommand* command = aCommandTree->
GetGuidance();
4739 tmp = GetCommandList(command).count(text, Qt::CaseInsensitive);
4741 commandResultMap.insertMulti(
4745 commandChildResultMap = LookForHelpStringInChildTree(aCommandTree->
GetTree(a + 1), text);
4746 if (! commandChildResultMap.empty()) {
4748 QMap<G4int, QString>::const_iterator i = commandChildResultMap.constBegin();
4749 while (i != commandChildResultMap.constEnd()) {
4750 commandResultMap.insertMulti(i.key(), i.value());
4753 commandChildResultMap.clear();
4758 const G4UIcommand* command = aCommandTree->
GetCommand(a + 1);
4759 tmp = GetCommandList(command).count(text, Qt::CaseInsensitive);
4761 commandResultMap.insertMulti(
4765 return commandResultMap;
4769QMultiMap<G4int, QString> G4UIQt::LookForHelpStringInChildTree(
4770 G4UIcommandTree* aCommandTree,
const QString& text)
4772 QMultiMap<G4int, QString> commandResultMap;
4773 if (aCommandTree ==
nullptr)
return commandResultMap;
4776 QMultiMap<G4int, QString> commandChildResultMap;
4778 const G4UIcommand* command = aCommandTree->
GetGuidance();
4779 tmp = (int)GetCommandList(command).count(text, Qt::CaseInsensitive);
4781 commandResultMap.insert(
4785 commandChildResultMap = LookForHelpStringInChildTree(aCommandTree->
GetTree(a + 1), text);
4786 if (! commandChildResultMap.empty()) {
4788 auto i = commandChildResultMap.constBegin();
4789 while (i != commandChildResultMap.constEnd()) {
4790 commandResultMap.insert(i.key(), i.value());
4793 commandChildResultMap.clear();
4798 const G4UIcommand* command = aCommandTree->
GetCommand(a + 1);
4799 tmp = (int)GetCommandList(command).count(text, Qt::CaseInsensitive);
4801 commandResultMap.insert(
4805 return commandResultMap;
4809QString G4UIQt::GetShortCommandPath(QString& commandPath)
4811 if (commandPath.indexOf(
"/") == 0) {
4812 commandPath = commandPath.right(commandPath.size() - 1);
4815 commandPath = commandPath.right(commandPath.size() - commandPath.lastIndexOf(
"/", -2) - 1);
4817 if (commandPath.lastIndexOf(
"/") == (commandPath.size() - 1)) {
4818 commandPath = commandPath.left(commandPath.size() - 1);
4824QString G4UIQt::GetLongCommandPath(QTreeWidgetItem* item)
4826 if (item ==
nullptr)
return "";
4829 QString itemText =
"";
4830 itemText = item->text(0);
4832 while (item->parent() !=
nullptr) {
4833 itemText = item->parent()->text(0) +
"/" + itemText;
4834 item = item->parent();
4836 itemText =
"/" + itemText;
4841void G4UIQt::ChangeColorCallback(QWidget* widget)
4843 if (widget ==
nullptr) {
4847 auto button =
dynamic_cast<QPushButton*
>(widget);
4848 if (button ==
nullptr) {
4851 QString value = button->accessibleName();
4854 old.setRgbF(value.section(
" ", 0, 1).toDouble(), value.section(
" ", 1, 2).toDouble(),
4855 value.section(
" ", 2, 3).toDouble());
4857 QColorDialog::getColor(old, fUITabWidget,
"Change color", QColorDialog::ShowAlphaChannel);
4859 if (color.isValid()) {
4861 QPixmap pixmap = QPixmap(QSize(16, 16));
4863 QPainter painter(&pixmap);
4864 painter.setPen(Qt::black);
4865 painter.drawRect(0, 0, 15, 15);
4867 button->setAccessibleName(QString::number(color.redF()) +
" " +
4868 QString::number(color.greenF()) +
" " +
4869 QString::number(color.blueF()) +
" ");
4870 button->setIcon(pixmap);
4874void G4UIQt::ChangeCursorAction(
const QString& action)
4878 fMoveSelected =
true;
4879 fPickSelected =
true;
4880 fRotateSelected =
true;
4881 fZoomInSelected =
true;
4882 fZoomOutSelected =
true;
4884 if (fToolbarApp ==
nullptr)
return;
4885 QList<QAction*> list = fToolbarApp->actions();
4886 for (
auto i : list) {
4887 if (i->data().toString() == action) {
4888 i->setChecked(
true);
4889 if (i->data().toString() ==
"pick") {
4891 CreatePickInfosDialog();
4893 fPickInfosDialog->show();
4894 fPickInfosDialog->raise();
4895 fPickInfosDialog->activateWindow();
4898 else if (i->data().toString() ==
"move") {
4899 fMoveSelected =
false;
4900 i->setChecked(
false);
4902 else if (i->data().toString() ==
"pick") {
4903 fPickSelected =
false;
4904 i->setChecked(
false);
4906 if (fPickInfosDialog !=
nullptr) {
4907 fPickInfosDialog->hide();
4910 else if (i->data().toString() ==
"rotate") {
4911 fRotateSelected =
false;
4912 i->setChecked(
false);
4914 else if (i->data().toString() ==
"zoom_in") {
4915 fZoomInSelected =
false;
4916 i->setChecked(
false);
4918 else if (i->data().toString() ==
"zoom_out") {
4919 fZoomOutSelected =
false;
4920 i->setChecked(
false);
4932void G4UIQt::ChangeSurfaceStyle(
const QString& action)
4936 if (fToolbarApp ==
nullptr)
return;
4937 QList<QAction*> list = fToolbarApp->actions();
4938 for (
auto i : list) {
4939 if (i->data().toString() == action) {
4940 i->setChecked(
true);
4942 else if (i->data().toString() ==
"hidden_line_removal") {
4943 i->setChecked(
false);
4945 else if (i->data().toString() ==
"hidden_line_and_surface_removal") {
4946 i->setChecked(
false);
4948 else if (i->data().toString() ==
"solid") {
4949 i->setChecked(
false);
4951 else if (i->data().toString() ==
"wireframe") {
4952 i->setChecked(
false);
4957 if (action ==
"hidden_line_removal") {
4961 else if (action ==
"hidden_line_and_surface_removal") {
4965 else if (action ==
"solid") {
4969 else if (action ==
"wireframe") {
4975void G4UIQt::OpenIconCallback(
const QString& aParam)
4977 QString aCommand = aParam.left(aParam.indexOf(fStringSeparator));
4978 QString aLabel = aParam.mid(aParam.indexOf(fStringSeparator) + fStringSeparator.length());
4980 QString nomFich = QFileDialog::getOpenFileName(fMainWindow, aLabel, fLastOpenPath,
4981 "Macro files (*.mac);;Geant4 files( *.mac *.g4* *.in);;All (*.*)");
4982 if (nomFich !=
"") {
4984 (QString(aCommand) + QString(
" ") + nomFich).toStdString().c_str());
4986 fLastOpenPath = dir.absoluteFilePath(nomFich);
4990void G4UIQt::SaveIconCallback(
const QString& aParam)
4992 QString aCommand = aParam.left(aParam.indexOf(fStringSeparator));
4993 QString aLabel = aParam.mid(aParam.indexOf(fStringSeparator) + fStringSeparator.length());
4996 QFileDialog::getSaveFileName(fMainWindow, aLabel, fLastOpenPath,
"Macro files (*.mac)");
4997 if (nomFich !=
"") {
4999 (QString(aCommand) + QString(
" ") + nomFich).toStdString().c_str());
5001 fLastOpenPath = dir.absoluteFilePath(nomFich);
5005void G4UIQt::CreateViewerPropertiesDialog()
5007 if (fViewerPropertiesDialog !=
nullptr) {
5010 fViewerPropertiesDialog =
new QDialog();
5012 fViewerPropertiesDialog->setWindowTitle(
"Viewer properties");
5013 fViewerPropertiesDialog->setSizePolicy(
5014 QSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding));
5016 if (fViewerPropertiesWidget ==
nullptr) {
5017 fViewerPropertiesWidget =
new QWidget();
5018 auto layoutPropertiesWidget =
new QVBoxLayout();
5019 fViewerPropertiesWidget->setLayout(layoutPropertiesWidget);
5021 CreateEmptyViewerPropertiesWidget();
5024 auto layoutDialog =
new QVBoxLayout();
5026 layoutDialog->addWidget(fViewerPropertiesWidget);
5027 layoutDialog->setContentsMargins(0, 0, 0, 0);
5028 fViewerPropertiesDialog->setLayout(layoutDialog);
5031void G4UIQt::CreatePickInfosDialog()
5033 if (fPickInfosDialog !=
nullptr) {
5036 fPickInfosDialog =
new QDialog();
5038 fPickInfosDialog->setWindowTitle(
"Pick infos");
5039 fPickInfosDialog->setSizePolicy(QSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding));
5041 if (fPickInfosWidget ==
nullptr) {
5042 fPickInfosWidget =
new QWidget();
5043 auto layoutPickInfos =
new QVBoxLayout();
5044 fPickInfosWidget->setLayout(layoutPickInfos);
5046 CreateEmptyPickInfosWidget();
5049 auto layoutDialog =
new QVBoxLayout();
5051 layoutDialog->addWidget(fPickInfosWidget);
5052 layoutDialog->setContentsMargins(0, 0, 0, 0);
5053 fPickInfosDialog->setLayout(layoutDialog);
5054 fPickInfosDialog->setWindowFlags(Qt::WindowStaysOnTopHint);
5057void G4UIQt::CreateEmptyViewerPropertiesWidget()
5059 if (fViewerPropertiesWidget ==
nullptr)
return;
5060 if (fViewerPropertiesWidget->layout() ==
nullptr)
return;
5062 if (fViewerPropertiesWidget->layout()->count() != 0) {
5063 while ((wItem = fViewerPropertiesWidget->layout()->takeAt(0)) !=
nullptr) {
5064 delete wItem->widget();
5069 auto label =
new QLabel(
"No viewer - Please open a viewer first");
5070 fViewerPropertiesWidget->layout()->addWidget(label);
5071 fViewerPropertiesDialog->setWindowTitle(
"No viewer");
5072 fViewerPropertiesDialog->setVisible(
false);
5075void G4UIQt::CreateEmptyPickInfosWidget()
5078 if (fPickInfosWidget->layout()->count() != 0) {
5079 while ((wItem = fPickInfosWidget->layout()->takeAt(0)) !=
nullptr) {
5080 delete wItem->widget();
5085 auto label =
new QLabel(
"Click on the object you want to pick");
5086 fPickInfosWidget->layout()->addWidget(label);
5087 fPickInfosDialog->setWindowTitle(
"Nothing to pick");
5090void G4UIQt::ViewerPropertiesIconCallback(
int)
5092 CreateViewerPropertiesDialog();
5094 fViewerPropertiesDialog->show();
5095 fViewerPropertiesDialog->raise();
5096 fViewerPropertiesDialog->activateWindow();
5099void G4UIQt::ChangePerspectiveOrtho(
const QString& action)
5103 if (fToolbarApp ==
nullptr)
return;
5104 QList<QAction*> list = fToolbarApp->actions();
5105 QString checked =
"";
5106 for (
auto i : list) {
5107 if (i->data().toString() == action) {
5108 i->setChecked(
true);
5109 checked = i->data().toString();
5111 else if (i->data().toString() ==
"perspective") {
5112 i->setChecked(
false);
5114 else if (i->data().toString() ==
"ortho") {
5115 i->setChecked(
false);
5119 if ((action ==
"ortho") && (checked ==
"ortho")) {
5122 else if ((action ==
"perspective") && (checked ==
"perspective")) {
5130 fMoveSelected =
true;
5131 fRotateSelected =
false;
5132 fPickSelected =
false;
5133 fZoomInSelected =
false;
5134 fZoomOutSelected =
false;
5136 if (fToolbarApp ==
nullptr)
return;
5137 QList<QAction*> list = fToolbarApp->actions();
5138 for (
auto i : list) {
5139 if (i->data().toString() ==
"move") {
5140 i->setChecked(
true);
5142 else if (i->data().toString() ==
"rotate") {
5143 i->setChecked(
false);
5145 else if (i->data().toString() ==
"pick") {
5146 i->setChecked(
false);
5148 else if (i->data().toString() ==
"zoom_in") {
5149 i->setChecked(
false);
5151 else if (i->data().toString() ==
"zoom_out") {
5152 i->setChecked(
false);
5160 fRotateSelected =
true;
5161 fMoveSelected =
false;
5162 fPickSelected =
false;
5163 fZoomInSelected =
false;
5164 fZoomOutSelected =
false;
5166 if (fToolbarApp ==
nullptr)
return;
5167 QList<QAction*> list = fToolbarApp->actions();
5168 for (
auto i : list) {
5169 if (i->data().toString() ==
"rotate") {
5170 i->setChecked(
true);
5172 else if (i->data().toString() ==
"move") {
5173 i->setChecked(
false);
5175 else if (i->data().toString() ==
"pick") {
5176 i->setChecked(
false);
5178 else if (i->data().toString() ==
"zoom_in") {
5179 i->setChecked(
false);
5181 else if (i->data().toString() ==
"zoom_out") {
5182 i->setChecked(
false);
5190 fPickSelected =
true;
5191 fMoveSelected =
false;
5192 fRotateSelected =
false;
5193 fZoomInSelected =
false;
5194 fZoomOutSelected =
false;
5196 QToolBar* bar = fToolbarApp;
5197 if (! fDefaultIcons) {
5200 if (bar ==
nullptr)
return;
5202 QList<QAction*> list = bar->actions();
5203 for (
auto i : list) {
5204 if (i->data().toString() ==
"pick") {
5205 i->setChecked(
true);
5207 else if (i->data().toString() ==
"move") {
5208 i->setChecked(
false);
5210 else if (i->data().toString() ==
"rotate") {
5211 i->setChecked(
false);
5213 else if (i->data().toString() ==
"zoom_in") {
5214 i->setChecked(
false);
5216 else if (i->data().toString() ==
"zoom_out") {
5217 i->setChecked(
false);
5225 fZoomInSelected =
true;
5226 fMoveSelected =
false;
5227 fRotateSelected =
false;
5228 fPickSelected =
false;
5229 fZoomOutSelected =
false;
5231 QToolBar* bar = fToolbarApp;
5232 if (! fDefaultIcons) {
5235 if (bar ==
nullptr)
return;
5237 QList<QAction*> list = bar->actions();
5238 for (
auto i : list) {
5239 if (i->data().toString() ==
"zoom_in") {
5240 i->setChecked(
true);
5242 else if (i->data().toString() ==
"move") {
5243 i->setChecked(
false);
5245 else if (i->data().toString() ==
"rotate") {
5246 i->setChecked(
false);
5248 else if (i->data().toString() ==
"pick") {
5249 i->setChecked(
false);
5251 else if (i->data().toString() ==
"zoom_out") {
5252 i->setChecked(
false);
5260 fZoomOutSelected =
true;
5261 fMoveSelected =
false;
5262 fRotateSelected =
false;
5263 fPickSelected =
false;
5264 fZoomInSelected =
false;
5266 QToolBar* bar = fToolbarApp;
5267 if (! fDefaultIcons) {
5270 if (bar ==
nullptr)
return;
5272 QList<QAction*> list = bar->actions();
5273 for (
auto i : list) {
5274 if (i->data().toString() ==
"zoom_out") {
5275 i->setChecked(
true);
5277 else if (i->data().toString() ==
"move") {
5278 i->setChecked(
false);
5280 else if (i->data().toString() ==
"rotate") {
5281 i->setChecked(
false);
5283 else if (i->data().toString() ==
"pick") {
5284 i->setChecked(
false);
5286 else if (i->data().toString() ==
"zoom_in") {
5287 i->setChecked(
false);
5296 QToolBar* bar = fToolbarApp;
5297 if (! fDefaultIcons) {
5300 if (bar ==
nullptr)
return;
5302 QList<QAction*> list = bar->actions();
5303 for (
auto i : list) {
5304 if (i->data().toString() ==
"solid") {
5305 i->setChecked(
true);
5307 else if (i->data().toString() ==
"hidden_line_removal") {
5308 i->setChecked(
false);
5310 else if (i->data().toString() ==
"hidden_line_and_surface_removal") {
5311 i->setChecked(
false);
5313 else if (i->data().toString() ==
"wireframe") {
5314 i->setChecked(
false);
5323 QToolBar* bar = fToolbarApp;
5324 if (! fDefaultIcons) {
5327 if (bar ==
nullptr)
return;
5329 QList<QAction*> list = bar->actions();
5330 for (
auto i : list) {
5331 if (i->data().toString() ==
"wireframe") {
5332 i->setChecked(
true);
5334 else if (i->data().toString() ==
"hidden_line_removal") {
5335 i->setChecked(
false);
5337 else if (i->data().toString() ==
"hidden_line_and_surface_removal") {
5338 i->setChecked(
false);
5340 else if (i->data().toString() ==
"solid") {
5341 i->setChecked(
false);
5350 QToolBar* bar = fToolbarApp;
5351 if (! fDefaultIcons) {
5354 if (bar ==
nullptr)
return;
5356 QList<QAction*> list = bar->actions();
5357 for (
auto i : list) {
5358 if (i->data().toString() ==
"hidden_line_removal") {
5359 i->setChecked(
true);
5361 else if (i->data().toString() ==
"solid") {
5362 i->setChecked(
false);
5364 else if (i->data().toString() ==
"hidden_line_and_surface_removal") {
5365 i->setChecked(
false);
5367 else if (i->data().toString() ==
"wireframe") {
5368 i->setChecked(
false);
5377 QToolBar* bar = fToolbarApp;
5378 if (! fDefaultIcons) {
5382 if (bar ==
nullptr)
return;
5384 QList<QAction*> list = bar->actions();
5385 for (
auto i : list) {
5386 if (i->data().toString() ==
"hidden_line_and_surface_removal") {
5387 i->setChecked(
true);
5389 else if (i->data().toString() ==
"solid") {
5390 i->setChecked(
false);
5392 else if (i->data().toString() ==
"hidden_line_removal") {
5393 i->setChecked(
false);
5395 else if (i->data().toString() ==
"wireframe") {
5396 i->setChecked(
false);
5405 QToolBar* bar = fToolbarApp;
5406 if (! fDefaultIcons) {
5409 if (bar ==
nullptr)
return;
5411 QList<QAction*> list = bar->actions();
5412 for (
auto i : list) {
5413 if (i->data().toString() ==
"perspective") {
5414 i->setChecked(
true);
5416 else if (i->data().toString() ==
"ortho") {
5417 i->setChecked(
false);
5426 QToolBar* bar = fToolbarApp;
5427 if (! fDefaultIcons) {
5431 if (bar ==
nullptr)
return;
5433 QList<QAction*> list = bar->actions();
5434 for (
auto i : list) {
5435 if (i->data().toString() ==
"ortho") {
5436 i->setChecked(
true);
5438 else if (i->data().toString() ==
"perspective") {
5439 i->setChecked(
false);
5444#if QT_VERSION < 0x060000
5446 : QTabWidget(aParent),
5453 setMinimumSize(100, 100);
5454 QSizePolicy policy = QSizePolicy(QSizePolicy::Preferred, QSizePolicy::Preferred);
5455 setSizePolicy(policy);
5466 if (!
GetOutputList().contains(QString(
" ") + outputStream +
" ")) {
5475void G4UIQt::TabCloseCallback(
int a)
5477 if (fViewerTabWidget ==
nullptr)
return;
5480 QWidget* temp = fViewerTabWidget->widget(a);
5482#if QT_VERSION < 0x060000
5484 fViewerTabWidget->removeTab(a);
5488 for (
G4int c = 0; c < fViewerTabWidget->count(); ++c) {
5489 if (fViewerTabWidget->tabText(c).contains(
"viewer")) {
5495 CreateEmptyViewerPropertiesWidget();
5501 QObject::disconnect(fViewerTabWidget, SIGNAL(currentChanged(
int)),
this, SLOT(UpdateTabWidget(
int)));
5502 fViewerTabWidget->removeTab(a);
5503 QObject::connect(fViewerTabWidget, SIGNAL(currentChanged(
int)),
this, SLOT(UpdateTabWidget(
int)));
5505 G4int lastViewerTabIndex = -1;
5506 for (
G4int c = 0; c < fViewerTabWidget->count(); ++c) {
5507 if (fViewerTabWidget->tabText(c).contains(
"viewer")) {
5508 lastViewerTabIndex = c;
5516 if (lastViewerTabIndex==(-1)) {
5517 CreateEmptyViewerPropertiesWidget();
5519 UpdateTabWidget(lastViewerTabIndex);
5524void G4UIQt::ToolBoxActivated(
int a)
5526 if (fUITabWidget->widget(a) == fHelpTBWidget) {
5530 else if (fUITabWidget->widget(a) == fSceneTreeWidget) {
5531 fSceneTreeWidget->setVisible(
true);
5535#if QT_VERSION < 0x060000
5538 if (currentWidget() !=
nullptr) {
5542 QString text = tabText(currentIndex());
5545 auto edit =
dynamic_cast<QTextEdit*
>(currentWidget());
5546 if (edit ==
nullptr) {
5547 QString paramSelect = QString(
"/vis/viewer/select ") + text;
5549 if (UI !=
nullptr) {
G4TemplateAutoLock< G4Mutex > G4AutoLock
#define G4MUTEX_INITIALIZER
G4GLOB_DLL std::ostream G4cout
G4double GetAlpha() const
G4double GetGreen() const
G4String GetFullPrefixString() const
G4String GetPrefixString() const
static G4Qt * getInstance()
void FlushAndWaitExecution() override
const G4String & GetDescription() const
const std::list< G4SceneTreeItem > & GetChildren() const
const G4String & GetPVPath() const
const std::map< G4String, G4AttDef > * GetAttDefs() const
std::vector< G4AttValue > * GetAttValues() const
static G4StateManager * GetStateManager()
G4UIOutputString(const QString &text, const G4String &thread="", const G4String &outputstream="info")
void SetIconPickSelected()
G4bool AddTabWidget(QWidget *, QString)
QWidget * GetViewerPropertiesWidget()
void SetIconOrthoSelected()
void UpdateSceneTree(const G4SceneTreeItem &) override
G4UIsession * SessionStart() override
void SetStartPage(const std::string &)
G4bool AddViewerTabFromFile(std::string fileName, std::string title)
G4int ReceiveG4cout(const G4String &) override
void SetIconZoomInSelected()
void PauseSessionStart(const G4String &) override
void AddMenu(const char *, const char *) override
QWidget * GetSceneTreeWidget()
G4int ReceiveG4cerr(const G4String &) override
void AddButton(const char *, const char *, const char *) override
void SetOutputStyle(const char *destination, const char *style) override
void SetIconZoomOutSelected()
void SetIconHLRSelected()
void ClearMenu() override
void SetIconPerspectiveSelected()
void NativeMenu(G4bool aVal) override
QWidget * GetPickInfosWidget()
void DefaultIcons(G4bool aVal) override
void SetIconSolidSelected()
G4int ReceiveG4debug(const G4String &) override
void SetIconRotateSelected()
void Prompt(const G4String &)
void SetIconWireframeSelected()
void SetIconMoveSelected()
G4bool AddViewerTab(QWidget *w, std::string title)
void AddIcon(const char *userLabel, const char *iconFile, const char *command, const char *file_name="") override
void SetIconHLHSRSelected()
G4int GetCommandEntry() const
const G4UIcommand * GetGuidance() const
G4UIcommand * GetCommand(G4int i)
const G4String & GetPathName() const
G4int GetTreeEntry() const
G4UIcommandTree * GetTree(G4int i)
G4UIcommandTree * FindCommandTree(const char *commandPath)
const G4String GetTitle() const
G4String GetFirstMatchedString(const G4String &, const G4String &) const
G4UIcommand * FindPath(const char *commandPath) const
std::size_t GetParameterEntries() const
const G4String & GetGuidanceLine(G4int i) const
G4UIparameter * GetParameter(G4int i) const
static G4String ConvertToString(G4bool boolVal)
const G4String & GetCommandPath() const
std::size_t GetGuidanceEntries() const
const G4String & GetCommandName() const
const G4String & GetRange() const
void SetCoutDestination(G4UIsession *const value)
G4UIcommandTree * GetTree() const
G4int ApplyCommand(const char *aCommand)
bool IsLastCommandOutputTreated()
G4int GetVerboseLevel() const
G4String FindMacroPath(const G4String &fname) const
static G4UImanager * GetUIpointer()
G4MTcoutDestination * GetThreadCout()
void SetSession(G4UIsession *const value)
void SetG4UIWindow(G4UIsession *const value)
void SetLastCommandOutputTreated()
const G4String & GetParameterCandidates() const
const G4String & GetParameterGuidance() const
G4bool IsOmittable() const
const G4String & GetParameterRange() const
G4bool GetCurrentAsDefault() const
char GetParameterType() const
const G4String & GetParameterName() const
const G4String & GetDefaultValue() const
G4String ModifyToFullPathCommand(const char *aCommandLine) const
G4String Complete(const G4String &)
void TerminalHelp(const G4String &)
void ApplyShellCommand(const G4String &, G4bool &, G4bool &)
G4Interactor GetInteractor(const G4String &)
void SetStyleUtility(const G4String &destination, const G4String &style)
std::map< G4String, OutputStyle > fOutputStyles
void AddInteractor(G4String, G4Interactor)
void EnableSecondaryLoop()
G4Interactor GetMainInteractor()
void DisableSecondaryLoop()
static G4MTGLOB_DLL G4coutDestination * masterG4coutDestination
const char * name(G4int ptype)