Eclipse SUMO - Simulation of Urban MObility
Loading...
Searching...
No Matches
GNEApplicationWindow.cpp
Go to the documentation of this file.
1/****************************************************************************/
2// Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo
3// Copyright (C) 2001-2026 German Aerospace Center (DLR) and others.
4// This program and the accompanying materials are made available under the
5// terms of the Eclipse Public License 2.0 which is available at
6// https://www.eclipse.org/legal/epl-2.0/
7// This Source Code may also be made available under the following Secondary
8// Licenses when the conditions for such availability set forth in the Eclipse
9// Public License 2.0 are satisfied: GNU General Public License, version 2
10// or later which is available at
11// https://www.gnu.org/licenses/old-licenses/gpl-2.0-standalone.html
12// SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-or-later
13/****************************************************************************/
19// Functions from main window of netedit
20/****************************************************************************/
21
23#include <netbuild/NBFrame.h>
51#include <netedit/templates.h>
52#include <netimport/NIFrame.h>
55#include <netwrite/NWFrame.h>
71#include <utils/xml/XMLSubSys.h>
72
74#include "GNEEvent_FileLoaded.h"
75#include "GNEInternalTest.h"
76#include "GNELoadThread.h"
77#include "GNENet.h"
78#include "GNEUndoList.h"
79#include "GNEViewParent.h"
80
81#ifdef HAVE_VERSION_H
82#include <version.h>
83#endif
84
85// ===========================================================================
86// FOX-declarations
87// ===========================================================================
88
89FXDEFMAP(GNEApplicationWindow) GNEApplicationWindowMap[] = {
90 // quit calls
94 FXMAPFUNC(SEL_CLOSE, MID_WINDOW, GNEApplicationWindow::onCmdQuit),
95 // toolbar file
102 FXMAPFUNC(SEL_UPDATE, MID_RECENTFILE, GNEApplicationWindow::onUpdOpen),
107 // network
122 // NeteditConfig
130 // SumoConfig
138 // TLS
147 // edge types
156 // additionals
169 // demand elements
180 // data elements
191 // meanDatas
202 // other
207 // Toolbar supermode
211 // Toolbar modes
228 // Toolbar edit
237 // Network view options
270 // Demand view options
293 // Data view options
310 // view
327 /* Prepared for #6042
328 FXMAPFUNC(SEL_COMMAND, MID_HOTKEY_CTRL_X_CUT, GNEApplicationWindow::onCmdCut),
329 FXMAPFUNC(SEL_COMMAND, MID_HOTKEY_CTRL_C_COPY, GNEApplicationWindow::onCmdCopy),
330 FXMAPFUNC(SEL_COMMAND, MID_HOTKEY_CTRL_V_PASTE, GNEApplicationWindow::onCmdPaste),
331 */
332 // toolbar lock
364 // Toolbar processing
383 // Toolbar locate
408 // toolbar python tools
413 // toolbar windows
415 // toolbar help
418 FXMAPFUNC(SEL_COMMAND, MID_HOTKEYS, GNEApplicationWindow::onCmdHotkeys),
419 FXMAPFUNC(SEL_COMMAND, MID_TUTORIAL, GNEApplicationWindow::onCmdTutorial),
420 FXMAPFUNC(SEL_COMMAND, MID_FEEDBACK, GNEApplicationWindow::onCmdFeedback),
422 // alt + <number>
443 // key events
444 FXMAPFUNC(SEL_KEYPRESS, 0, GNEApplicationWindow::onKeyPress),
445 FXMAPFUNC(SEL_KEYRELEASE, 0, GNEApplicationWindow::onKeyRelease),
446 FXMAPFUNC(SEL_COMMAND, MID_HOTKEY_ESC, GNEApplicationWindow::onCmdAbort),
447 FXMAPFUNC(SEL_COMMAND, MID_HOTKEY_DEL, GNEApplicationWindow::onCmdDel),
448 FXMAPFUNC(SEL_COMMAND, MID_HOTKEY_ENTER, GNEApplicationWindow::onCmdEnter),
450 // threads events
453 // edge template functions
457 // languages
482 // tools
485 // other
486 FXMAPFUNC(SEL_CLIPBOARD_REQUEST, 0, GNEApplicationWindow::onClipboardRequest),
493 FXMAPFUNC(SEL_COMMAND, MID_RUNTESTS, GNEApplicationWindow::onCmdRunTests),
494};
495
496// Object implementation
497FXIMPLEMENT(GNEApplicationWindow, FXMainWindow, GNEApplicationWindowMap, ARRAYNUMBER(GNEApplicationWindowMap))
498
499// ===========================================================================
500// GNEApplicationWindow method definitions
501// ===========================================================================
502#ifdef _MSC_VER
503#pragma warning(push)
504#pragma warning(disable: 4355) // mask warning about "this" in initializers
505#endif
506GNEApplicationWindow::GNEApplicationWindow(FXApp* app, const GNETagPropertiesDatabase* tagPropertiesDatabase, const std::string& configPattern) :
507 GUIMainWindow(app),
508 myTagPropertiesDatabase(tagPropertiesDatabase),
509 myUndoList(new GNEUndoList(this)),
510 myConfigPattern(configPattern),
511 myToolbarsGrip(this),
512 myMenuBarFile(this),
513 myFileMenuCommands(this),
514 myModesMenuCommands(this),
515 myEditMenuCommands(this),
516 myLockMenuCommands(this),
517 myProcessingMenuCommands(this),
518 myLocateMenuCommands(this),
519 myToolsMenuCommands(this),
520 myWindowsMenuCommands(this),
521 myHelpMenuCommands(this),
522 mySupermodeCommands(this),
523 myFileBucketHandler(new GNEApplicationWindowHelper::FileBucketHandler(this, OptionsCont::getOptions(), mySumoOptions)),
524 myTitlePrefix("netedit " VERSION_STRING),
525 myAllowUndoRedo(getApp()->reg().readBoolEntry("NETEDIT", "AllowUndoRedo", true) == TRUE),
526 myAllowUndoRedoLoading(getApp()->reg().readBoolEntry("NETEDIT", "AllowUndoRedoLoading", true) == TRUE) {
527 // init icons
529 // init Textures
531 // init cursors
533 // set tooltip options
534 app->setTooltipTime(1000000000);
535 app->setTooltipPause(1000000000);
536 // set SUMO Options descriptions
537 mySumoOptions.setApplicationDescription(TL("A microscopic, multi-modal traffic simulation."));
538 mySumoOptions.setApplicationName("sumo", "Eclipse SUMO sumo " VERSION_STRING);
539 // set default netedit options
542 // parse options
548 // add extra option for automatic closing
549 myNetgenerateOptions.doRegister("close-dialog-automatic", new Option_Bool(true));
550 myNetgenerateOptions.addDescription("close-dialog-automatic", "report", TL("Close dialog automatically"));
551}
552#ifdef _MSC_VER
553#pragma warning(pop)
554#endif
555
556
557void
559 // do this not twice
561 // do not translate debug messages
562 WRITE_ERROR("DEBUG: GNEApplicationWindow::dependentBuild called twice");
563 return;
564 }
565 myHadDependentBuild = true;
566 setTarget(this);
567 setSelector(MID_WINDOW);
568 // build toolbar menu
570 // build the thread - io
573 // build the status bar
574 myStatusbar = new FXStatusBar(this, GUIDesignStatusBar);
575 // build geo coordinates label
576 auto requireRecomputingFrame = new FXHorizontalFrame(myStatusbar, GUIDesignHorizontalFrameStatusBar);
578 TL("Recomputing"), nullptr, this, MID_GNE_RECOMPUTINGNEEDED, GUIDesignButtonStatusBarFixed);
579 myRequireRecomputingButton->setHelpText(TL("Recomputing is needed"));
580 // build geo coordinates label
582 myGeoCoordinate = new FXLabel(myGeoFrame, TL("N/A"), nullptr, GUIDesignLabelStatusBar);
583 myGeoCoordinate->setHelpText(TL("Original coordinate (before coordinate transformation in netconvert)"));
584 // build cartesian coordinates label
586 myCartesianCoordinate = new FXLabel(myCartesianFrame, TL("N/A"), nullptr, GUIDesignLabelStatusBar);
587 myCartesianCoordinate->setHelpText(TL("Network coordinate"));
588 // build test coordinates label (only if gui-testing is enabled)
590 myTestCoordinate = new FXLabel(myTestFrame, TL("N/A"), nullptr, GUIDesignLabelStatusBar);
591 myTestCoordinate->setHelpText(TL("Test coordinate"));
593 myTestFrame->hide();
594 // make the window a mdi-window
595 myMainSplitter = new FXSplitter(this, GUIDesignSplitter | SPLITTER_VERTICAL | SPLITTER_REVERSED);
597 myMDIMenu = new FXMDIMenu(this, myMDIClient);
598 // build the message window
600 myMainSplitter->setSplit(1, 65);
601 // fill menu and tool bar
602 fillMenuBar();
603 // build additional threads
605 // check if create internal test system
606 if (OptionsCont::getOptions().getString("test-file").size() > 0) {
607 myInternalTest = new GNEInternalTest(OptionsCont::getOptions().getString("test-file"));
608 }
609 // set the status bar
610 setStatusBarText(TL("Ready."));
611 // set the caption
612 setTitle(myTitlePrefix);
613 // set Netedit ICON
616 // build netedit Accelerators (hotkeys)
617 GUIShortcutsSubSys::buildAccelerators(getAccelTable(), this, false);
618}
619
620
621void
623 // set windows size and position
625 // set current folder
626 gCurrentFolder = getApp()->reg().readStringEntry("SETTINGS", "basedir", "");
627 // Create main window
628 FXMainWindow::create();
629 // get text width
630 const auto textWidth = getApp()->getNormalFont()->getTextWidth("8", 1) * 22;
631 // adjust cartesian and geo frame
632 myCartesianFrame->setWidth(textWidth);
633 myGeoFrame->setWidth(textWidth);
634 // fill online maps
635 if (myOnlineMaps.empty()) {
636 myOnlineMaps["GeoHack"] = "https://geohack.toolforge.org/geohack.php?params=%lat;%lon_scale:1000";
637 myOnlineMaps["Google Maps"] = "https://www.google.com/maps?ll=%lat,%lon&t=h&z=18";
638 myOnlineMaps["OSM"] = "https://www.openstreetmap.org/?mlat=%lat&mlon=%lon&zoom=18&layers=M";
639 }
640 // show application windows
641 show(PLACEMENT_DEFAULT);
642 // check if maximice
643 if (!OptionsCont::getOptions().isSet("window-size")) {
644 if (getApp()->reg().readIntEntry("SETTINGS", "maximized", 0) == 1) {
645 maximize();
646 }
647 }
648}
649
650
652 closeAllWindows(true);
653 // Close icons
655 // Close gifs (Textures)
658 // delete visuals
659 delete myGLVisual;
660 // must delete menus to avoid segfault on removing accelerators
661 // (http://www.fox-toolkit.net/faq#TOC-What-happens-when-the-application-s)
664 delete myFileMenuTLS;
665 delete myFileMenuEdgeTypes;
672 delete myFileMenu;
673 delete myModesMenu;
674 delete myEditMenu;
675 delete myLockMenu;
676 delete myProcessingMenu;
677 delete myLocatorMenu;
678 delete myToolsMenu;
679 delete myToolsDetectorMenu;
680 delete myToolsDistrictMenu;
681 delete myToolsDRTMenu;
683 delete myToolsImportMenu;
686 delete myToolsImportVissim;
687 delete myToolsImportVisum;
688 delete myToolsNetMenu;
689 delete myToolsRouteMenu;
690 delete myToolsOutputMenu;
691 delete myToolsShapes;
692 delete myToolsTLS;
693 delete myToolsTurnDefs;
695 delete myToolsXML;
696 delete myWindowMenu;
697 delete myHelpMenu;
698 delete myLanguageMenu;
699 // Delete load thread
700 delete myLoadThread;
701 if (myInternalTest) {
702 delete myInternalTest;
703 }
704 // drop all events
705 while (!myThreadEvents.empty()) {
706 // get the next event
709 delete e;
710 }
711 // delete undoList and dialog
712 delete myUndoList;
713}
714
715
716long
717GNEApplicationWindow::onCmdQuit(FXObject* sender, FXSelector sel, void* ptr) {
718 if (askSaveElements(sender, sel, ptr)) {
720 getApp()->reg().writeStringEntry("SETTINGS", "basedir", gCurrentFolder.text());
721 if (isMaximized()) {
722 getApp()->reg().writeIntEntry("SETTINGS", "maximized", 1);
723 } else {
724 getApp()->reg().writeIntEntry("SETTINGS", "maximized", 0);
725 }
726 getApp()->exit(0);
727 }
728 return 1;
729}
730
731
732long
733GNEApplicationWindow::onCmdEditChosen(FXObject*, FXSelector, void*) {
734 GUIDialog_GLChosenEditor* chooser =
736 chooser->create();
737 chooser->show();
738 return 1;
739}
740
741
742long
743GNEApplicationWindow::onCmdNewNetwork(FXObject*, FXSelector, void*) {
744 // check if close current simulation
745 if (onCmdClose(0, 0, 0) == 1) {
746 // create new network
748 }
749 return 1;
750}
751
752
753long
755 auto& neteditOptions = OptionsCont::getOptions();
756 // get netconvert file dialog
757 const GNEFileDialog netConvertFileDialog(this, TL("netconvert config file"),
762 // continue depending of dialog
763 if ((netConvertFileDialog.getResult() == GNEDialog::Result::ACCEPT) && (onCmdClose(0, 0, 0) == 1)) {
764 // stop test before calling load thread
765 if (myInternalTest) {
767 }
768 // reset netedit options
769 myLoadThread->fillOptions(neteditOptions);
770 myLoadThread->setDefaultOptions(neteditOptions);
771 // set netconvert configuration file to load
772 neteditOptions.resetWritable();
773 neteditOptions.set("netccfg-file", netConvertFileDialog.getFilename());
774 // run load thread
776 // update view
777 update();
778 }
779 return 1;
780}
781
782
783long
784GNEApplicationWindow::onCmdOpenNetwork(FXObject*, FXSelector, void*) {
785 // get netconvert filename
786 const GNEFileDialog networkFileDialog(this, TL("network file"),
791 // continue depending of dialog
792 if ((networkFileDialog.getResult() == GNEDialog::Result::ACCEPT) && (onCmdClose(0, 0, 0) == 1)) {
793 // load network
794 loadNetwork(networkFileDialog.getFilename());
795 }
796 return 0;
797}
798
799
800long
801GNEApplicationWindow::onCmdOpenForeign(FXObject*, FXSelector, void*) {
802 // get OSM file dilaog
803 const GNEFileDialog OSMFileDialog(this, TL("OpenStreetMap file"),
808 // continue depending of dialog
809 if ((OSMFileDialog.getResult() == GNEDialog::Result::ACCEPT) && (onCmdClose(0, 0, 0) == 1)) {
810 loadOSM(OSMFileDialog.getFilename());
811 }
812 return 1;
813}
814
815
816long
817GNEApplicationWindow::onCmdOpenNeteditConfig(FXObject*, FXSelector, void*) {
818 auto& neteditOptions = OptionsCont::getOptions();
819 // get netconvert filename
820 const GNEFileDialog neteditConfigFileDialog(this, TL("netedit config file"),
825 // continue depending of dialog
826 if ((neteditConfigFileDialog.getResult() == GNEDialog::Result::ACCEPT) && (onCmdClose(0, 0, 0) == 1)) {
827 // stop test before calling load thread
828 if (myInternalTest) {
830 }
831 // reset netedit options
832 myLoadThread->fillOptions(neteditOptions);
833 myLoadThread->setDefaultOptions(neteditOptions);
834 // set netedit configuration file to load
835 neteditOptions.resetWritable();
836 neteditOptions.set("netecfg-file", neteditConfigFileDialog.getFilename());
837 // run load thread
839 // update view
840 update();
841 }
842 return 1;
843}
844
845
846long
847GNEApplicationWindow::onCmdOpenSumoConfig(FXObject*, FXSelector, void*) {
848 auto& neteditOptions = OptionsCont::getOptions();
849 // get netconvert filename
850 const GNEFileDialog sumoConfigFileDialog(this, TL("sumo config file"),
855 // continue depending of dialog
856 if ((sumoConfigFileDialog.getResult() == GNEDialog::Result::ACCEPT) && (onCmdClose(0, 0, 0) == 1)) {
857 // stop test before calling load thread
858 if (myInternalTest) {
860 }
861 // reset options
862 myLoadThread->fillOptions(neteditOptions);
863 myLoadThread->setDefaultOptions(neteditOptions);
864 // set sumo configuration file to load
865 neteditOptions.resetWritable();
866 neteditOptions.set("sumocfg-file", sumoConfigFileDialog.getFilename());
867 // run load thread
869 // update view
870 update();
871 }
872 return 1;
873}
874
875
876long
878 // get existent configuration file
880 // check if close current simulation
881 if (onCmdClose(0, 0, 0) == 1) {
882 // stop test before calling load thread
883 if (myInternalTest) {
885 }
886 auto& neteditOptions = OptionsCont::getOptions();
887 // reset options
888 myLoadThread->fillOptions(neteditOptions);
889 myLoadThread->setDefaultOptions(neteditOptions);
890 // set netedit configuration file to load
891 neteditOptions.resetWritable();
892 neteditOptions.set("netecfg-file", neteditConfigFile);
893 // run load thread
895 // update view
896 update();
897 }
898 return 1;
899}
900
901
902long
903GNEApplicationWindow::onCmdReloadSumoConfig(FXObject*, FXSelector, void*) {
904 // get existent sumo config file
906 // check if close current simulation
907 if (onCmdClose(0, 0, 0) == 1) {
908 // stop test before calling load thread
909 if (myInternalTest) {
911 }
912 auto& neteditOptions = OptionsCont::getOptions();
913 // reset options
914 myLoadThread->fillOptions(neteditOptions);
915 myLoadThread->setDefaultOptions(neteditOptions);
916 // set configuration file to load
917 neteditOptions.resetWritable();
918 neteditOptions.set("sumocfg-file", sumoConfigFile);
919 // run load thread
921 // update view
922 update();
923 }
924 return 1;
925}
926
927
928long
929GNEApplicationWindow::onUpdReloadNeteditConfig(FXObject* sender, FXSelector, void*) {
930 // check if file exist
932 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
933 } else {
934 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
935 }
936}
937
938
939long
940GNEApplicationWindow::onUpdReloadSumoConfig(FXObject* sender, FXSelector, void*) {
941 // check if file exist
943 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
944 } else {
945 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
946 }
947}
948
949
950long
951GNEApplicationWindow::onCmdOpenTLSPrograms(FXObject*, FXSelector, void*) {
952 // get netconvert filename
953 const GNEFileDialog TLSfileDialog(this, TL("Traffic Light definitions file"),
958 // continue depending of dialog
959 if (TLSfileDialog.getResult() == GNEDialog::Result::ACCEPT) {
960 // set tls type in bucket
962 // load traffic lights
963 loadTrafficLights("Loading");
964 }
965 return 1;
966}
967
968
969long
970GNEApplicationWindow::onCmdReloadTLSPrograms(FXObject*, FXSelector, void*) {
971 // load traffic lights
972 loadTrafficLights("Reloading");
973 return 1;
974}
975
976
977long
978GNEApplicationWindow::onUpdReloadTLSPrograms(FXObject* sender, FXSelector, void*) {
979 // check if file exist
981 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
982 } else {
983 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
984 }
985}
986
987
988long
989GNEApplicationWindow::onCmdOpenEdgeTypes(FXObject*, FXSelector, void*) {
990 // get netconvert filename
991 const GNEFileDialog edgeTypesFileDialog(this, TL("EdgeTypes file"),
996 // continue depending of dialog
997 if (edgeTypesFileDialog.getResult() == GNEDialog::Result::ACCEPT) {
998 // set tls type in bucket
1000 // load edge types
1001 loadEdgeTypes("Loading");
1002 }
1003 return 1;
1004}
1005
1006
1007long
1008GNEApplicationWindow::onCmdReloadEdgeTypes(FXObject*, FXSelector, void*) {
1009 // load edge types
1010 loadEdgeTypes("Reloading");
1011 return 0;
1012}
1013
1014
1015long
1016GNEApplicationWindow::onUpdReloadEdgeTypes(FXObject* sender, FXSelector, void*) {
1017 // check if file exist
1019 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
1020 } else {
1021 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
1022 }
1023}
1024
1025
1026long
1027GNEApplicationWindow::onCmdSmartReload(FXObject*, FXSelector sel, void*) {
1028 auto& neteditOptions = OptionsCont::getOptions();
1029 // check if close current file
1030 if (onCmdClose(0, sel, 0) == 1) {
1031 // stop test before calling load thread
1032 if (myInternalTest) {
1034 }
1035 // store size, position and viewport
1037 gSchemeStorage.saveViewport(0, 0, -1, 0); // recenter view
1038 // set flag
1039 myAmLoading = true;
1040 // get files
1044 // fill (reset) all options
1045 myLoadThread->fillOptions(neteditOptions);
1046 // set default options defined in GNELoadThread::setDefaultOptions(...)
1047 myLoadThread->setDefaultOptions(neteditOptions);
1048 // set file to load
1049 neteditOptions.resetWritable();
1050 if (neteditConfig.size() > 0) {
1051 // set netedit config
1053 // set status bar
1054 setStatusBarText(TLF("Reloading netedit config file '%'", neteditConfig));
1055 } else if (sumoConfig.size() > 0) {
1056 // set sumo config
1058 // set status bar
1059 setStatusBarText(TLF("Reloading sumo config file '%'", sumoConfig));
1060 } else if (networkFile.size() > 0) {
1061 // set network config
1063 // set status bar
1064 setStatusBarText(TLF("Reloading network file '%'", networkFile));
1065 } else {
1066 // nothing to load
1067 return 0;
1068 }
1069 // load network
1071 }
1072 return 1;
1073}
1074
1075
1076long
1077GNEApplicationWindow::onUpdSmartReload(FXObject* sender, FXSelector, void*) {
1078 // declare strings
1079 FXString neteditConfig = TL("&Reload Netedit config");
1080 FXString sumoConfig = TL("&Reload Sumo config");
1081 FXString netFile = TL("&Reload Network");
1082 FXString reload = TL("&Reload");
1083 // check options
1084 if (myNet == nullptr) {
1085 sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
1086 sender->handle(this, FXSEL(SEL_COMMAND, ID_SETSTRINGVALUE), &reload);
1088 sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
1089 sender->handle(this, FXSEL(SEL_COMMAND, ID_SETSTRINGVALUE), &neteditConfig);
1091 sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
1092 sender->handle(this, FXSEL(SEL_COMMAND, ID_SETSTRINGVALUE), &sumoConfig);
1094 sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
1095 sender->handle(this, FXSEL(SEL_COMMAND, ID_SETSTRINGVALUE), &netFile);
1096 } else {
1097 sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
1098 sender->handle(this, FXSEL(SEL_COMMAND, ID_SETSTRINGVALUE), &reload);
1099 }
1100 return 1;
1101}
1102
1103
1104long
1105GNEApplicationWindow::onCmdReloadNetwork(FXObject*, FXSelector sel, void*) {
1106 auto& neteditOptions = OptionsCont::getOptions();
1107 // check if close current file
1108 if (onCmdClose(0, sel, 0) == 1) {
1109 // stop test before calling load thread
1110 if (myInternalTest) {
1112 }
1113 // store size, position and viewport
1115 gSchemeStorage.saveViewport(0, 0, -1, 0); // recenter view
1116 // set flag
1117 myAmLoading = true;
1118 // get network
1119 const std::string networkFile = myFileBucketHandler->getDefaultFilename(FileBucket::Type::NETWORK);
1120 // fill (reset) all options
1121 myLoadThread->fillOptions(neteditOptions);
1122 // set default options defined in GNELoadThread::setDefaultOptions(...)
1123 myLoadThread->setDefaultOptions(neteditOptions);
1124 // set file to load
1126 // set status bar
1127 setStatusBarText(TLF("Reloading network file '%'", networkFile));
1128 // loaad network
1130 }
1131 return 1;
1132}
1133
1134
1135long
1136GNEApplicationWindow::onUpdReloadNetwork(FXObject* sender, FXSelector, void*) {
1137 if (myNet == nullptr) {
1138 sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
1139 sender->handle(this, FXSEL(SEL_COMMAND, ID_HIDE), nullptr);
1142 sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
1143 sender->handle(this, FXSEL(SEL_COMMAND, ID_SHOW), nullptr);
1144 } else {
1145 sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
1146 sender->handle(this, FXSEL(SEL_COMMAND, ID_HIDE), nullptr);
1147 }
1148 return 1;
1149}
1150
1151
1152long
1153GNEApplicationWindow::onCmdOpenRecent(FXObject*, FXSelector, void* fileData) {
1154 // first check that current edited Net can be closed (und therefore the undo-list cleared, see #5753)
1155 if (myAmLoading) {
1156 myStatusbar->getStatusLine()->setText(TL("Already loading!"));
1157 } else if (onCmdClose(0, 0, 0) == 1) {
1158 // get filedata
1159 const std::string recentFile = ((const char*)fileData);
1160 // check if we're loading a network o a config
1161 if ((recentFile.find(".netecfg") != std::string::npos) ||
1162 (recentFile.find(".sumocfg") != std::string::npos) ||
1163 (recentFile.find(".netccfg") != std::string::npos)) {
1164 // load config
1165 loadConfiguration(recentFile);
1166 } else {
1167 // load network
1168 loadNetwork(recentFile);
1169 }
1170 }
1171 return 1;
1172}
1173
1174
1175long
1176GNEApplicationWindow::onCmdClose(FXObject* sender, FXSelector sel, void* ptr) {
1177 if (myViewNet == nullptr) {
1178 return 1;
1179 } else if (askSaveElements(sender, sel, ptr)) {
1180 // check if is reloading
1181 const bool reloading = (FXSELID(sel) == MID_GNE_TOOLBARFILE_RELOADNETWORK) || (FXSELID(sel) == MID_HOTKEY_CTRL_R_RELOAD);
1182 // close all windows
1183 closeAllWindows(!reloading);
1184 // add a separator to the log
1186 // hide all menu commands
1190 // hide view options
1194 return 1;
1195 } else {
1196 return 0;
1197 }
1198}
1199
1200
1201long
1202GNEApplicationWindow::onCmdLocate(FXObject*, FXSelector sel, void*) {
1203 if (myMDIClient->numChildren() > 0) {
1204 GNEViewParent* w = dynamic_cast<GNEViewParent*>(myMDIClient->getActiveChild());
1205 if (w != nullptr) {
1206 w->onCmdLocate(nullptr, sel, nullptr);
1207 }
1208 }
1209 return 1;
1210}
1211
1212
1213long
1214GNEApplicationWindow::onCmdOpenPythonToolDialog(FXObject* obj, FXSelector, void*) {
1215 return myToolsMenuCommands.showTool(obj);
1216}
1217
1218
1219long
1220GNEApplicationWindow::onCmdRunPythonTool(FXObject* obj, FXSelector, void*) {
1222}
1223
1224
1225long
1228}
1229
1230
1231long
1232GNEApplicationWindow::onUpdPythonTool(FXObject*, FXSelector, void*) {
1233 // currently always enabled
1234 return 1;
1235}
1236
1237
1238long
1239GNEApplicationWindow::onUpdOpen(FXObject* sender, FXSelector, void*) {
1240 sender->handle(this, myAmLoading ? FXSEL(SEL_COMMAND, ID_DISABLE) : FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
1241 return 1;
1242}
1243
1244
1245long
1246GNEApplicationWindow::onCmdClearMsgWindow(FXObject*, FXSelector, void*) {
1248 return 1;
1249}
1250
1251
1252long
1254 return 1;
1255}
1256
1257
1258long
1260 return 1;
1261}
1262
1263
1264long
1265GNEApplicationWindow::onCmdAbout(FXObject*, FXSelector, void*) {
1266 // create and open about dialog
1267 GNEAboutDialog(this);
1268 return 1;
1269}
1270
1271
1272long GNEApplicationWindow::onClipboardRequest(FXObject*, FXSelector, void* ptr) {
1273 FXEvent* event = (FXEvent*)ptr;
1274 FXString string = GUIUserIO::clipped.c_str();
1275 setDNDData(FROM_CLIPBOARD, event->target, string);
1276 return 1;
1277}
1278
1279
1280long
1281GNEApplicationWindow::onLoadThreadEvent(FXObject*, FXSelector, void*) {
1282 eventOccurred();
1283 return 1;
1284}
1285
1286
1287void
1289 // load events
1290 while (!myThreadEvents.empty()) {
1291 // get the next event
1294 // process
1295 switch (e->getOwnType()) {
1298 break;
1305 break;
1306 default:
1307 break;
1308 }
1309 delete e;
1310 }
1311}
1312
1313
1314void
1316 myAmLoading = false;
1317 GNEEvent_FileLoaded* fileLoadedEvent = static_cast<GNEEvent_FileLoaded*>(e);
1318 // check whether the loading was successful
1319 if (fileLoadedEvent->getNet() == nullptr) {
1320 // report failure
1321 std::string failureMessage;
1322 switch (fileLoadedEvent->getType()) {
1324 failureMessage = TLF("Loading of netedit config '%' failed", fileLoadedEvent->getFile());
1325 break;
1327 failureMessage = TLF("Loading of sumo config '%' failed", fileLoadedEvent->getFile());
1328 break;
1330 failureMessage = TLF("Loading of netconvert config '%' failed", fileLoadedEvent->getFile());
1331 break;
1333 failureMessage = TLF("Loading of network '%' failed", fileLoadedEvent->getFile());
1334 break;
1336 failureMessage = TLF("Loading of OSM Network '%' failed", fileLoadedEvent->getFile());
1337 break;
1339 failureMessage = TL("Invalid Options. Nothing loaded");
1340 break;
1342 failureMessage = TL("Could not build projection. Nothing loaded");
1343 break;
1345 failureMessage = TL("Invalid extension for config file. Only .netecfg, .sumocfg or .netccfg are allowed");
1346 break;
1347 default:
1348 failureMessage = TL("Invalid input network option. Load with either sumo/netedit/netconvert config or with --new option");
1349 break;
1350 }
1351 // write info
1352 WRITE_ERROR(failureMessage);
1353 setStatusBarText(failureMessage);
1354 } else {
1355 // report success
1356 std::string successMessage;
1357 switch (fileLoadedEvent->getType()) {
1359 successMessage = TLF("Netedit config '%' loaded", fileLoadedEvent->getFile());
1360 break;
1362 successMessage = TLF("Sumo config '%' loaded", fileLoadedEvent->getFile());
1363 break;
1365 successMessage = TLF("Netconvert config '%' loaded", fileLoadedEvent->getFile());
1366 break;
1368 successMessage = TLF("Network '%' loaded", fileLoadedEvent->getFile());
1369 break;
1371 successMessage = TLF("OSM Network '%' loaded", fileLoadedEvent->getFile());
1372 break;
1374 successMessage = TLF("Network '%' loaded through console", fileLoadedEvent->getFile());
1375 break;
1377 successMessage = TL("New network successfully created");
1378 break;
1379 default:
1380 throw ProcessError("Invalid sucess mesage. Check if all cases were covered");
1381 }
1382 // write info
1383 WRITE_MESSAGE(successMessage);
1384 setStatusBarText(successMessage);
1385 // set new Net
1386 myNet = fileLoadedEvent->getNet();
1387 // set size and pos
1389 // build viewparent toolbar grips before creating view parent
1391 // initialise netedit View
1392 GNEViewParent* viewParent = new GNEViewParent(myMDIClient, myMDIMenu, "netedit VIEW", this, nullptr, myNet, myUndoList, nullptr, MDI_TRACKING, 10, 10, 300, 200);
1393 // create it maximized
1394 viewParent->maximize();
1395 // mark it as Active child
1396 myMDIClient->setActiveChild(viewParent);
1397 // cast pointer myViewNet
1398 myViewNet = dynamic_cast<GNEViewNet*>(viewParent->getView());
1399 // set settings in view
1400 if (viewParent->getView() && (fileLoadedEvent->getSettingsFile().size() > 0)) {
1401 GUISettingsHandler settings(fileLoadedEvent->getSettingsFile(), true, true);
1402 settings.addSettings(viewParent->getView());
1403 viewParent->getView()->addDecals(settings.getDecals());
1404 settings.applyViewport(viewParent->getView());
1405 settings.setSnapshots(viewParent->getView());
1406 }
1407 // set network name on the caption
1408 setTitle(MFXUtils::getTitleText(myTitlePrefix, fileLoadedEvent->getFile().c_str()));
1409 // force supermode network
1411 // update view port
1412 if (fileLoadedEvent->getViewportFromRegistry()) {
1413 Position off;
1414 off.set(getApp()->reg().readRealEntry("viewport", "x"), getApp()->reg().readRealEntry("viewport", "y"), getApp()->reg().readRealEntry("viewport", "z"));
1415 Position p(off.x(), off.y(), 0);
1416 myViewNet->setViewportFromToRot(off, p, 0);
1417 }
1418 // load elements
1419 loadAdditionalElements("Loading");
1420 loadDemandElements("Loading");
1421 loadDataElements("Loading");
1422 loadMeanDataElements("Loading");
1423 // load selection
1424 if (!OptionsCont::getOptions().isDefault("selection-file")) {
1426 }
1428 }
1430 // update app
1431 update();
1432 // restore focus
1433 setFocus();
1434}
1435
1436
1437void
1442
1443// ---------------------------------------------------------------------------
1444// private methods
1445// ---------------------------------------------------------------------------
1446
1447void
1449 // build file menu
1450 myFileMenu = new FXMenuPane(this, LAYOUT_FIX_HEIGHT);
1452 myFileMenuNeteditConfig = new FXMenuPane(this);
1453 myFileMenuSumoConfig = new FXMenuPane(this);
1454 myFileMenuTLS = new FXMenuPane(this);
1455 myFileMenuEdgeTypes = new FXMenuPane(this);
1456 myFileMenuAdditionals = new FXMenuPane(this);
1457 myFileMenuDemandElements = new FXMenuPane(this);
1458 myFileMenuDataElements = new FXMenuPane(this);
1459 myFileMenuMeanDataElements = new FXMenuPane(this);
1460 myFileMenuRecentNetworks = new FXMenuPane(this);
1461 myFileMenuRecentConfigs = new FXMenuPane(this);
1465 // add separator for recent files
1466 new FXMenuSeparator(myFileMenu);
1467 // build recent files
1470 new FXMenuSeparator(myFileMenu);
1471 GUIDesigns::buildFXMenuCommandShortcut(myFileMenu, TL("&Quit"), "Ctrl+Q", TL("Quit the Application."),
1472 nullptr, this, MID_HOTKEY_CTRL_Q_CLOSE);
1473 // build modes menu
1474 myModesMenu = new FXMenuPane(this);
1476 myModesMenuTitle->setTarget(this);
1478 // build Supermode commands and hide it
1480 // add separator
1481 new FXSeparator(myModesMenu);
1482 // build modes menu commands
1484 // build edit menu
1485 myEditMenu = new FXMenuPane(this);
1487 // build edit menu commands
1489 // build separator
1490 new FXMenuSeparator(myEditMenu);
1491 // build view options
1495 // hide view options
1499 // build view menu commands
1501 // build separator
1502 new FXMenuSeparator(myEditMenu);
1503 // build front element menu commands
1505 // build separator
1506 new FXMenuSeparator(myEditMenu);
1507 // build open in sumo menu commands
1509 // build lock menu
1510 myLockMenu = new FXMenuPane(this);
1512 myLockMenuTitle->setTarget(this);
1514 // build lock menu commands
1516 // build processing menu (trigger netbuild computations)
1517 myProcessingMenu = new FXMenuPane(this);
1520 // build locate menu
1521 myLocatorMenu = new FXMenuPane(this);
1524 // build tools menu
1525 myToolsMenu = new FXMenuPane(this);
1526 myToolsAssignMenu = new FXMenuPane(this);
1527 myToolsDetectorMenu = new FXMenuPane(this);
1528 myToolsDistrictMenu = new FXMenuPane(this);
1529 myToolsDRTMenu = new FXMenuPane(this);
1530 myToolsEmissionsMenu = new FXMenuPane(this);
1531 myToolsImportMenu = new FXMenuPane(this);
1532 myToolsImportCityBrainMenu = new FXMenuPane(this);
1533 myToolsImportGTFSMenu = new FXMenuPane(this);
1534 myToolsImportVissim = new FXMenuPane(this);
1535 myToolsImportVisum = new FXMenuPane(this);
1536 myToolsNetMenu = new FXMenuPane(this);
1537 myToolsRouteMenu = new FXMenuPane(this);
1538 myToolsOutputMenu = new FXMenuPane(this);
1539 myToolsShapes = new FXMenuPane(this);
1540 myToolsTLS = new FXMenuPane(this);
1541 myToolsTriggerMenu = new FXMenuPane(this);
1542 myToolsTurnDefs = new FXMenuPane(this);
1543 myToolsVisualizationMenu = new FXMenuPane(this);
1544 myToolsXML = new FXMenuPane(this);
1546 // build tools menu cascasde
1547 new FXMenuCascade(myToolsMenu, TL("Assign"), nullptr, myToolsAssignMenu);
1548 new FXMenuCascade(myToolsMenu, TL("Detectors"), GUIIconSubSys::getIcon(GUIIcon::E1), myToolsDetectorMenu);
1549 new FXMenuCascade(myToolsMenu, TL("Districts"), GUIIconSubSys::getIcon(GUIIcon::TAZ), myToolsDistrictMenu);
1551 //new FXMenuCascade(myToolsMenu, TL("Emissions"), GUIIconSubSys::getIcon(GUIIcon::TOOL_EMISSIONS), myToolsEmissionsMenu);
1560 //new FXMenuCascade(myToolsMenu, TL("Shapes"), GUIIconSubSys::getIcon(GUIIcon::MODESHAPE), myToolsShapes);
1561 new FXMenuCascade(myToolsMenu, TL("TLS"), GUIIconSubSys::getIcon(GUIIcon::MODETLS), myToolsTLS);
1562 new FXMenuCascade(myToolsMenu, TL("Trigger"), nullptr, myToolsTriggerMenu);
1566 // add separators between folders
1567 new FXMenuSeparator(myToolsMenu);
1568 new FXMenuSeparator(myToolsImportMenu);
1569 // create map with tool Menu panes and their associated folder
1576 myMenuPaneToolMaps["import/citybrain"] = myToolsImportCityBrainMenu;
1578 myMenuPaneToolMaps["import/vissim"] = myToolsImportVissim;
1579 myMenuPaneToolMaps["import/visum"] = myToolsImportVisum;
1586 myMenuPaneToolMaps["turn-defs"] = myToolsTurnDefs;
1589 // build tools
1591 // build windows menu
1592 myWindowMenu = new FXMenuPane(this);
1595 // build language menu
1597 // build help menu
1598 myHelpMenu = new FXMenuPane(this);
1601}
1602
1603
1604FXGLCanvas*
1606 // netedit uses only a single View, then return nullptr
1607 return nullptr;
1608}
1609
1610
1613 return 0;
1614}
1615
1616
1617double
1619 return 1;
1620}
1621
1622
1627
1628
1633
1634
1639
1640
1645
1646
1647void
1649 if (myViewNet && myViewNet->getNet()) {
1650 // show
1652 // set label depending of recomputing
1654 myRequireRecomputingButton->setText("");
1655 myRequireRecomputingButton->setTipText(TL("Network computed"));
1657 myRequireRecomputingButton->setBackColor(FXRGBA(240, 255, 205, 255));
1658 } else {
1659 myRequireRecomputingButton->setText(TL("Press F5"));
1660 myRequireRecomputingButton->setTipText(TL("Network requires recomputing"));
1662 myRequireRecomputingButton->setBackColor(FXRGBA(253, 255, 206, 255));
1663 }
1664 } else {
1665 // hide
1667 }
1668}
1669
1670
1671void
1672GNEApplicationWindow::closeAllWindows(const bool resetFilenames) {
1673 // first check if net must be deleted
1674 if (myNet != nullptr) {
1675 delete myNet;
1676 myNet = nullptr;
1678 }
1679 // reset default filenames
1680 if (resetFilenames) {
1682 }
1683 // check if view has to be saved
1684 if (myViewNet) {
1686 // clear decals
1687 myViewNet->getDecals().clear();
1688 }
1689 // lock tracker
1690 myTrackerLock.lock();
1691 // remove trackers and other external windows
1692 while (!myGLWindows.empty()) {
1693 delete myGLWindows.front();
1694 }
1695 myViewNet = nullptr;
1696 for (FXMainWindow* const window : myTrackerWindows) {
1697 window->destroy();
1698 delete window;
1699 }
1700 myTrackerWindows.clear();
1701 // reset the caption
1702 setTitle(myTitlePrefix);
1703 // unlock tracker
1704 myTrackerLock.unlock();
1705 // remove coordinate information
1706 myGeoCoordinate->setText(TL("N/A"));
1707 myCartesianCoordinate->setText(TL("N/A"));
1708 myTestCoordinate->setText(TL("N/A"));
1709 myTestFrame->hide();
1711 // Reset textures
1713 // reset fonts
1715}
1716
1717
1718FXCursor*
1720 return getApp()->getDefaultCursor(DEF_ARROW_CURSOR);
1721}
1722
1723
1724void
1726 auto& neteditOptions = OptionsCont::getOptions();
1727 if (neteditOptions.getBool("new")) {
1728 // save output file
1729 const auto outputFile = neteditOptions.getString("output-file");
1730 // create new network reset all options
1732 // check if define network file using this ouput file
1733 if (!outputFile.empty()) {
1735 }
1736 } else {
1737 // set flag
1738 myAmLoading = true;
1739 // set status bar
1740 setStatusBarText(TL("Loading console arguments."));
1741 // load console arguments
1743 // add it into recent networks and configs
1746 }
1749 }
1750 }
1751}
1752
1753
1754void
1756 auto& neteditOptions = OptionsCont::getOptions();
1757 // save windows size and position
1759 // enable loading flag and disable reloading flag
1760 myAmLoading = true;
1761 // recenter view
1762 gSchemeStorage.saveViewport(0, 0, -1, 0);
1763 // fill (reset) all options
1764 GNELoadThread::fillOptions(neteditOptions);
1765 // set default options defined in GNELoadThread::setDefaultOptions(...)
1766 GNELoadThread::setDefaultOptions(neteditOptions);
1767 // update status bar
1768 setStatusBarText(TL("Creating new network."));
1769 // create new network
1771 // update window
1772 update();
1773}
1774
1775
1776void
1777GNEApplicationWindow::loadNetwork(const std::string& networkFile) {
1778 if (networkFile.empty()) {
1779 WRITE_ERROR(TL("Trying to load an empty network."));
1780 } else {
1781 auto& neteditOptions = OptionsCont::getOptions();
1782 // stop test before calling load thread
1783 if (myInternalTest) {
1785 }
1786 // store size, position and viewport
1788 gSchemeStorage.saveViewport(0, 0, -1, 0); // recenter view
1789 // set flag
1790 myAmLoading = true;
1791 // fill (reset) all options
1792 myLoadThread->fillOptions(neteditOptions);
1793 // set default options defined in GNELoadThread::setDefaultOptions(...)
1794 myLoadThread->setDefaultOptions(neteditOptions);
1795 // update default net file
1797 // set status bar
1798 setStatusBarText(TLF("Loading network file '%'.", networkFile));
1799 // load network
1801 // add it into recent nets
1802 myMenuBarFile.myRecentNetworks.appendFile(networkFile.c_str());
1803 }
1804}
1805
1806
1807void
1808GNEApplicationWindow::loadConfiguration(const std::string& configurationFile) {
1809 if (configurationFile.empty()) {
1810 WRITE_ERROR(TL("Trying to load an empty configuration."));
1811 } else {
1812 auto& neteditOptions = OptionsCont::getOptions();
1813 // store size, position and viewport
1815 gSchemeStorage.saveViewport(0, 0, -1, 0); // recenter view
1816 // set flag
1817 myAmLoading = true;
1818 // fill (reset) all options
1819 myLoadThread->fillOptions(neteditOptions);
1820 // set default options defined in GNELoadThread::setDefaultOptions(...)
1821 myLoadThread->setDefaultOptions(neteditOptions);
1822 // set file to load
1823 neteditOptions.resetWritable();
1824 neteditOptions.set("configuration-file", configurationFile);
1825 // set status bar
1826 setStatusBarText(TLF("Loading configuration file '%'.", configurationFile));
1827 // load config
1829 // add it into recent configs
1830 myMenuBarFile.myRecentConfigs.appendFile(configurationFile.c_str());
1831 }
1832}
1833
1834
1835void
1836GNEApplicationWindow::loadOSM(const std::string& OSMFile) {
1837 auto& neteditOptions = OptionsCont::getOptions();
1838 // store size, position and viewport
1840 gSchemeStorage.saveViewport(0, 0, -1, 0); // recenter view
1841 // set flag
1842 myAmLoading = true;
1843 // fill (reset) all options
1844 myLoadThread->fillOptions(neteditOptions);
1845 // set default options defined in GNELoadThread::setDefaultOptions(...)
1846 myLoadThread->setDefaultOptions(neteditOptions);
1847 // recommended osm options
1848 // https://sumo.dlr.de/wiki/Networks/Import/OpenStreetMap#Recommended_NETCONVERT_Options
1849 neteditOptions.set("osm-files", OSMFile);
1850 neteditOptions.set("geometry.remove", "true");
1851 neteditOptions.set("ramps.guess", "true");
1852 neteditOptions.set("junctions.join", "true");
1853 neteditOptions.set("tls.guess-signals", "true");
1854 neteditOptions.set("tls.discard-simple", "true");
1855 // open netedit options dialog
1856 const GNENeteditOptionsDialog neteditOptionsDialog(this, neteditOptions, myOriginalNeteditOptions);
1857 // open wizard dialog
1858 if (neteditOptionsDialog.getResult() == GNEDialog::Result::ACCEPT) {
1859 // needed to set projection parameters
1860 NIFrame::checkOptions(neteditOptions);
1861 // set file to load
1862 neteditOptions.resetWritable();
1863 neteditOptions.set("configuration-file", OSMFile);
1864 // set status bar
1865 setStatusBarText(TLF("Loading OSM file '%'.", OSMFile));
1866 // load config
1868 }
1869}
1870
1871void
1872GNEApplicationWindow::setStatusBarText(const std::string& statusBarText) {
1873 myStatusbar->getStatusLine()->setText(statusBarText.c_str());
1874 myStatusbar->getStatusLine()->setNormalText(statusBarText.c_str());
1875}
1876
1877
1878long
1879GNEApplicationWindow::computeJunctionWithVolatileOptions(FXObject* sender, FXSelector sel, void* ptr) {
1880 // open question dialog box
1881 const GNEQuestionBasicDialog questionDialog(this, GNEDialog::Buttons::YES_NO,
1882 TL("Recompute with volatile options"),
1883 TL("Changes produced in the net due a recomputing with"),
1884 TL("volatile options cannot be undone. Continue?"));
1885 // check result
1886 if (questionDialog.getResult() == GNEDialog::Result::ACCEPT) {
1887 // save all elements
1888 onCmdSaveAdditionalElements(sender, sel, ptr);
1889 onCmdSaveDemandElements(sender, sel, ptr);
1890 onCmdSaveDataElements(sender, sel, ptr);
1891 onCmdSaveMeanDataElements(sender, sel, ptr);
1892 // compute with volatile options
1893 myNet->computeNetwork(this, true, true);
1895 }
1896 return 1;
1897}
1898
1899
1900bool
1903 myConsoleOptionsLoaded = false;
1904 return true;
1905 } else {
1906 return false;
1907 }
1908}
1909
1910
1915
1916
1921
1922
1923void
1927
1928
1929long
1930GNEApplicationWindow::onCmdSetSuperMode(FXObject* sender, FXSelector sel, void* ptr) {
1931 // check that currently there is a View
1932 if (myViewNet) {
1933 myViewNet->onCmdSetSupermode(sender, sel, ptr);
1934 }
1935 return 1;
1936}
1937
1938
1939long
1940GNEApplicationWindow::onCmdSetMode(FXObject* sender, FXSelector sel, void* ptr) {
1941 // check that currently there is a View
1942 if (myViewNet) {
1943 myViewNet->onCmdSetMode(sender, sel, ptr);
1944 }
1945 return 1;
1946}
1947
1948
1949long
1950GNEApplicationWindow::onCmdLockElements(FXObject*, FXSelector sel, void*) {
1951 if (myViewNet) {
1952 // check if we're calling the functions using internal test
1953 switch (FXSELID(sel)) {
1956 break;
1957 case MID_GNE_LOCK_EDGE:
1959 break;
1960 case MID_GNE_LOCK_LANE:
1962 break;
1965 break;
1968 break;
1971 break;
1974 break;
1975 case MID_GNE_LOCK_WIRE:
1977 break;
1978 case MID_GNE_LOCK_TAZ:
1980 break;
1983 break;
1984 case MID_GNE_LOCK_POI:
1986 break;
1989 break;
1992 break;
1993 case MID_GNE_LOCK_ROUTE:
1995 break;
1998 break;
2001 break;
2004 break;
2005 case MID_GNE_LOCK_WALK:
2007 break;
2008 case MID_GNE_LOCK_RIDE:
2010 break;
2013 break;
2016 break;
2019 break;
2020 case MID_GNE_LOCK_STOP:
2022 break;
2025 break;
2028 break;
2031 break;
2032 default:
2033 break;
2034 }
2036 }
2037 return 1;
2038}
2039
2040
2041long
2042GNEApplicationWindow::onCmdLockAllElements(FXObject*, FXSelector, void*) {
2043 // lock all
2046 return 1;
2047}
2048
2049
2050long
2052 // unlock all
2055 return 1;
2056}
2057
2058
2059long
2061 if (myViewNet) {
2062 myViewNet->update();
2063 }
2064 return 1;
2065}
2066
2067
2068long
2069GNEApplicationWindow::onUpdLockMenuTitle(FXObject*, FXSelector, void*) {
2070 if (myViewNet) {
2072 // supermode network
2078 myLockMenuTitle->enable();
2079 } else {
2080 myLockMenuTitle->disable();
2081 }
2083 // supermode demand
2088 myLockMenuTitle->enable();
2089 } else {
2090 myLockMenuTitle->disable();
2091 }
2093 // supermode data
2097 myLockMenuTitle->enable();
2098 } else {
2099 myLockMenuTitle->disable();
2100 }
2101 } else {
2102 myLockMenuTitle->disable();
2103 }
2104 } else {
2105 myLockMenuTitle->disable();
2106 }
2107 return 1;
2108}
2109
2110
2111long
2112GNEApplicationWindow::onCmdProcessButton(FXObject* sender, FXSelector sel, void* ptr) {
2113 // first check if there is a view
2114 if (myViewNet) {
2115 // process depending of supermode
2117 // check what FXMenuCommand was called
2118 switch (FXSELID(sel)) {
2120 myNet->computeNetwork(this, true, false);
2122 break;
2124 computeJunctionWithVolatileOptions(sender, sel, ptr);
2125 break;
2128 break;
2131 break;
2134 break;
2135 default:
2136 break;
2137 }
2139 // check what FXMenuCommand was called
2140 switch (FXSELID(sel)) {
2144 break;
2147 break;
2150 break;
2153 break;
2156 break;
2157 default:
2158 break;
2159 }
2160 }
2161 // refresh to update undo-redo button
2162 myViewNet->getViewParent()->getGNEAppWindows()->forceRefresh();
2163 }
2164 return 1;
2165}
2166
2167
2168long
2169GNEApplicationWindow::onCmdNewWindow(FXObject*, FXSelector sel, void* /*ptr*/) {
2170 // get extra arguments
2171 std::string extraArg;
2173 extraArg = " -s \"" + StringUtils::escapeShell(myNetgenerateOptions.getValueString("output-file")) + "\" ";
2174 }
2175 FXRegistry reg("SUMO netedit", "netedit");
2176 std::string netedit = "netedit";
2177 const char* sumoPath = getenv("SUMO_HOME");
2178 if (sumoPath != nullptr) {
2179#ifdef DEBUG
2180 std::string newPath = std::string(sumoPath) + "/bin/neteditD";
2181#else
2182 std::string newPath = std::string(sumoPath) + "/bin/netedit";
2183#endif
2184 if (FileHelpers::isReadable(newPath) || FileHelpers::isReadable(newPath + ".exe")) {
2185 netedit = "\"" + newPath + "\"";
2186 }
2187 }
2188 std::string cmd = netedit + extraArg;
2189 // start in background
2190#ifndef WIN32
2191 cmd = cmd + " &";
2192#else
2193 // see "help start" for the parameters
2194 cmd = "start /B \"\" " + cmd;
2195#endif
2196 WRITE_MESSAGE(TLF("Running '%'.", cmd));
2197 // yay! fun with dangerous commands... Never use this over the internet
2199 return 1;
2200}
2201
2202
2203long
2204GNEApplicationWindow::onCmdOpenSUMOGUI(FXObject* obj, FXSelector sel, void* ptr) {
2205 // input parameters
2206 std::string inputParameters;
2207 // if we have only a network, then load directly without creating a SumoConfig
2209 ((myEditMenuCommands.loadAdditionalsInSUMOGUI->getCheck() == FALSE) && (myEditMenuCommands.loadDemandInSUMOGUI->getCheck() == FALSE))) {
2210 // force save network
2211 if (onCmdSaveNetwork(obj, sel, ptr) == 0) {
2212 // network wasn't saved, then stop
2213 return 0;
2214 }
2215 inputParameters = " --registry-viewport -n \"" + myFileBucketHandler->getDefaultFilename(FileBucket::Type::NETWORK) + "\"";
2216 // write info
2218 } else {
2219 // force save SumoConfig
2220 if (onCmdSaveSumoConfig(obj, sel, ptr) == 0) {
2221 // SumoConfig wasn't saved, then stop
2222 return 0;
2223 }
2224 inputParameters = " --registry-viewport -c \"" + myFileBucketHandler->getDefaultFilename(FileBucket::Type::SUMO_CONFIG) + "\"";
2225 // write info
2226 WRITE_MESSAGE(TLF("Loading sumo config '%' in SUMO-GUI.", myFileBucketHandler->getDefaultFilename(FileBucket::Type::SUMO_CONFIG)));
2227 }
2228 // save current viewport in registry
2229 FXRegistry reg("SUMO GUI", "sumo-gui");
2230 reg.read();
2231 reg.writeRealEntry("viewport", "x", myViewNet->getChanger().getXPos());
2232 reg.writeRealEntry("viewport", "y", myViewNet->getChanger().getYPos());
2233 reg.writeRealEntry("viewport", "z", myViewNet->getChanger().getZPos());
2234 reg.write();
2235 // declare executable
2236 std::string sumoGuiExecutable = "sumo-gui";
2237 // if SUMO_HOME is defined, update executable
2238 const char* sumoHome = getenv("SUMO_HOME");
2239 if (sumoHome != nullptr) {
2240 std::string newPath = std::string(sumoHome) + "/bin/sumo-gui";
2241 if (FileHelpers::isReadable(newPath) || FileHelpers::isReadable(newPath + ".exe")) {
2242 sumoGuiExecutable = "\"" + newPath + "\"";
2243 }
2244 }
2245 // declare command
2246 std::string cmd = sumoGuiExecutable + inputParameters;
2247 // start in background
2248#ifndef WIN32
2249 cmd = cmd + " &";
2250#else
2251 // see "help start" for the parameters
2252 cmd = "start /B \"\" " + cmd;
2253#endif
2254 WRITE_MESSAGE(TLF("Running '%'.", cmd));
2255 // yay! fun with dangerous commands... Never use this over the internet
2257 return 1;
2258}
2259
2260
2261long
2262GNEApplicationWindow::onCmdAbort(FXObject*, FXSelector, void*) {
2263 // check that view exists
2264 if (myViewNet) {
2265 // first check if we're selecting a subset of edges in TAZ Frame
2267 // clear current selection
2269 } else if (myViewNet->getViewParent()->getInspectorFrame()->shown()) {
2270 // check if stop select parent
2272 // and stop select paretn
2274 } else {
2275 // clear inspected elements
2277 }
2278 } else {
2279 // abort current operation
2281 }
2282 }
2283 return 1;
2284}
2285
2286
2287long
2288GNEApplicationWindow::onCmdDel(FXObject*, FXSelector, void*) {
2289 // check that view exists
2290 if (myViewNet) {
2292 }
2293 return 1;
2294}
2295
2296
2297long
2298GNEApplicationWindow::onCmdEnter(FXObject*, FXSelector, void*) {
2299 // check that view exists
2300 if (myViewNet) {
2302 }
2303 return 1;
2304}
2305
2306
2307long
2308GNEApplicationWindow::onCmdBackspace(FXObject*, FXSelector, void*) {
2309 // check that view exists
2310 if (myViewNet) {
2312 }
2313 return 1;
2314}
2315
2316
2317long
2318GNEApplicationWindow::onCmdFocusFrame(FXObject*, FXSelector, void*) {
2319 // check that view exists
2320 if (myViewNet) {
2322 }
2323 return 1;
2324}
2325
2326
2327long
2329 // check that view exists
2330 if (myViewNet) {
2332 }
2333 return 1;
2334}
2335
2336
2337long
2338GNEApplicationWindow::onCmdToggleTimeFormat(FXObject*, FXSelector, void*) {
2339 // check that view exists
2340 if (myViewNet) {
2342 // refresh flow frames
2343 if (myViewNet->getViewParent()->getVehicleFrame()->shown()) {
2345 }
2346 if (myViewNet->getViewParent()->getPersonFrame()->shown()) {
2348 }
2349 if (myViewNet->getViewParent()->getContainerFrame()->shown()) {
2351 }
2352 // refresh inspector frame
2353 if (myViewNet->getViewParent()->getInspectorFrame()->shown()) {
2355 }
2356 }
2357 return 1;
2358}
2359
2360
2361long
2362GNEApplicationWindow::onUpdToggleTimeFormat(FXObject*, FXSelector, void*) {
2363 // check that view exists
2364 if (myViewNet) {
2366 }
2367 return 1;
2368}
2369
2370
2371long
2372GNEApplicationWindow::onCmdRunTests(FXObject*, FXSelector, void*) {
2375 }
2376 return 1;
2377}
2378
2379
2380long
2381GNEApplicationWindow::onUpdRequireViewNet(FXObject* sender, FXSelector, void*) {
2382 // enable or disable sender element depending of viewNet
2383 return sender->handle(this, myViewNet ? FXSEL(SEL_COMMAND, ID_ENABLE) : FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2384}
2385
2386
2387long
2390 return 1;
2391}
2392
2393
2394long
2395GNEApplicationWindow::onCmdRunNetgenerate(FXObject*, FXSelector, void*) {
2396 GNERunNetgenerateDialog netgenerateDialog(this, &myNetgenerateOptions);
2397 return 1;
2398}
2399
2400
2401long
2402GNEApplicationWindow::onCmdPostprocessingNetgenerate(FXObject* obj, FXSelector, void* ptr) {
2404}
2405
2406
2407long
2408GNEApplicationWindow::onCmdEditViewport(FXObject*, FXSelector, void*) {
2409 // check that view exists
2410 if (myViewNet) {
2412 }
2413 return 1;
2414}
2415
2416
2417long
2418GNEApplicationWindow::onCmdEditViewScheme(FXObject*, FXSelector, void*) {
2419 // check that view exists
2420 if (myViewNet) {
2422 }
2423 return 1;
2424}
2425
2426
2427long
2428GNEApplicationWindow::onCmdToggleGrid(FXObject* sender, FXSelector sel, void* ptr) {
2429 // check that view exists
2430 if (myViewNet) {
2431 // Call manually toggle grid function
2432 myViewNet->onCmdToggleShowGrid(sender, sel, ptr);
2433 }
2434 return 1;
2435}
2436
2437
2438long
2439GNEApplicationWindow::onCmdToggleDrawJunctionShape(FXObject* sender, FXSelector sel, void* ptr) {
2440 // check that view exists
2441 if (myViewNet) {
2442 // Call manually toggle junction shape function
2443 myViewNet->onCmdToggleDrawJunctionShape(sender, sel, ptr);
2444 }
2445 return 1;
2446}
2447
2448
2449long
2451 if (myViewNet) {
2452 // check if all element are front
2453 bool allFront = true;
2454 for (auto& AC : myViewNet->getInspectedElements().getACs()) {
2455 if (!AC->isMarkedForDrawingFront()) {
2456 allFront = false;
2457 break;
2458 }
2459 }
2460 // first unfront all elements
2462 // only mark front elements if we have at least one non-front element
2463 if (!allFront) {
2464 for (auto& AC : myViewNet->getInspectedElements().getACs()) {
2465 AC->markForDrawingFront();
2466 }
2467 }
2468 myViewNet->update();
2470 }
2471 return 1;
2472}
2473
2474
2475long
2476GNEApplicationWindow::onCmdToggleEditOptions(FXObject* sender, FXSelector sel, void* /* ptr */) {
2477 // first check that we have a ViewNet
2478 if (myViewNet) {
2479 // first check what selector was called
2480 int numericalKeyPressed = sel - FXSEL(SEL_COMMAND, MID_HOTKEY_ALT_0_TOGGLEEDITOPTION) - 1;
2481 // check that numericalKeyPressed is valid
2482 if ((numericalKeyPressed < 0) || (numericalKeyPressed > 10)) {
2483 return 0;
2484 }
2485 // declare a vector in which save visible menu commands
2486 std::vector<MFXCheckableButton*> visibleMenuCommands;
2487 // get common, network and demand visible menu commands
2491 // now check that numericalKeyPressed isn't greater than visible view options
2492 if (numericalKeyPressed >= (int)visibleMenuCommands.size()) {
2493 return 0;
2494 }
2495 // toggle edit options
2497 visibleMenuCommands.at(numericalKeyPressed), sender, sel)) {
2498 return 1;
2500 visibleMenuCommands.at(numericalKeyPressed), sender, sel)) {
2501 return 1;
2503 visibleMenuCommands.at(numericalKeyPressed), sender, sel)) {
2504 return 1;
2505 }
2506 }
2507 return 0;
2508}
2509
2510
2511long
2512GNEApplicationWindow::onCmdHelp(FXObject*, FXSelector, void*) {
2513 MFXLinkLabel::fxexecute("https://sumo.dlr.de/docs/netedit.html");
2514 return 1;
2515}
2516
2517
2518long
2519GNEApplicationWindow::onCmdChangelog(FXObject*, FXSelector, void*) {
2520 // update in every version
2521 MFXLinkLabel::fxexecute("https://sumo.dlr.de/docs/ChangeLog.html");
2522 return 1;
2523}
2524
2525
2526long
2527GNEApplicationWindow::onCmdHotkeys(FXObject*, FXSelector, void*) {
2528 MFXLinkLabel::fxexecute("https://sumo.dlr.de/docs/Netedit/shortcuts.html");
2529 return 1;
2530}
2531
2532
2533long
2536 return getApp()->reg().writeBoolEntry("NETEDIT", "RecomputeData", true);
2537 } else {
2538 return getApp()->reg().writeBoolEntry("NETEDIT", "RecomputeData", false);
2539 }
2540}
2541
2542
2543long
2544GNEApplicationWindow::onCmdToggleUndoRedo(FXObject*, FXSelector, void*) {
2545 if (myEditMenuCommands.menuCheckAllowUndoRedo->getCheck() == TRUE) {
2546 myAllowUndoRedo = true;
2547 return getApp()->reg().writeBoolEntry("NETEDIT", "AllowUndoRedo", true);
2548 } else {
2549 myAllowUndoRedo = false;
2550 // drop undo-redo list after changing flag
2551 myUndoList->clear();
2552 return getApp()->reg().writeBoolEntry("NETEDIT", "AllowUndoRedo", false);
2553 }
2554}
2555
2556
2557long
2559 if (myFileMenuCommands.menuCheckAllowUndoRedoLoading->getCheck() == TRUE) {
2561 return getApp()->reg().writeBoolEntry("NETEDIT", "AllowUndoRedoLoading", true);
2562 } else {
2563 myAllowUndoRedoLoading = false;
2564 return getApp()->reg().writeBoolEntry("NETEDIT", "AllowUndoRedoLoading", false);
2565 }
2566}
2567
2568
2569long
2570GNEApplicationWindow::onCmdTutorial(FXObject*, FXSelector, void*) {
2571 MFXLinkLabel::fxexecute("https://sumo.dlr.de/docs/Tutorials/index.html");
2572 return 1;
2573}
2574
2575
2576long
2577GNEApplicationWindow::onCmdFeedback(FXObject*, FXSelector, void*) {
2578 // create and open feedback dialog
2579 GUIDialog_Feedback* feedback = new GUIDialog_Feedback(this);
2580 feedback->create();
2581 feedback->show(PLACEMENT_OWNER);
2582 return 1;
2583}
2584
2585
2586long
2588 auto& neteditOptions = OptionsCont::getOptions();
2589 // open netedit option dialog
2590 const GNENeteditOptionsDialog neteditOptionsDialog(this, neteditOptions, myOriginalNeteditOptions);
2591 // continue depending of result
2592 if (neteditOptionsDialog.getResult() == GNEDialog::Result::ACCEPT) {
2593 NIFrame::checkOptions(neteditOptions); // needed to set projection parameters
2594 NBFrame::checkOptions(neteditOptions);
2595 NWFrame::checkOptions(neteditOptions);
2596 SystemFrame::checkOptions(neteditOptions); // needed to set precision
2597 // check if mark netedit config as unsaved
2598 if (neteditOptionsDialog.isOptionModified() && myNet) {
2600 }
2601 }
2602 return 1;
2603}
2604
2605
2606long
2608 // open sumo option dialog
2609 const GNESumoOptionsDialog sumoOptionsDialog(this, mySumoOptions, myOriginalSumoOptions);
2610 // continue depending of result
2611 if ((sumoOptionsDialog.getResult() == GNEDialog::Result::ACCEPT) && sumoOptionsDialog.isOptionModified() && myNet) {
2613 }
2614 return 1;
2615}
2616
2617
2618long
2621 return 1;
2622}
2623
2624
2625long
2627 // open netgenerate options dialog
2629 return 1;
2630}
2631
2632
2633long
2634GNEApplicationWindow::onCmdUndo(FXObject* sender, FXSelector, void*) {
2635 // Check conditions
2636 if (myViewNet == nullptr) {
2637 return 0;
2638 } else if ((myInternalTest != sender) && !myEditMenuCommands.undoLastChange->isEnabled()) {
2639 return 0;
2640 } else {
2641 // check supermode (currently ignore supermode data)
2644 // abort if user doesn't press "yes"
2646 return 0;
2647 }
2648 }
2650 // update current show frame after undo
2653 }
2654 // update file bucket options (needed to maintain integrity)
2656 // update manually undo/redo menu commands (see #6005)
2659 // update toolbar undo-redo buttons
2661 return 1;
2662 }
2663}
2664
2665
2666long
2667GNEApplicationWindow::onCmdRedo(FXObject* sender, FXSelector, void*) {
2668 // Check conditions
2669 if (myViewNet == nullptr) {
2670 return 0;
2671 } else if ((myInternalTest != sender) && !myEditMenuCommands.redoLastChange->isEnabled()) {
2672 return 0;
2673 } else {
2674 // check supermode (currently ignore supermode data)
2677 // abort if user doesn't press "yes"
2679 return 0;
2680 }
2681 }
2683 // update current show frame after redo
2686 }
2687 // update file bucket options (needed to maintain integrity)
2689 // update manually undo/redo menu commands (see #6005)
2692 // update toolbar undo-redo buttons
2694 return 1;
2695 }
2696}
2697
2698
2699long
2701 // open UndoList Dialog
2702 GNEUndoListDialog(this);
2703 return 1;
2704}
2705
2706
2707long
2708GNEApplicationWindow::onUpdOpenUndoListDialog(FXObject* sender, FXSelector, void*) {
2709 // check if net exist and there is something to undo/redo
2710 if (myNet && (myEditMenuCommands.undoLastChange->isEnabled() || myEditMenuCommands.redoLastChange->isEnabled())) {
2711 sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
2712 } else {
2713 sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2714 }
2715 return 1;
2716}
2717
2718
2719long
2721 // first check viewNet
2723 // update demand path calculator
2725 }
2726 return 1;
2727}
2728
2729
2730long
2731GNEApplicationWindow::onCmdCut(FXObject*, FXSelector, void*) {
2732 // Prepared for #6042
2733 return 1;
2734}
2735
2736
2737long
2738GNEApplicationWindow::onCmdCopy(FXObject*, FXSelector, void*) {
2739 // Prepared for #6042
2740 return 1;
2741}
2742
2743
2744long
2745GNEApplicationWindow::onCmdPaste(FXObject*, FXSelector, void*) {
2746 // Prepared for #6042
2747 return 1;
2748}
2749
2750
2751long
2752GNEApplicationWindow::onCmdSetTemplate(FXObject*, FXSelector, void*) {
2753 // first check if myViewNet exist
2754 if (myViewNet) {
2755 // call set template in inspector frame
2757 }
2758 return 1;
2759}
2760
2761
2762long
2763GNEApplicationWindow::onCmdCopyTemplate(FXObject*, FXSelector, void*) {
2764 // first check if myViewNet exist
2765 if (myViewNet) {
2766 // call copy template in inspector frame
2768 }
2769 return 1;
2770}
2771
2772
2773long
2774GNEApplicationWindow::onCmdClearTemplate(FXObject*, FXSelector, void*) {
2775 // first check if myViewNet exist
2776 if (myViewNet) {
2777 // call clear template in inspector frame
2779 }
2780 return 1;
2781}
2782
2783
2784long
2785GNEApplicationWindow::onUpdNeedsNetwork(FXObject* sender, FXSelector, void*) {
2786 // check if net exist
2787 if (myNet) {
2789 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
2790 } else {
2792 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2793 }
2794}
2795
2796
2797long
2798GNEApplicationWindow::onUpdNeedsNetworkElement(FXObject* sender, FXSelector, void*) {
2799 // check if at least there is one edge in the network
2800 if (myNet && (myNet->getAttributeCarriers()->getEdges().size() > 0)) {
2801 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
2802 } else {
2803 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2804 }
2805}
2806
2807
2808long
2809GNEApplicationWindow::onUpdNeedsFrontElement(FXObject* sender, FXSelector, void*) {
2810 // check if net, viewnet and front attribute exist
2811 if (myViewNet && (myViewNet->getInspectedElements().getACs().size() > 0)) {
2812 // check if all element are front
2813 bool allFront = true;
2814 for (auto& AC : myViewNet->getInspectedElements().getACs()) {
2815 if (!AC->isMarkedForDrawingFront()) {
2816 allFront = false;
2817 break;
2818 }
2819 }
2820 // set button text depending of all selected
2821 if (allFront) {
2822 myEditMenuCommands.toggleFrontElement->setText(TL("Unfront element"));
2823 myEditMenuCommands.toggleFrontElement->setTipText(TL("Unfront inspected elements"));
2824 } else {
2825 myEditMenuCommands.toggleFrontElement->setText(TL("Front element"));
2826 myEditMenuCommands.toggleFrontElement->setTipText(TL("Mark element to be drawn above everything else"));
2827 }
2828 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
2829 } else if (myViewNet && (myViewNet->getMarkFrontElements().getACs().size() > 0)) {
2830 myEditMenuCommands.toggleFrontElement->setText(TL("Unfront all element"));
2831 myEditMenuCommands.toggleFrontElement->setTipText(TL("Unfront all elements"));
2832 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
2833 } else {
2834 myEditMenuCommands.toggleFrontElement->setText(TL("Front element (only inspected elements)"));
2835 myEditMenuCommands.toggleFrontElement->setTipText(TL("Mark element to be drawn above everything else"));
2836 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2837 }
2838}
2839
2840
2841long
2842GNEApplicationWindow::onUpdSaveNetwork(FXObject* sender, FXSelector, void*) {
2843 if (myNet == nullptr) {
2844 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2845 } else if (myNet->getSavingStatus()->isNetworkSaved()) {
2846 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2847 } else {
2848 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
2849 }
2850}
2851
2852
2853long
2854GNEApplicationWindow::onUpdSaveAdditionalElements(FXObject* sender, FXSelector, void*) {
2855 if (myNet == nullptr) {
2856 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2858 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2859 } else {
2860 return sender->handle(this, myNet->getSavingStatus()->isAdditionalsSaved() ? FXSEL(SEL_COMMAND, ID_DISABLE) : FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
2861 }
2862}
2863
2864
2865long
2867 if (myNet == nullptr) {
2868 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2869 } else if (myNet->getAttributeCarriers()->getNumberOfAdditionals() == 0) {
2870 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2871 } else {
2872 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
2873 }
2874}
2875
2876
2877long
2878GNEApplicationWindow::onUpdSaveJuPedSimElementsAs(FXObject* sender, FXSelector, void*) {
2879 if (myNet == nullptr) {
2880 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2881 } else if (myNet->getAttributeCarriers()->getAdditionals().at(GNE_TAG_JPS_WALKABLEAREA).size() > 0) {
2882 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
2883 } else if (myNet->getAttributeCarriers()->getAdditionals().at(GNE_TAG_JPS_OBSTACLE).size() > 0) {
2884 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
2885 } else {
2886 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2887 }
2888}
2889
2890
2891long
2892GNEApplicationWindow::onUpdSaveDemandElements(FXObject* sender, FXSelector, void*) {
2893 if (myNet == nullptr) {
2894 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2895 } else if (myNet->getSavingStatus()->isDemandElementsSaved()) {
2896 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2897 } else {
2898 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
2899 }
2900
2901}
2902
2903
2904long
2905GNEApplicationWindow::onUpdSaveDemandElementsUnified(FXObject* sender, FXSelector, void*) {
2906 if (myNet == nullptr) {
2907 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2909 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2910 } else {
2911 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
2912 }
2913}
2914
2915
2916long
2917GNEApplicationWindow::onUpdSaveDataElements(FXObject* sender, FXSelector, void*) {
2918 if (myNet == nullptr) {
2919 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2920 } else if (myNet->getSavingStatus()->isDataElementsSaved()) {
2921 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2922 } else {
2923 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
2924 }
2925
2926}
2927
2928
2929long
2930GNEApplicationWindow::onUpdSaveDataElementsUnified(FXObject* sender, FXSelector, void*) {
2931 if (myNet == nullptr) {
2932 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2933 } else if (myNet->getAttributeCarriers()->getDataSets().size() == 0) {
2934 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2935 } else {
2936 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
2937 }
2938
2939}
2940
2941
2942long
2943GNEApplicationWindow::onUpdSaveMeanDataElements(FXObject* sender, FXSelector, void*) {
2944 if (myNet == nullptr) {
2945 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2946 } else if (myNet->getSavingStatus()->isMeanDatasSaved()) {
2947 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2948 } else {
2949 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
2950 }
2951}
2952
2953
2954long
2956 if (myNet == nullptr) {
2957 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2958 } else if (myNet->getAttributeCarriers()->getNumberOfMeanDatas() == 0) {
2959 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2960 } else {
2961 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
2962 }
2963
2964}
2965
2966
2967long
2968GNEApplicationWindow::onUpdUndo(FXObject* sender, FXSelector sel, void* ptr) {
2969 return myUndoList->onUpdUndo(sender, sel, ptr);
2970}
2971
2972
2973long
2974GNEApplicationWindow::onUpdRedo(FXObject* sender, FXSelector sel, void* ptr) {
2975 return myUndoList->onUpdRedo(sender, sel, ptr);
2976}
2977
2978
2979long
2980GNEApplicationWindow::onUpdComputePathManager(FXObject* sender, FXSelector /*sel*/, void* /*ptr*/) {
2981 // first check viewNet
2982 if (myViewNet) {
2983 // check supermode network
2985 // disable
2986 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2988 // disable
2989 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2990 } else {
2991 // enable
2992 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
2993 }
2994 } else {
2995 // disable
2996 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2997 }
2998}
2999
3000
3001long
3002GNEApplicationWindow::onCmdToggleViewOption(FXObject* sender, FXSelector sel, void* ptr) {
3003 // check viewNet
3004 if (myViewNet) {
3005 // continue depending of selector
3006 switch (FXSELID(sel)) {
3007 // Network
3009 return myViewNet->onCmdToggleShowGrid(sender, sel, ptr);
3011 return myViewNet->onCmdToggleDrawJunctionShape(sender, sel, ptr);
3013 return myViewNet->onCmdToggleDrawSpreadVehicles(sender, sel, ptr);
3015 return myViewNet->onCmdToggleShowDemandElementsNetwork(sender, sel, ptr);
3017 return myViewNet->onCmdToggleSelectEdges(sender, sel, ptr);
3019 return myViewNet->onCmdToggleShowConnections(sender, sel, ptr);
3021 return myViewNet->onCmdToggleHideConnections(sender, sel, ptr);
3023 return myViewNet->onCmdToggleShowAdditionalSubElements(sender, sel, ptr);
3025 return myViewNet->onCmdToggleShowTAZElements(sender, sel, ptr);
3027 return myViewNet->onCmdToggleExtendSelection(sender, sel, ptr);
3029 return myViewNet->onCmdToggleChangeAllPhases(sender, sel, ptr);
3031 return myViewNet->onCmdToggleMergeAutomatically(sender, sel, ptr);
3033 return myViewNet->onCmdToggleShowJunctionBubbles(sender, sel, ptr);
3035 return myViewNet->onCmdToggleMoveElevation(sender, sel, ptr);
3037 return myViewNet->onCmdToggleChainEdges(sender, sel, ptr);
3039 return myViewNet->onCmdToggleAutoOppositeEdge(sender, sel, ptr);
3040 // Demand
3042 return myViewNet->onCmdToggleShowGrid(sender, sel, ptr);
3044 return myViewNet->onCmdToggleDrawJunctionShape(sender, sel, ptr);
3046 return myViewNet->onCmdToggleDrawSpreadVehicles(sender, sel, ptr);
3048 return myViewNet->onCmdToggleHideNonInspecteDemandElements(sender, sel, ptr);
3050 return myViewNet->onCmdToggleHideShapes(sender, sel, ptr);
3052 return myViewNet->onCmdToggleShowTrips(sender, sel, ptr);
3054 return myViewNet->onCmdToggleShowAllPersonPlans(sender, sel, ptr);
3056 return myViewNet->onCmdToggleLockPerson(sender, sel, ptr);
3058 return myViewNet->onCmdToggleShowAllContainerPlans(sender, sel, ptr);
3060 return myViewNet->onCmdToggleLockContainer(sender, sel, ptr);
3062 return myViewNet->onCmdToggleShowOverlappedRoutes(sender, sel, ptr);
3063 // Data
3065 return myViewNet->onCmdToggleDrawJunctionShape(sender, sel, ptr);
3067 return myViewNet->onCmdToggleShowAdditionals(sender, sel, ptr);
3069 return myViewNet->onCmdToggleShowShapes(sender, sel, ptr);
3071 return myViewNet->onCmdToggleShowDemandElementsData(sender, sel, ptr);
3073 return myViewNet->onCmdToggleTAZRelDrawing(sender, sel, ptr);
3075 return myViewNet->onCmdToggleTAZRelDrawing(sender, sel, ptr);
3077 return myViewNet->onCmdToggleTAZRelOnlyFrom(sender, sel, ptr);
3079 return myViewNet->onCmdToggleTAZRelOnlyTo(sender, sel, ptr);
3080 default:
3081 return 0;
3082 }
3083 } else {
3084 return 0;
3085 }
3086}
3087
3088
3089long
3090GNEApplicationWindow::onUpdToggleViewOption(FXObject* sender, FXSelector sel, void* /*ptr*/) {
3091 // get menuCheck
3092 MFXMenuCheckIcon* menuCheck = dynamic_cast<MFXMenuCheckIcon*>(sender);
3093 // check viewNet
3094 if (myViewNet && menuCheck) {
3095 // continue depending of selector
3096 switch (FXSELID(sel)) {
3097 // Network
3100 menuCheck->setCheck(TRUE);
3101 } else {
3102 menuCheck->setCheck(FALSE);
3103 }
3104 break;
3107 menuCheck->setCheck(TRUE);
3108 } else {
3109 menuCheck->setCheck(FALSE);
3110 }
3111 break;
3114 menuCheck->setCheck(TRUE);
3115 } else {
3116 menuCheck->setCheck(FALSE);
3117 }
3118 break;
3121 menuCheck->setCheck(TRUE);
3122 } else {
3123 menuCheck->setCheck(FALSE);
3124 }
3125 break;
3128 menuCheck->setCheck(TRUE);
3129 } else {
3130 menuCheck->setCheck(FALSE);
3131 }
3132 break;
3135 menuCheck->setCheck(TRUE);
3136 } else {
3137 menuCheck->setCheck(FALSE);
3138 }
3139 break;
3142 menuCheck->setCheck(TRUE);
3143 } else {
3144 menuCheck->setCheck(FALSE);
3145 }
3146 break;
3149 menuCheck->setCheck(TRUE);
3150 } else {
3151 menuCheck->setCheck(FALSE);
3152 }
3153 break;
3156 menuCheck->setCheck(TRUE);
3157 } else {
3158 menuCheck->setCheck(FALSE);
3159 }
3160 break;
3163 menuCheck->setCheck(TRUE);
3164 } else {
3165 menuCheck->setCheck(FALSE);
3166 }
3167 break;
3170 menuCheck->setCheck(TRUE);
3171 } else {
3172 menuCheck->setCheck(FALSE);
3173 }
3174 break;
3177 menuCheck->setCheck(TRUE);
3178 } else {
3179 menuCheck->setCheck(FALSE);
3180 }
3181 break;
3184 menuCheck->setCheck(TRUE);
3185 } else {
3186 menuCheck->setCheck(FALSE);
3187 }
3188 break;
3191 menuCheck->setCheck(TRUE);
3192 } else {
3193 menuCheck->setCheck(FALSE);
3194 }
3195 break;
3198 menuCheck->setCheck(TRUE);
3199 } else {
3200 menuCheck->setCheck(FALSE);
3201 }
3202 break;
3205 menuCheck->setCheck(TRUE);
3206 } else {
3207 menuCheck->setCheck(FALSE);
3208 }
3209 break;
3210 // Demand
3213 menuCheck->setCheck(TRUE);
3214 } else {
3215 menuCheck->setCheck(FALSE);
3216 }
3217 break;
3220 menuCheck->setCheck(TRUE);
3221 } else {
3222 menuCheck->setCheck(FALSE);
3223 }
3224 break;
3227 menuCheck->setCheck(TRUE);
3228 } else {
3229 menuCheck->setCheck(FALSE);
3230 }
3231 break;
3234 menuCheck->setCheck(TRUE);
3235 } else {
3236 menuCheck->setCheck(FALSE);
3237 }
3238 break;
3241 menuCheck->setCheck(TRUE);
3242 } else {
3243 menuCheck->setCheck(FALSE);
3244 }
3245 break;
3248 menuCheck->setCheck(TRUE);
3249 } else {
3250 menuCheck->setCheck(FALSE);
3251 }
3252 break;
3255 menuCheck->setCheck(TRUE);
3256 } else {
3257 menuCheck->setCheck(FALSE);
3258 }
3259 // special case for lock persons
3261 menuCheck->enable();
3262 } else {
3263 menuCheck->disable();
3264 }
3265 break;
3268 menuCheck->setCheck(TRUE);
3269 } else {
3270 menuCheck->setCheck(FALSE);
3271 }
3272 break;
3275 menuCheck->setCheck(TRUE);
3276 } else {
3277 menuCheck->setCheck(FALSE);
3278 }
3279 // special case for lock containers
3281 menuCheck->enable();
3282 } else {
3283 menuCheck->disable();
3284 }
3285 break;
3288 menuCheck->setCheck(TRUE);
3289 } else {
3290 menuCheck->setCheck(FALSE);
3291 }
3292 break;
3295 menuCheck->setCheck(TRUE);
3296 } else {
3297 menuCheck->setCheck(FALSE);
3298 }
3299 break;
3300 // Data
3303 menuCheck->setCheck(TRUE);
3304 } else {
3305 menuCheck->setCheck(FALSE);
3306 }
3307 break;
3310 menuCheck->setCheck(TRUE);
3311 } else {
3312 menuCheck->setCheck(FALSE);
3313 }
3314 break;
3317 menuCheck->setCheck(TRUE);
3318 } else {
3319 menuCheck->setCheck(FALSE);
3320 }
3321 break;
3324 menuCheck->setCheck(TRUE);
3325 } else {
3326 menuCheck->setCheck(FALSE);
3327 }
3328 break;
3331 menuCheck->setCheck(TRUE);
3332 } else {
3333 menuCheck->setCheck(FALSE);
3334 }
3335 break;
3338 menuCheck->setCheck(TRUE);
3339 } else {
3340 menuCheck->setCheck(FALSE);
3341 }
3342 break;
3343
3346 menuCheck->setCheck(TRUE);
3347 } else {
3348 menuCheck->setCheck(FALSE);
3349 }
3350 break;
3353 menuCheck->setCheck(TRUE);
3354 } else {
3355 menuCheck->setCheck(FALSE);
3356 }
3357 break;
3358 default:
3359 break;
3360 }
3361 }
3362 return 0;
3363}
3364
3365
3366long
3367GNEApplicationWindow::onCmdSaveNetwork(FXObject* sender, FXSelector sel, void* ptr) {
3368 auto& neteditOptions = OptionsCont::getOptions();
3369 // check if we're forcing to saving additionals
3371 neteditOptions.getBool("force-saving")) {
3372 WRITE_MESSAGE(TL("Force save network"));
3373 } else if (myNet->getSavingStatus()->isNetworkSaved()) {
3374 // nothing to save
3375 return 1;
3376 }
3377 // first check if we have to set the output filename
3380 }
3381 // function onCmdSaveNetworkAs must be executed if this is the first save
3383 return onCmdSaveNetworkAs(sender, sel, ptr);
3384 } else {
3385 // always recompute before saving
3386 myNet->computeNetwork(this);
3387 bool saved = false;
3388 try {
3389 // obtain invalid networkElements (currently only edges or crossings
3390 std::vector<GNENetworkElement*> invalidNetworkElements;
3391 // iterate over crossings and edges
3392 for (const auto& edge : myViewNet->getNet()->getAttributeCarriers()->getEdges()) {
3393 if (!edge.second->isNetworkElementValid()) {
3394 invalidNetworkElements.push_back(edge.second);
3395 }
3396 }
3397 for (const auto& crossing : myViewNet->getNet()->getAttributeCarriers()->getCrossings()) {
3398 if (!crossing.second->isNetworkElementValid()) {
3399 invalidNetworkElements.push_back(crossing.second);
3400 }
3401 }
3402 // if there are invalid network elements, open GNEFixNetworkElements
3403 if (invalidNetworkElements.size() > 0) {
3404 // create fix network elements dialog
3405 const GNEFixNetworkElements fixNetworkElementsDialog(this, invalidNetworkElements);
3406 // continue depending of result
3407 if (fixNetworkElementsDialog.getResult() == GNEDialog::Result::ACCEPT) {
3408 // Save network
3409 myNet->saveNetwork();
3410 saved = true;
3411 } else {
3412 // stop
3413 return 0;
3414 }
3415 } else {
3416 // Save network
3417 myNet->saveNetwork();
3418 saved = true;
3419 }
3420 } catch (IOError& e) {
3421 // open error message box
3422 GNEErrorBasicDialog(this, TL("Saving network failed"), e.what());
3423 }
3424 if (saved) {
3425 // write info
3427 // After saving a net successfully, add it into Recent Nets list.
3430 } else {
3433 return 0;
3434 }
3435 return 1;
3436 }
3437}
3438
3439
3440long
3441GNEApplicationWindow::onCmdSaveNetworkAs(FXObject* sender, FXSelector sel, void* ptr) {
3442 // get network file file
3443 const GNEFileDialog networkFileDialog(this, TL("network file"),
3448 // continue depending of dialog
3449 if (networkFileDialog.getResult() == GNEDialog::Result::ACCEPT) {
3450 // update default network file
3452 // update netedit title with the network name
3453 setTitle(MFXUtils::getTitleText(myTitlePrefix, networkFileDialog.getFilename().c_str()));
3454 // enable save network
3456 // save network
3457 return onCmdSaveNetwork(sender, sel, ptr);
3458 } else {
3459 return 0;
3460 }
3461}
3462
3463
3464long
3465GNEApplicationWindow::onCmdSavePlainXML(FXObject* sender, FXSelector sel, void* ptr) {
3466 // first check if we have to set the output filename
3469 }
3470 // function onCmdSaveNetworkAs must be executed if this is the first save
3472 return onCmdSavePlainXMLAs(sender, sel, ptr);
3473 } else {
3474 // start saving plain XML
3475 getApp()->beginWaitCursor();
3476 try {
3477 // we use the prefix instead the netconvert config
3479 // save plain xml
3480 myNet->savePlain(plainXMLPrefix, myNetconvertOptions);
3481 // write info
3482 WRITE_MESSAGE(TLF("Plain XML saved with prefix '%'.", plainXMLPrefix));
3483 } catch (IOError& e) {
3484 // open message box
3485 GNEErrorBasicDialog(this, TL("Saving plain xml failed"), e.what());
3486 }
3487 // end saving plain XML
3488 getApp()->endWaitCursor();
3489 // set focus again in viewNet
3490 myViewNet->setFocus();
3491 }
3492 return 1;
3493}
3494
3495
3496long
3497GNEApplicationWindow::onCmdSavePlainXMLAs(FXObject* sender, FXSelector sel, void* ptr) {
3498 // get neteditConfig filename
3499 const GNEFileDialog plainXMLFileDialog(this, TL("plain XML file"),
3504 // continue depending of dialog
3505 if (plainXMLFileDialog.getResult() == GNEDialog::Result::ACCEPT) {
3506 // update default netconvert file
3508 // save plain xml
3509 return onCmdSavePlainXML(sender, sel, ptr);
3510 }
3511 return 1;
3512}
3513
3514
3515long
3517 // get neteditConfig filename
3518 const GNEFileDialog joinedJunctionsFileDialog(this, TL("joined junctions file"),
3523 // continue depending of dialog
3524 if (joinedJunctionsFileDialog.getResult() == GNEDialog::Result::ACCEPT) {
3525 getApp()->beginWaitCursor();
3526 try {
3527 myNet->saveJoined(joinedJunctionsFileDialog.getFilename());
3528 // write info
3529 WRITE_MESSAGE(TLF("Joined junctions saved to '%'.", joinedJunctionsFileDialog.getFilename()));
3530 } catch (IOError& e) {
3531 // opening error message
3532 GNEErrorBasicDialog(this, TL("Saving joined junctions failed"), e.what());
3533 }
3534 getApp()->endWaitCursor();
3535 // set focus again in viewNet
3536 myViewNet->setFocus();
3537 }
3538 return 1;
3539}
3540
3541
3542long
3543GNEApplicationWindow::onCmdSaveNeteditConfig(FXObject* sender, FXSelector sel, void* ptr) {
3544 // first check if netedit config is already saved
3546 return 1;
3547 }
3548 // Check if configuration file was already set at start of netedit or with a previous save
3550 return onCmdSaveNeteditConfigAs(sender, sel, ptr);
3551 } else {
3552 // save all elements giving automatic names based on patter if their file isn't defined
3553 if (onCmdSaveNetwork(sender, sel, ptr) != 1) {
3554 WRITE_MESSAGE(TL("Saving of netedit configuration aborted (due network)."));
3555 return 0;
3556 }
3557 if (onCmdSaveAdditionalElements(sender, sel, ptr) != 1) {
3558 WRITE_MESSAGE(TL("Saving of netedit configuration aborted (due additional file)."));
3559 return 0;
3560 }
3561 if (onCmdSaveDemandElements(sender, sel, ptr) != 1) {
3562 WRITE_MESSAGE(TL("Saving of netedit configuration aborted (due demand file)."));
3563 return 0;
3564 }
3565 if (onCmdSaveDataElements(sender, sel, ptr) != 1) {
3566 WRITE_MESSAGE(TL("Saving of netedit configuration aborted (due data file)."));
3567 return 0;
3568 }
3569 if (onCmdSaveMeanDataElements(sender, sel, ptr) != 1) {
3570 WRITE_MESSAGE(TL("Saving of netedit configuration aborted (due meanData file)."));
3571 return 0;
3572 }
3573 // get netedit config file
3575 // configuration
3576 std::ofstream out(StringUtils::transcodeToLocal(neteditConfigFile));
3577 if (out.good()) {
3578 const auto& neteditOptions = OptionsCont::getOptions();
3579 // write netedit config
3580 neteditOptions.writeConfiguration(out, true, false, false, neteditConfigFile, true);
3581 // write info
3582 WRITE_MESSAGE(TLF("Netedit configuration saved in '%'.", neteditConfigFile));
3583 // config saved
3585 // After saving a config successfully, add it into recent configs
3586 myMenuBarFile.myRecentConfigs.appendFile(neteditConfigFile.c_str());
3587 // if we have a sumo config defined, save it also
3589 // get SumoConfig file
3591 std::ofstream out(StringUtils::transcodeToLocal(sumoConfigFile));
3592 if (out.good()) {
3593 // before saving sumo config, check if force enable option junction-taz
3595 mySumoOptions.set("junction-taz", "true");
3596 }
3597 // write SUMO config
3598 mySumoOptions.writeConfiguration(out, true, false, false, sumoConfigFile, true);
3599 // write info
3600 WRITE_MESSAGE(TLF("SUMO configuration saved in '%'.", sumoConfigFile));
3601 // After saving a config successfully, add it into recent configs
3602 myMenuBarFile.myRecentConfigs.appendFile(sumoConfigFile.c_str());
3603 }
3604 }
3605 // save in plain XML (netconvert) if the option is enabled (usually used in netedit tests)
3606 if (neteditOptions.getBool("autosave-netconvert-file")) {
3607 onCmdSavePlainXML(sender, sel, ptr);
3608 }
3609 } else {
3610 WRITE_ERROR(TLF("Could not save netedit configuration in '%'.", neteditConfigFile));
3611 }
3612 out.close();
3613 return 1;
3614 }
3615}
3616
3617
3618long
3619GNEApplicationWindow::onCmdSaveNeteditConfigAs(FXObject* sender, FXSelector sel, void* ptr) {
3620 // get neteditConfig filename
3621 const GNEFileDialog neteditConfigFileDialog(this, TL("netedit config file"),
3626 // continue depending of dialog
3627 if (neteditConfigFileDialog.getResult() == GNEDialog::Result::ACCEPT) {
3628 // set file in file bucket handler
3630 // mark netedit config as unsaved
3632 // continue saving netedit config
3633 return onCmdSaveNeteditConfig(sender, sel, ptr);
3634 } else {
3635 return 0;
3636 }
3637}
3638
3639
3640long
3641GNEApplicationWindow::onUpdSaveNeteditConfig(FXObject* sender, FXSelector, void*) {
3642 // check if enable or disable save netedit config button
3643 if (myNet == nullptr) {
3644 sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
3646 sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
3647 } else if (!myNet->getSavingStatus()->isNeteditConfigSaved()) {
3648 sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
3649 } else {
3650 sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
3651 }
3652 // check if enable/disable save individual files
3653 if (myNet) {
3657 } else {
3659 }
3660 }
3661 return 1;
3662}
3663
3664
3665long
3666GNEApplicationWindow::onCmdSaveSumoConfig(FXObject* sender, FXSelector sel, void* ptr) {
3667 // first check if netedit config is already saved
3669 return 1;
3670 }
3671 // obtain netedit option container
3672 auto& neteditOptions = OptionsCont::getOptions();
3673 // reset containers
3674 neteditOptions.resetWritable();
3676 // Check if configuration file was already set at start of netedit or with a previous save
3678 return onCmdSaveSumoConfigAs(sender, sel, ptr);
3679 } else {
3680 // save all elements giving automatic names based on patter in their file isn't defined
3681 if (onCmdSaveNetwork(sender, sel, ptr) != 1) {
3682 WRITE_MESSAGE(TL("Saving of SUMO configuration aborted"));
3683 return 0;
3684 }
3685 if (onCmdSaveAdditionalElements(sender, sel, ptr) != 1) {
3686 WRITE_MESSAGE(TL("Saving of SUMO configuration aborted"));
3687 return 0;
3688 }
3689 if (onCmdSaveDemandElements(sender, sel, ptr) != 1) {
3690 WRITE_MESSAGE(TL("Saving of SUMO configuration aborted"));
3691 return 0;
3692 }
3693 if (onCmdSaveDataElements(sender, sel, ptr) != 1) {
3694 WRITE_MESSAGE(TL("Saving of SUMO configuration aborted"));
3695 return 0;
3696 }
3697 if (onCmdSaveMeanDataElements(sender, sel, ptr) != 1) {
3698 WRITE_MESSAGE(TL("Saving of SUMO configuration aborted"));
3699 return 0;
3700 }
3701 // get SumoConfig file
3703 // confinguration
3704 std::ofstream out(StringUtils::transcodeToLocal(sumoConfigFile));
3705 if (out.good()) {
3706 // before saving sumo config, check if force enable option junction-taz
3708 mySumoOptions.set("junction-taz", "true");
3709 }
3710 // write SUMO config
3711 mySumoOptions.writeConfiguration(out, true, false, false, sumoConfigFile, true);
3712 // write info
3713 WRITE_MESSAGE(TLF("SUMO configuration saved in '%'.", sumoConfigFile));
3714 // After saving a config successfully, add it into recent configs
3715 myMenuBarFile.myRecentConfigs.appendFile(sumoConfigFile.c_str());
3716 // if we have a netedit cong defined, save it also
3718 // get netedit config file
3720 // configuration
3721 std::ofstream out(StringUtils::transcodeToLocal(neteditConfigFile));
3722 if (out.good()) {
3723 // write netedit config
3724 neteditOptions.writeConfiguration(out, true, false, false, myFileBucketHandler->getDefaultFolder(FileBucket::Type::NETEDIT_CONFIG), true);
3725 // write info
3726 WRITE_MESSAGE(TLF("Netedit configuration saved in '%'.", neteditConfigFile));
3727 // config saved
3729 // After saving a config successfully, add it into recent configs
3730 myMenuBarFile.myRecentConfigs.appendFile(neteditConfigFile.c_str());
3731 }
3732 }
3733 // save in plain XML (netconvert) if the option is enabled (usually used in netedit tests)
3734 if (neteditOptions.getBool("autosave-netconvert-file")) {
3735 onCmdSavePlainXML(sender, sel, ptr);
3736 }
3737 } else {
3738 WRITE_MESSAGE(TLF("Could not save SUMO configuration in '%'.", sumoConfigFile));
3739 }
3740 out.close();
3741 return 1;
3742 }
3743}
3744
3745
3746long
3747GNEApplicationWindow::onCmdSaveSumoConfigAs(FXObject* sender, FXSelector sel, void* ptr) {
3748 // get sumoConfig filename
3749 const GNEFileDialog sumoConfigFileDialog(this, TL("sumo config file"),
3754 // continue depending of dialog
3755 if (sumoConfigFileDialog.getResult() == GNEDialog::Result::ACCEPT) {
3756 // set sumo config
3758 // mark netedit config as unsaved
3760 // check instead saving sumo config, save netedit config (this will save also the sumoConfig)
3762 return onCmdSaveNeteditConfig(sender, sel, ptr);
3763 } else {
3764 return onCmdSaveSumoConfig(sender, sel, ptr);
3765 }
3766 } else {
3767 return 0;
3768 }
3769}
3770
3771
3772long
3773GNEApplicationWindow::onUpdSaveSumoConfig(FXObject* sender, FXSelector, void*) {
3774 if (myNet == nullptr) {
3775 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
3777 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
3778 } else if (!myNet->getSavingStatus()->isSumoConfigSaved()) {
3779 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
3780 } else {
3781 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
3782 }
3783}
3784
3785
3786long
3787GNEApplicationWindow::onCmdSaveTLSPrograms(FXObject* obj, FXSelector sel, void* ptr) {
3788 // Check if TLS Programs file was already set at start of netedit or with a previous save
3790 return onCmdSaveTLSProgramsAs(obj, sel, ptr);
3791 } else {
3792 // Start saving TLS Programs
3793 getApp()->beginWaitCursor();
3794 try {
3795 // compute before saving
3796 myNet->computeNetwork(this, true); // GNEChange_TLS does not triggere GNENet:requireRecompute
3798 // write info
3800 } catch (IOError& e) {
3801 // open error message box
3802 GNEErrorBasicDialog(this, TL("Saving TLS Programs failed"), e.what());
3803 }
3805 getApp()->endWaitCursor();
3806 // set focus again in viewNet
3807 myViewNet->setFocus();
3808 }
3809 return 1;
3810}
3811
3812
3813long
3814GNEApplicationWindow::onUpdSaveTLSPrograms(FXObject* sender, FXSelector, void*) {
3815 if (myNet == nullptr) {
3816 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
3817 } else {
3818 // check if there is at least one TLS
3819 for (const auto& junction : myNet->getAttributeCarriers()->getJunctions()) {
3820 if (junction.second->getNBNode()->getControllingTLS().size() > 0) {
3821 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
3822 }
3823 }
3824 // no TLS, then disable
3825 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
3826 }
3827}
3828
3829
3830long
3831GNEApplicationWindow::onCmdSaveEdgeTypes(FXObject* obj, FXSelector sel, void* ptr) {
3832 // Check if edgeType file was already set at start of netedit or with a previous save
3834 return onCmdSaveEdgeTypesAs(obj, sel, ptr);
3835 } else {
3836 // Start saving edgeTypes
3837 getApp()->beginWaitCursor();
3838 try {
3840 // save edge types
3841 myNet->saveEdgeTypes(edgeTypeFile);
3842 // write info
3843 WRITE_MESSAGE(TLF("EdgeType saved in '%'.", edgeTypeFile));
3844 } catch (IOError& e) {
3845 // open error message box
3846 GNEErrorBasicDialog(this, TL("Saving edgeTypes failed"), e.what());
3847 }
3849 getApp()->endWaitCursor();
3850 }
3851 return 1;
3852}
3853
3854
3855long
3856GNEApplicationWindow::onUpdSaveEdgeTypes(FXObject* sender, FXSelector, void*) {
3857 // check if net exist and there are edge types
3858 if (myNet && (myNet->getAttributeCarriers()->getEdgeTypes().size() > 0)) {
3859 sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
3860 } else {
3861 sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
3862 }
3863 return 1;
3864}
3865
3866
3867long
3868GNEApplicationWindow::onCmdSaveTLSProgramsAs(FXObject* sender, FXSelector sel, void* ptr) {
3869 // get TLS file
3870 const GNEFileDialog TLSfileDialog(this, TL("Traffic Light definitions file"),
3875 // continue depending of dialog
3876 if (TLSfileDialog.getResult() == GNEDialog::Result::ACCEPT) {
3877 // set tls type in bucket
3879 // enable save netedit config
3881 // set focus again in viewNet
3882 myViewNet->setFocus();
3883 // save TLS Programs
3884 return onCmdSaveTLSPrograms(sender, sel, ptr);
3885 } else {
3886 return 1;
3887 }
3888}
3889
3890
3891long
3892GNEApplicationWindow::onCmdSaveEdgeTypesAs(FXObject* sender, FXSelector sel, void* ptr) {
3893 // get network file file
3894 const GNEFileDialog edgeTypeFileDialog(this, TL("EdgeTypes file"),
3899 // continue depending of dialog
3900 if (edgeTypeFileDialog.getResult() == GNEDialog::Result::ACCEPT) {
3901 // set tls type in bucket
3903 // enable save netedit config
3905 // set focus again in viewNet
3906 myViewNet->setFocus();
3907 // save edgeTypes
3908 return onCmdSaveEdgeTypes(sender, sel, ptr);
3909 } else {
3910 return 1;
3911 }
3912}
3913
3914
3915long
3917 // get file
3918 const GNEFileDialog additionalFileDialog(this, TL("Additional elements file"),
3923 // continue depending of dialog
3924 if (additionalFileDialog.getResult() == GNEDialog::Result::ACCEPT) {
3925 // flag for save current saving status
3926 const auto previouslySaved = myNet->getSavingStatus()->isAdditionalsSaved();
3927 // get (or create) bucket for this new file
3928 auto bucket = myFileBucketHandler->getBucket(FileBucket::Type::ADDITIONAL, additionalFileDialog.getFilename(), true);
3929 // disable validation for additionals
3930 XMLSubSys::setValidation("never", "auto", "auto");
3931 // Create additional handler
3932 GNEGeneralHandler generalHandler(myNet, bucket, myAllowUndoRedoLoading ? myAllowUndoRedo : false);
3933 // begin undoList operation
3934 myUndoList->begin(Supermode::NETWORK, GUIIcon::SUPERMODENETWORK, TLF("load additionals from '%'", bucket->getFilename()));
3935 // Run parser
3936 if (!generalHandler.parse()) {
3937 // write error
3938 WRITE_ERROR(TLF("Loading of additional file '%' failed.", bucket->getFilename()));
3939 } else {
3940 // write info
3941 WRITE_MESSAGE(TLF("Loading of additional file '%' successfully.", bucket->getFilename()));
3942 // enable save if there is errors loading additionals
3943 if (previouslySaved && !generalHandler.isErrorCreatingElement()) {
3945 }
3946 }
3947 // end undoList operation
3948 myUndoList->end();
3949 // restore validation for additionals
3950 XMLSubSys::setValidation("auto", "auto", "auto");
3951 // check if clear undoList
3953 myUndoList->clear();
3954 }
3955 update();
3956 }
3957 return 1;
3958}
3959
3960
3961long
3963 // disable validation for additionals
3964 XMLSubSys::setValidation("never", "auto", "auto");
3965 // begin undoList operation
3966 myUndoList->begin(Supermode::DEMAND, GUIIcon::SUPERMODENETWORK, TL("reloading additionals"));
3967 // clear additionals
3969 // reload additional elements stored in options
3970 loadAdditionalElements("Reloading");
3971 // end undoList operation
3972 myUndoList->end();
3973 // restore validation for additionals
3974 XMLSubSys::setValidation("auto", "auto", "auto");
3975 // check if clear undoList
3977 myUndoList->clear();
3978 }
3979 update();
3980 return 1;
3981}
3982
3983
3984long
3985GNEApplicationWindow::onUpdReloadAdditionalElements(FXObject* sender, FXSelector, void*) {
3986 if (myViewNet == nullptr) {
3987 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
3989 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
3990 } else {
3991 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
3992 }
3993}
3994
3995
3996long
3997GNEApplicationWindow::onCmdSaveAdditionalElements(FXObject* sender, FXSelector sel, void* ptr) {
3998 const auto savingFileHandler = myFileBucketHandler;
3999 // get option container
4000 auto& neteditOptions = OptionsCont::getOptions();
4001 // check if we're forcing to saving additionals
4003 neteditOptions.getBool("force-saving") &&
4005 WRITE_MESSAGE(TL("Force save additional elements"));
4006 } else if (myNet->getSavingStatus()->isAdditionalsSaved()) {
4007 // nothing to save
4008 return 1;
4009 }
4010 // check if we have to define a default filename
4012 savingFileHandler->setDefaultFilenameFile(FileBucket::Type::ADDITIONAL, myFileBucketHandler->getConfigFilePrefix(".add.xml"));
4013 }
4014 // check if we have to open save as dialog
4015 if (!savingFileHandler->isFilenameDefined(FileBucket::Type::ADDITIONAL)) {
4016 // choose file to save
4017 return onCmdSaveAdditionalElementsAs(sender, sel, ptr);
4018 } else {
4019 // always recompute before saving
4020 myNet->computeNetwork(this);
4021 try {
4022 // compute before saving (for detectors positions)
4023 myNet->computeNetwork(this);
4024 // save additionals
4025 const bool savingResult = myNet->saveAdditionals();
4026 // show info
4027 if (savingResult) {
4028 WRITE_MESSAGE(TL("Additionals saved."));
4029 return 1;
4030 } else {
4031 WRITE_MESSAGE(TL("Saving additional aborted."));
4032 return 0;
4033 }
4034 } catch (IOError& e) {
4035 // open error message box
4036 GNEErrorBasicDialog(this, TL("Saving additional elements failed"), e.what());
4037 }
4038 return 0;
4039 }
4040}
4041
4042
4043long
4044GNEApplicationWindow::onCmdSaveAdditionalElementsAs(FXObject* sender, FXSelector sel, void* ptr) {
4045 // get additional file
4046 const GNEFileDialog additionalFileDialog(this, TL("Additional elements as"),
4051 // continue depending of dialog
4052 if (additionalFileDialog.getResult() == GNEDialog::Result::ACCEPT) {
4053 // update default name
4055 // save additional
4056 return onCmdSaveAdditionalElements(sender, sel, ptr);
4057 } else {
4058 return 0;
4059 }
4060}
4061
4062
4063long
4064GNEApplicationWindow::onCmdSaveAdditionalElementsUnified(FXObject* sender, FXSelector sel, void* ptr) {
4065 // get additional file
4066 const GNEFileDialog additionalFileDialog(this, TL("Additional elements in unified file"),
4071 // continue depending of dialog
4072 if (additionalFileDialog.getResult() == GNEDialog::Result::ACCEPT) {
4073 // use the file as default file
4075 // begin undoList operation
4076 myUndoList->begin(Supermode::NETWORK, GUIIcon::SUPERMODENETWORK, TLF("saving of unified additional elements in '%'", additionalFileDialog.getFilename()));
4077 // iterate over all demand elementes and change file
4078 for (const auto& additionalElementTag : myNet->getAttributeCarriers()->getAdditionals()) {
4079 for (const auto& additionalElement : additionalElementTag.second) {
4080 additionalElement.second->setAttribute(GNE_ATTR_SAVEFILE, additionalFileDialog.getFilename(), myUndoList);
4081 }
4082 }
4083 // end undoList operation
4084 myUndoList->end();
4085 // save additionals
4086 return onCmdSaveAdditionalElements(sender, sel, ptr);
4087 } else {
4088 return 0;
4089 }
4090}
4091
4092
4093long
4095 // get juPedSim file
4096 const GNEFileDialog juPedSimfileDialog(this, TL("JuPedSim elements file"),
4101 // continue depending of dialog
4102 if (juPedSimfileDialog.getResult() == GNEDialog::Result::ACCEPT) {
4103 try {
4104 // save additionals
4105 const bool savingResult = myNet->saveJuPedSimElements(juPedSimfileDialog.getFilename());
4106 // set focus again in viewNet
4107 myViewNet->setFocus();
4108 // show info
4109 if (savingResult) {
4110 WRITE_MESSAGE(TL("JuPedSim elements saved."));
4111 return 1;
4112 } else {
4113 WRITE_MESSAGE(TL("Saving JuPedSim elements aborted."));
4114 return 0;
4115 }
4116 } catch (IOError& e) {
4117 // open error message box
4118 GNEErrorBasicDialog(this, TL("Saving JuPedSim elements failed"), e.what());
4119 }
4120 }
4121 return 0;
4122}
4123
4124
4125long
4127 // get file
4128 const GNEFileDialog routeFileDialog(this, TL("Route elements file"),
4133 // continue depending of dialog
4134 if (routeFileDialog.getResult() == GNEDialog::Result::ACCEPT) {
4135 // save previous demand element status saving
4136 const auto previouslySaved = myNet->getSavingStatus()->isDemandElementsSaved();
4137 // disable validation for additionals
4138 XMLSubSys::setValidation("never", "auto", "auto");
4139 // get (or create) bucket for this new file
4140 auto bucket = myFileBucketHandler->getBucket(FileBucket::Type::DEMAND, routeFileDialog.getFilename(), true);
4141 // Create generic handler
4143 // begin undoList operation
4144 myUndoList->begin(Supermode::DEMAND, GUIIcon::SUPERMODEDEMAND, TLF("loading demand elements from '%'", bucket->getFilename()));
4145 // Run parser for additionals
4146 if (!handler.parse()) {
4147 // write error
4148 WRITE_ERROR(TLF("Loading of route file '%' failed.", bucket->getFilename()));
4149 } else {
4150 // show info
4151 WRITE_MESSAGE(TLF("Loading of route file '%' successfully.", bucket->getFilename()));
4152 // enable demand elements if there is an error creating element
4153 if (previouslySaved && !handler.isErrorCreatingElement()) {
4155 }
4156 }
4157 // end undoList operation
4158 myUndoList->end();
4159 // restore validation
4160 XMLSubSys::setValidation("auto", "auto", "auto");
4161 // check if clear undoList
4163 myUndoList->clear();
4164 }
4165 update();
4166 }
4167 return 1;
4168}
4169
4170
4171long
4173 // disable validation for additionals
4174 XMLSubSys::setValidation("never", "auto", "auto");
4175 // begin undoList operation
4176 myUndoList->begin(Supermode::DEMAND, GUIIcon::SUPERMODEDEMAND, TL("reloading demand elements"));
4177 // clear demand elements
4179 // reload demand elements stored in options
4180 loadDemandElements("Reloading");
4181 // end undoList operation and update view
4182 myUndoList->end();
4183 // restore validation for demand
4184 XMLSubSys::setValidation("auto", "auto", "auto");
4185 // check if clear undoList
4187 myUndoList->clear();
4188 }
4189 update();
4190 return 1;
4191}
4192
4193
4194long
4195GNEApplicationWindow::onUpdReloadDemandElements(FXObject* sender, FXSelector, void*) {
4196 if (myViewNet == nullptr) {
4197 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
4199 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
4200 } else {
4201 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
4202 }
4203}
4204
4205
4206long
4207GNEApplicationWindow::onCmdSaveDemandElements(FXObject* sender, FXSelector sel, void* ptr) {
4208 const auto savingFileHandler = myFileBucketHandler;
4209 // get option container
4210 auto& neteditOptions = OptionsCont::getOptions();
4211 // check if we're forcing to saving demand elements
4213 neteditOptions.getBool("force-saving") &&
4215 WRITE_MESSAGE(TL("Force save demand elements"));
4216 } else if (myNet->getSavingStatus()->isDemandElementsSaved()) {
4217 // nothing to save
4218 return 1;
4219 }
4220 // check if we have to define a default filename
4222 savingFileHandler->setDefaultFilenameFile(FileBucket::Type::DEMAND, myFileBucketHandler->getConfigFilePrefix(".rou.xml"));
4223 }
4224 // check if we have to open save as dialog
4225 if (!savingFileHandler->isFilenameDefined(FileBucket::Type::DEMAND)) {
4226 // choose file to save
4227 return onCmdSaveDemandElementsAs(sender, sel, ptr);
4228 } else {
4229 // always recompute before saving
4230 myNet->computeNetwork(this);
4231 try {
4232 // save demand elements
4233 const bool savingResult = myNet->saveDemandElements();
4234 // show info
4235 if (savingResult) {
4236 WRITE_MESSAGE(TL("Demand elements saved."));
4237 return 1;
4238 } else {
4239 WRITE_MESSAGE(TL("Saving demand elements aborted."));
4240 return 0;
4241 }
4242 } catch (IOError& e) {
4243 // open error message box
4244 GNEErrorBasicDialog(this, TL("Saving demand elements failed"), e.what());
4245 }
4246 }
4247 return 0;
4248}
4249
4250
4251long
4252GNEApplicationWindow::onCmdSaveDemandElementsAs(FXObject* sender, FXSelector sel, void* ptr) {
4253 // get route file
4254 const GNEFileDialog routeFileDialog(this, TL("Route elements"),
4259 // continue depending of dialog
4260 if (routeFileDialog.getResult() == GNEDialog::Result::ACCEPT) {
4261 // update default name
4263 // save demand elements
4264 return onCmdSaveDemandElements(sender, sel, ptr);
4265 } else {
4266 return 0;
4267 }
4268}
4269
4270
4271long
4272GNEApplicationWindow::onCmdSaveDemandElementsUnified(FXObject* sender, FXSelector sel, void* ptr) {
4273 // get route file
4274 const GNEFileDialog routeFileDialog(this, TL("Route elements file in unified file"),
4279 // continue depending of dialog
4280 if (routeFileDialog.getResult() == GNEDialog::Result::ACCEPT) {
4281 // use the file as default file
4283 // begin undoList operation
4284 myUndoList->begin(Supermode::DEMAND, GUIIcon::SUPERMODEDEMAND, TLF("saving of unified demand elements in '%'.", routeFileDialog.getFilename()));
4285 // iterate over all demand elementes and change file
4286 for (const auto& demandElementTag : myNet->getAttributeCarriers()->getDemandElements()) {
4287 for (const auto& demandElement : demandElementTag.second) {
4288 demandElement.second->setAttribute(GNE_ATTR_SAVEFILE, routeFileDialog.getFilename(), myUndoList);
4289 }
4290 }
4291 // end undoList operation
4292 myUndoList->end();
4293 // save demand elements
4294 return onCmdSaveDemandElements(sender, sel, ptr);
4295 } else {
4296 return 0;
4297 }
4298}
4299
4300
4301long
4302GNEApplicationWindow::onCmdOpenDataElements(FXObject*, FXSelector, void*) {
4303 // get file
4304 const GNEFileDialog dataFileDialog(this, TL("Data elements file"),
4309 // continue depending of dialog
4310 if (dataFileDialog.getResult() == GNEDialog::Result::ACCEPT) {
4311 // save previous demand element status saving
4312 const auto previouslySaved = myNet->getSavingStatus()->isDataElementsSaved();
4313 // get (or create) bucket for this new file
4314 auto bucket = myFileBucketHandler->getBucket(FileBucket::Type::DATA, dataFileDialog.getFilename(), true);
4315 // disable update data
4317 // disable validation for data elements
4318 XMLSubSys::setValidation("never", "auto", "auto");
4319 // Create data handler
4320 GNEDataHandler dataHandler(myNet, bucket, myAllowUndoRedoLoading ? myAllowUndoRedo : false);
4321 // begin undoList operation
4322 myUndoList->begin(Supermode::DATA, GUIIcon::SUPERMODEDATA, TLF("loading data elements from '%'.", bucket->getFilename()));
4323 // Run data parser
4324 if (!dataHandler.parse()) {
4325 // write error
4326 WRITE_ERROR(TLF("Loading of data file '%' failed.", bucket->getFilename()));
4327 } else {
4328 // show info
4329 WRITE_MESSAGE(TLF("Loading of data file '%' successfully.", bucket->getFilename()));
4330 // enable demand elements if there is an error creating element
4331 if (previouslySaved && !dataHandler.isErrorCreatingElement()) {
4333 }
4334 }
4335 // end undoList operation
4336 myUndoList->end();
4337 // enable update data
4339 // restore validation for data
4340 XMLSubSys::setValidation("auto", "auto", "auto");
4341 // check if clear undoList
4343 myUndoList->clear();
4344 }
4345 update();
4346 }
4347 return 1;
4348}
4349
4350
4351long
4353 // disable update data
4355 // disable validation for additionals
4356 XMLSubSys::setValidation("never", "auto", "auto");
4357 // begin undoList operation
4358 myUndoList->begin(Supermode::DATA, GUIIcon::SUPERMODEDATA, TL("reloading data elements"));
4359 // clear data elements
4361 // reload data elements stored in options
4362 loadDataElements("Reloading");
4363 // restore validation for data
4364 XMLSubSys::setValidation("auto", "auto", "auto");
4365 // end undoList operation and update view
4366 myUndoList->end();
4367 // enable update data
4369 // check if clear undoList
4371 myUndoList->clear();
4372 }
4373 update();
4374 return 1;
4375}
4376
4377
4378long
4379GNEApplicationWindow::onUpdReloadDataElements(FXObject* sender, FXSelector, void*) {
4380 if (myViewNet == nullptr) {
4381 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
4383 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
4384 } else {
4385 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
4386 }
4387}
4388
4389
4390long
4391GNEApplicationWindow::onCmdSaveDataElements(FXObject* sender, FXSelector sel, void* ptr) {
4392 const auto savingFileHandler = myFileBucketHandler;
4393 // get option container
4394 auto& neteditOptions = OptionsCont::getOptions();
4395 // check if we're forcing to saving data elements
4397 neteditOptions.getBool("force-saving") &&
4399 WRITE_MESSAGE(TL("Force save data elements"));
4400 } else if (myNet->getSavingStatus()->isDataElementsSaved()) {
4401 // nothing to save
4402 return 1;
4403 }
4404 // check if we have to define a default filename
4406 savingFileHandler->setDefaultFilenameFile(FileBucket::Type::DATA, myFileBucketHandler->getConfigFilePrefix(".dat.xml"));
4407 }
4408 // check if we have to open save as dialog
4409 if (!savingFileHandler->isFilenameDefined(FileBucket::Type::DATA)) {
4410 return onCmdSaveDataElementsAs(sender, sel, ptr);
4411 } else {
4412 try {
4413 // save data elements
4414 const bool savingResult = myNet->saveDataElements();
4415 // show info
4416 if (savingResult) {
4417 WRITE_MESSAGE(TL("Data elements saved."));
4418 return 1;
4419 } else {
4420 WRITE_MESSAGE(TL("Saving demand elements aborted."));
4421 return 0;
4422 }
4423 } catch (IOError& e) {
4424 // open error message box
4425 GNEErrorBasicDialog(this, TL("Saving data elements failed"), e.what());
4426 }
4427 }
4428 return 0;
4429}
4430
4431
4432long
4433GNEApplicationWindow::onCmdSaveDataElementsAs(FXObject* sender, FXSelector sel, void* ptr) {
4434 // get data file
4435 const GNEFileDialog dataFileDialog(this, TL("Data elements file"),
4440 // continue depending of dialog
4441 if (dataFileDialog.getResult() == GNEDialog::Result::ACCEPT) {
4442 // update default name
4444 // save data elements
4445 return onCmdSaveDataElements(sender, sel, ptr);
4446 } else {
4447 return 0;
4448 }
4449}
4450
4451
4452long
4453GNEApplicationWindow::onCmdSaveDataElementsUnified(FXObject* sender, FXSelector sel, void* ptr) {
4454 // get data file
4455 const GNEFileDialog dataFileDialog(this, TL("Data elements file in unified file"),
4460 // continue depending of dialog
4461 if (dataFileDialog.getResult() == GNEDialog::Result::ACCEPT) {
4462 // use the file as default file
4464 // begin undoList operation
4465 myUndoList->begin(Supermode::DATA, GUIIcon::SUPERMODEDATA, TLF("saving of unified data elements in '%'", dataFileDialog.getFilename()));
4466 // iterate over all demand elementes and change file
4467 for (const auto& dataSet : myNet->getAttributeCarriers()->getDataSets()) {
4468 dataSet.second->setAttribute(GNE_ATTR_SAVEFILE, dataFileDialog.getFilename(), myUndoList);
4469 }
4470 // end undoList operation
4471 myUndoList->end();
4472 // save data elements
4473 return onCmdSaveDataElements(sender, sel, ptr);
4474 } else {
4475 return 0;
4476 }
4477}
4478
4479
4480long
4482 // get file
4483 const GNEFileDialog meanDataFileDialog(this, TL("MeanData elements file"),
4488 // continue depending of dialog
4489 if (meanDataFileDialog.getResult() == GNEDialog::Result::ACCEPT) {
4490 // save previous demand element status saving
4491 const auto previouslySaved = myNet->getSavingStatus()->isMeanDatasSaved();
4492 // get (or create) bucket for this new file
4493 auto bucket = myFileBucketHandler->getBucket(FileBucket::Type::MEANDATA, meanDataFileDialog.getFilename(), true);
4494 // disable validation for meanDatas
4495 XMLSubSys::setValidation("never", "auto", "auto");
4496 // Create meanData handler
4497 GNEGeneralHandler generalHandler(myNet, bucket, myAllowUndoRedoLoading ? myAllowUndoRedo : false);
4498 // begin undoList operation
4499 myUndoList->begin(Supermode::DATA, GUIIcon::SUPERMODEDATA, TLF("load meanDatas from '%'", bucket->getFilename()));
4500 // Run parser
4501 if (!generalHandler.parse()) {
4502 // write error
4503 WRITE_ERROR(TLF("Loading of meandata file '%' failed.", bucket->getFilename()));
4504 } else {
4505 // show info
4506 WRITE_MESSAGE(TLF("Loading of meandata file '%' successfully.", bucket->getFilename()));
4507 // enable demand elements if there is an error creating element
4508 if (previouslySaved && !generalHandler.isErrorCreatingElement()) {
4510 }
4511 }
4512 // end undoList operation
4513 myUndoList->end();
4514 // restore validation for meanDatas
4515 XMLSubSys::setValidation("auto", "auto", "auto");
4516 // check if clear undoList
4518 myUndoList->clear();
4519 }
4520 update();
4521 }
4522 return 1;
4523}
4524
4525
4526long
4528 // disable validation for meanDatas
4529 XMLSubSys::setValidation("never", "auto", "auto");
4530 // begin undoList operation
4532 // clear meanDatas
4534 // reload meanData elements stored in options
4535 loadMeanDataElements("Reloading");
4536 // end undoList operation and update view
4537 myUndoList->end();
4538 // restore validation for meanDatas
4539 XMLSubSys::setValidation("auto", "auto", "auto");
4540 // check if clear undoList
4542 myUndoList->clear();
4543 }
4544 update();
4545 return 1;
4546}
4547
4548
4549long
4550GNEApplicationWindow::onUpdReloadMeanDataElements(FXObject* sender, FXSelector, void*) {
4551 if (myViewNet == nullptr) {
4552 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
4554 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
4555 } else {
4556 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
4557 }
4558}
4559
4560
4561long
4562GNEApplicationWindow::onCmdSaveMeanDataElements(FXObject* sender, FXSelector sel, void* ptr) {
4563 const auto savingFileHandler = myFileBucketHandler;
4564 // get option container
4565 auto& neteditOptions = OptionsCont::getOptions();
4566 // check if we're forcing to saving meandata elements
4568 neteditOptions.getBool("force-saving") &&
4570 WRITE_MESSAGE(TL("Force save meandata elements"));
4571 } else if (myNet->getSavingStatus()->isMeanDatasSaved()) {
4572 // nothing to save
4573 return 1;
4574 }
4575 // check if we have to define a default filename
4577 savingFileHandler->setDefaultFilenameFile(FileBucket::Type::MEANDATA, myFileBucketHandler->getConfigFilePrefix(".dat.add.xml"));
4578 }
4579 // check if we have to open save as dialog
4580 if (!savingFileHandler->isFilenameDefined(FileBucket::Type::MEANDATA)) {
4581 return onCmdSaveMeanDataElementsAs(sender, sel, ptr);
4582 } else {
4583 try {
4584 // compute before saving
4585 myNet->computeNetwork(this);
4586 // save demand elements
4587 const bool savingResult = myNet->saveMeanDatas();
4588 // show info
4589 if (savingResult) {
4590 WRITE_MESSAGE(TL("MeanDatas elements saved"));
4591 return 1;
4592 } else {
4593 WRITE_MESSAGE(TL("Saving MeanData elements aborted"));
4594 return 0;
4595 }
4596 } catch (IOError& e) {
4597 // open error message box
4598 GNEErrorBasicDialog(this, TL("Saving demand elements failed!"), e.what());
4599 }
4600 }
4601 return 0;
4602}
4603
4604
4605long
4606GNEApplicationWindow::onCmdSaveMeanDataElementsAs(FXObject* sender, FXSelector sel, void* ptr) {
4607 // get meanData file
4608 const GNEFileDialog meanDataFileDialog(this, TL("MeanData elements"),
4613 // continue depending of dialog
4614 if (meanDataFileDialog.getResult() == GNEDialog::Result::ACCEPT) {
4615 // update default name
4617 // save meanDatas
4618 return onCmdSaveMeanDataElements(sender, sel, ptr);
4619 } else {
4620 return 0;
4621 }
4622}
4623
4624
4625long
4626GNEApplicationWindow::onCmdSaveMeanDataElementsUnified(FXObject* sender, FXSelector sel, void* ptr) {
4627 // get meanData file
4628 const GNEFileDialog meanDataFileDialog(this, TL("MeanData elements file in unified file"),
4633 // continue depending of dialog
4634 if (meanDataFileDialog.getResult() == GNEDialog::Result::ACCEPT) {
4635 // use the file as default file
4637 // begin undoList operation
4638 myUndoList->begin(Supermode::DATA, GUIIcon::MODEMEANDATA, TLF("saving of unified mean data elements in '%'", meanDataFileDialog.getFilename()));
4639 // iterate over all demand elementes and change file
4640 for (const auto& meanDataTag : myNet->getAttributeCarriers()->getMeanDatas()) {
4641 for (const auto& meanData : meanDataTag.second) {
4642 meanData.second->setAttribute(GNE_ATTR_SAVEFILE, meanDataFileDialog.getFilename(), myUndoList);
4643 }
4644 }
4645 // end undoList operation
4646 myUndoList->end();
4647 // save meanDatas
4648 return onCmdSaveMeanDataElements(sender, sel, ptr);
4649 } else {
4650 return 0;
4651 }
4652}
4653
4654
4655bool
4656GNEApplicationWindow::askSaveElements(FXObject* sender, FXSelector sel, void* ptr) {
4657 if (myNet) {
4659 const auto saveNetwork = myNet->getSavingStatus()->askSaveNetwork(commonResult);
4660 const auto saveAdditionalElements = myNet->getSavingStatus()->askSaveAdditionalElements(commonResult);
4661 const auto saveDemandElements = myNet->getSavingStatus()->askSaveDemandElements(commonResult);
4662 const auto saveDataElements = myNet->getSavingStatus()->askSaveDataElements(commonResult);
4663 const auto saveMeanDataElements = myNet->getSavingStatus()->askSaveMeanDataElements(commonResult);
4664 // first check if abort saving
4665 if (commonResult == GNEDialog::Result::ABORT) {
4666 return false;
4667 }
4668 // save every type of file
4669 if ((saveNetwork == GNEDialog::Result::ACCEPT) &&
4670 (onCmdSaveNetwork(sender, sel, ptr) != 1)) {
4671 return false;
4672 }
4673 if ((saveAdditionalElements == GNEDialog::Result::ACCEPT) &&
4674 (onCmdSaveAdditionalElements(sender, sel, ptr) != 1)) {
4675 return false;
4676 }
4677 if ((saveDemandElements == GNEDialog::Result::ACCEPT) &&
4678 (onCmdSaveDemandElements(sender, sel, ptr) != 1)) {
4679 return false;
4680 }
4681 if ((saveDataElements == GNEDialog::Result::ACCEPT) &&
4682 (onCmdSaveDataElements(sender, sel, ptr) != 1)) {
4683 return false;
4684 }
4685 if ((saveMeanDataElements == GNEDialog::Result::ACCEPT) &&
4686 (onCmdSaveMeanDataElements(sender, sel, ptr) != 1)) {
4687 return false;
4688 }
4689 // restore focus in viewNet
4690 myViewNet->setFocus();
4691 // clear undo list
4692 clearUndoList();
4693 // all saved, then continue
4694 return true;
4695 } else {
4696 // nothing to do, then continue
4697 return true;
4698 }
4699}
4700
4701
4702void
4704 // check that view exists
4705 if (myViewNet) {
4707 }
4708 // update require recomputing
4710}
4711
4712
4713void
4715 // remove lock hotkeys
4717 // check supermode
4718 if (supermode == Supermode::NETWORK) {
4719 // menu commands
4723 // lock
4727 // processing
4732 } else if (supermode == Supermode::DEMAND) {
4733 // menu commands
4737 // lock
4741 // processing
4746 } else if (supermode == Supermode::DATA) {
4747 // menu commands
4751 // lock
4755 // processing
4760 } else {
4761 // menu commands
4766 // lock
4770 // processing
4774 }
4775 // continue depending of view
4776 if (myViewNet) {
4780 } else if (myViewNet->getEditModes().isJuPedSimView()) {
4783 }
4784 }
4785}
4786
4787
4788bool
4792
4793
4794void
4798
4799
4800void
4802 myUndoRedoListEnabled = reason;
4803}
4804
4805
4806const std::string&
4810
4811
4812void
4814 if (myViewNet) {
4815 // destroy Popup (to avoid crashes)
4817 }
4818 // clear undo list and return true to continue with closing/reload
4819 myUndoList->clear();
4820}
4821
4822
4827
4828
4833
4834
4839
4840
4845
4846
4851
4852
4857
4858
4863
4864
4865void
4867 // get netedit option container
4868 auto& neteditOptions = OptionsCont::getOptions();
4869 // get additional files (don't use reference because it's modified during loading)
4870 const StringVector additionalFiles = neteditOptions.getStringVector("additional-files");
4871 // check if we have additionals to load
4872 if (myNet && (additionalFiles.size() > 0)) {
4873 // disable validation for additionals
4874 XMLSubSys::setValidation("never", "auto", "auto");
4875 // begin undolist
4876 myUndoList->begin(Supermode::NETWORK, GUIIcon::SUPERMODENETWORK, TLF("% additional elements from '%'", operation, toString(additionalFiles)));
4877 // use this flag for mark all elements as saved after loading, if it was sucessfully
4878 bool setSaved = additionalFiles.size() == 1;
4879 // iterate over every additional file
4880 for (const auto& file : additionalFiles) {
4881 // check if ignore missing inputs
4882 if (FileHelpers::isReadable(file) || !neteditOptions.getBool("ignore-missing-inputs")) {
4883 WRITE_MESSAGE(TLF("% additionals from '%'.", operation, file));
4884 // get (or create) bucket for this new file
4886 // declare general handler
4887 GNEGeneralHandler generalHandler(myNet, bucket, myAllowUndoRedoLoading ? myAllowUndoRedo : false);
4888 // check if force overwritte
4889 if (operation == "reloading") {
4890 generalHandler.forceOverwriteElements();
4891 }
4892 // Run parser
4893 if (!generalHandler.parse()) {
4894 WRITE_ERROR(TLF("% of '%' failed.", operation, file));
4895 }
4896 setSaved &= !generalHandler.isErrorCreatingElement();
4897 }
4898 }
4899 // end undo list
4900 myUndoList->end();
4901 // disable validation for additionals
4902 XMLSubSys::setValidation("auto", "auto", "auto");
4903 if (setSaved) {
4905 }
4906 // check if clear undoList
4908 myUndoList->clear();
4909 }
4910 }
4911}
4912
4913
4914void
4915GNEApplicationWindow::loadDemandElements(const std::string operation) {
4916 // get netedit option container
4917 auto& neteditOptions = OptionsCont::getOptions();
4918 // get demand files (don't use reference because it's modified during loading)
4919 const StringVector demandFiles = neteditOptions.getStringVector("route-files");
4920 // check if we have demand files to load
4921 if (myNet && (demandFiles.size() > 0)) {
4922 // disable validation for additionals
4923 XMLSubSys::setValidation("never", "auto", "auto");
4924 // begin undolist
4925 myUndoList->begin(Supermode::DEMAND, GUIIcon::SUPERMODEDEMAND, TLF("% demand elements from '%'", operation, toString(demandFiles)));
4926 // use this flag for mark all elements as saved after loading, if it was sucessfully
4927 bool setSaved = demandFiles.size() == 1;
4928 // iterate over every demand file
4929 for (const auto& file : demandFiles) {
4930 // check if ignore missing inputs
4931 if (FileHelpers::isReadable(file) || !neteditOptions.getBool("ignore-missing-inputs")) {
4932 WRITE_MESSAGE(TLF("% demand elements from '%'.", operation, file));
4933 // get (or create) bucket for this new file
4934 auto bucket = myFileBucketHandler->getBucket(FileBucket::Type::DEMAND, file, true);
4935 // declare general handler
4936 GNEGeneralHandler generalHandler(myNet, bucket, myAllowUndoRedoLoading ? myAllowUndoRedo : false);
4937 // check if force overwritte
4938 if (operation == "reloading") {
4939 generalHandler.forceOverwriteElements();
4940 }
4941 // Run parser
4942 if (!generalHandler.parse()) {
4943 WRITE_ERROR(TLF("% of '%' failed.", operation, file));
4944 }
4945 setSaved &= !generalHandler.isErrorCreatingElement();
4946 }
4947 }
4948 // end undo list
4949 myUndoList->end();
4950 // disable validation for additionals
4951 XMLSubSys::setValidation("auto", "auto", "auto");
4952 if (setSaved) {
4954 }
4955 // check if clear undoList
4957 myUndoList->clear();
4958 }
4959 }
4960}
4961
4962
4963void
4964GNEApplicationWindow::loadDataElements(const std::string operation) {
4965 // get option container
4966 auto& neteditOptions = OptionsCont::getOptions();
4967 // get data files (don't use reference because it's modified during loading)
4968 const StringVector dataFiles = neteditOptions.getStringVector("data-files");
4969 if (myNet && (dataFiles.size() > 0)) {
4970 // disable validation for additionals
4971 XMLSubSys::setValidation("never", "auto", "auto");
4972 // begin undolist
4973 myUndoList->begin(Supermode::DEMAND, GUIIcon::SUPERMODEDEMAND, TLF("% data elements from '%'", operation, toString(dataFiles)));
4974 // use this flag for mark all elements as saved after loading, if it was sucessfully
4975 bool setSaved = dataFiles.size() == 1;
4976 // iterate over every data file
4977 for (const auto& file : dataFiles) {
4978 // check if ignore missing inputs
4979 if (FileHelpers::isReadable(file) || !neteditOptions.getBool("ignore-missing-inputs")) {
4980 WRITE_MESSAGE(TLF("% data elements from '%'.", operation, file));
4981 // get (or create) bucket for this new file
4982 auto bucket = myFileBucketHandler->getBucket(FileBucket::Type::DATA, file, true);
4983 // declare general handler
4984 GNEDataHandler generalHandler(myNet, bucket, myAllowUndoRedoLoading ? myAllowUndoRedo : false);
4985 // check if force overwritte
4986 if (operation == "reloading") {
4987 generalHandler.forceOverwriteElements();
4988 }
4989 // Run parser
4990 if (!generalHandler.parse()) {
4991 WRITE_ERROR(TLF("% of % failed.", operation, file));
4992 }
4993 setSaved &= !generalHandler.isErrorCreatingElement();
4994 }
4995 }
4996 // end undo list
4997 myUndoList->end();
4998 // disable validation for additionals
4999 XMLSubSys::setValidation("auto", "auto", "auto");
5000 if (setSaved) {
5002 }
5003 // check if clear undoList
5005 myUndoList->clear();
5006 }
5007 }
5008}
5009
5010
5011void
5013 // get option container
5014 auto& neteditOptions = OptionsCont::getOptions();
5015 // get meanData files (don't use reference because it's modified during loading)
5016 const StringVector meanDataFiles = neteditOptions.getStringVector("meandata-files");
5017 if (myNet && (meanDataFiles.size() > 0)) {
5018 // disable validation for additionals
5019 XMLSubSys::setValidation("never", "auto", "auto");
5020 // begin undolist
5021 myUndoList->begin(Supermode::DEMAND, GUIIcon::SUPERMODEDEMAND, TLF("% meanData elements from '%'", operation, toString(meanDataFiles)));
5022 // use this flag for mark all elements as saved after loading, if it was sucessfully
5023 bool setSaved = meanDataFiles.size() == 1;
5024 // iterate over every meanData file
5025 for (const auto& file : meanDataFiles) {
5026 // check if ignore missing inputs
5027 if (FileHelpers::isReadable(file) || !neteditOptions.getBool("ignore-missing-inputs")) {
5028 WRITE_MESSAGE(TLF("% meanData elements from '%'.", operation, file));
5029 // get (or create) bucket for this new file
5030 auto bucket = myFileBucketHandler->getBucket(FileBucket::Type::MEANDATA, file, true);
5031 // declare general handler
5032 GNEGeneralHandler generalHandler(myNet, bucket, myAllowUndoRedoLoading ? myAllowUndoRedo : false);
5033 // check if force overwritte
5034 if (operation == "reloading") {
5035 generalHandler.forceOverwriteElements();
5036 }
5037 // Run parser
5038 if (!generalHandler.parse()) {
5039 WRITE_ERROR(TLF("% of % failed.", operation, file));
5040 }
5041 setSaved &= !generalHandler.isErrorCreatingElement();
5042 }
5043 }
5044 // end undo list
5045 myUndoList->end();
5046 // disable validation for additionals
5047 XMLSubSys::setValidation("auto", "auto", "auto");
5048 if (setSaved) {
5050 }
5051 // check if clear undoList
5053 myUndoList->clear();
5054 }
5055 }
5056}
5057
5058
5059void
5060GNEApplicationWindow::loadTrafficLights(const std::string operation) {
5061 // get TLS file
5063 if (tlsFile.size() > 0) {
5064 // show info
5065 WRITE_MESSAGE(TLF("% TLS programs from '%'.", operation, tlsFile));
5066 myUndoList->begin(Supermode::NETWORK, GUIIcon::MODETLS, TLF("% TLS programs from '%'.", operation, tlsFile));
5067 myNet->computeNetwork(this);
5068 // parse TLS programs
5069 if (myNet->getViewParent()->getTLSEditorFrame()->parseTLSPrograms(tlsFile) == false) {
5070 // Abort undo/redo
5072 } else {
5073 // commit undo/redo operation
5074 myUndoList->end();
5075 update();
5076 }
5077 // requiere save network
5079 // if defined, require save netedit config
5082 }
5083 }
5084}
5085
5086
5087void
5088GNEApplicationWindow::loadEdgeTypes(const std::string operation) {
5089 // get edgeType file
5091 if (edgeTypeFile.size() > 0) {
5092 // declare type container
5093 NBTypeCont typeContainerAux;
5094 // declare type handler
5095 NIXMLTypesHandler handler(typeContainerAux);
5096 // load edge types
5097 NITypeLoader::load(handler, {edgeTypeFile}, toString(SUMO_TAG_TYPES));
5098 // now create GNETypes based on typeContainerAux
5099 WRITE_MESSAGE(TLF("% edge types from '%'.", operation, edgeTypeFile));
5100 myUndoList->begin(Supermode::NETWORK, GUIIcon::MODETLS, TLF("% edge types from '%'.", operation, edgeTypeFile));
5101 // iterate over typeContainerAux
5102 for (const auto& auxEdgeType : typeContainerAux) {
5103 // create new edge type
5104 GNEEdgeType* edgeType = new GNEEdgeType(myNet, auxEdgeType.first, auxEdgeType.second);
5105 // add lane types
5106 for (const auto& laneType : auxEdgeType.second->laneTypeDefinitions) {
5107 edgeType->addLaneType(new GNELaneType(edgeType, laneType));
5108 }
5109 // add it using undoList
5110 myViewNet->getUndoList()->add(new GNEChange_EdgeType(edgeType, true), true);
5111
5112 }
5113 // end undo list
5115 // refresh edge type selector
5117 // requiere save network
5119 // if defined, require save netedit config
5122 }
5123 }
5124}
5125
5126
5131
5132
5133bool
5135 if (myInternalTest == nullptr) {
5136 return true;
5137 } else if (obj == myInternalTest) {
5138 return true;
5139 } else {
5140 return false;
5141 }
5142}
5143
5144// ---------------------------------------------------------------------------
5145// GNEApplicationWindow - protected methods
5146// ---------------------------------------------------------------------------
5147#ifdef _MSC_VER
5148#pragma warning(push)
5149#pragma warning(disable: 4355) // mask warning about "this" in initializers
5150#endif
5152 myToolbarsGrip(this),
5153 myMenuBarFile(this),
5154 myFileMenuCommands(this),
5155 myModesMenuCommands(this),
5156 myEditMenuCommands(this),
5157 myLockMenuCommands(this),
5158 myProcessingMenuCommands(this),
5159 myLocateMenuCommands(this),
5160 myToolsMenuCommands(this),
5161 myWindowsMenuCommands(this),
5162 myHelpMenuCommands(this),
5163 mySupermodeCommands(this) {
5164}
5165#ifdef _MSC_VER
5166#pragma warning(pop)
5167#endif
5168
5169
5170long
5171GNEApplicationWindow::onKeyPress(FXObject* o, FXSelector sel, void* eventData) {
5172 const long handled = FXMainWindow::onKeyPress(o, sel, eventData);
5173 if (handled == 0 && myMDIClient->numChildren() > 0) {
5174 GNEViewParent* w = dynamic_cast<GNEViewParent*>(myMDIClient->getActiveChild());
5175 if (w != nullptr) {
5176 w->onKeyPress(nullptr, sel, eventData);
5177 }
5178 }
5179 return 0;
5180}
5181
5182
5183long
5184GNEApplicationWindow::onKeyRelease(FXObject* o, FXSelector sel, void* eventData) {
5185 const long handled = FXMainWindow::onKeyRelease(o, sel, eventData);
5186 if (handled == 0 && myMDIClient->numChildren() > 0) {
5187 GNEViewParent* w = dynamic_cast<GNEViewParent*>(myMDIClient->getActiveChild());
5188 if (w != nullptr) {
5189 w->onKeyRelease(nullptr, sel, eventData);
5190 }
5191 }
5192 return 0;
5193}
5194
5195
5196/****************************************************************************/
FXDEFMAP(GNEApplicationWindow) GNEApplicationWindowMap[]
@ DATA_SELECT
mode for selecting data elements
@ DATA_INSPECT
mode for inspecting data elements
@ DATA_DELETE
mode for deleting data elements
Supermode
@brie enum for supermodes
@ NETWORK
Network mode (Edges, junctions, etc..)
@ DATA
Data mode (edgeData, LaneData etc..)
@ DEMAND
Demand mode (Routes, Vehicles etc..)
@ NETWORK_DELETE
mode for deleting network elements
@ NETWORK_MOVE
mode for moving network elements
@ NETWORK_SELECT
mode for selecting network elements
@ NETWORK_INSPECT
mode for inspecting network elements
@ NETWORK_CONNECT
mode for connecting lanes
@ DEMAND_INSPECT
mode for inspecting demand elements
@ DEMAND_DELETE
mode for deleting demand elements
@ DEMAND_SELECT
mode for selecting demand elements
@ DEMAND_MOVE
mode for moving demand elements
long long int SUMOTime
Definition GUI.h:36
@ MID_GNE_NETWORKVIEWOPTIONS_AUTOOPPOSITEEDGES
automatically create opposite edge
Definition GUIAppEnum.h:857
@ MID_GNE_NETGENERATE
netgenerate dialog
Definition GUIAppEnum.h:771
@ MID_HOTKEY_SHIFT_F10_SUMOOPTIONSMENU
open SUMO options menu (used in netedit)
Definition GUIAppEnum.h:274
@ MID_GNE_TOOLBARFILE_SAVEDEMANDELEMENTS_AS
save demand elements as
Definition GUIAppEnum.h:739
@ MID_HOTKEY_SHIFT_F7_ADJUST_PERSON_PLANS
Adjust person plans (start und end positions, arrival positions, etc.)
Definition GUIAppEnum.h:272
@ MID_GNE_LOCK_POLYGON
lock polygons
Definition GUIAppEnum.h:883
@ MID_HOTKEY_CTRL_Q_CLOSE
Main window closes.
Definition GUIAppEnum.h:115
@ MID_HOTKEY_SHIFT_F5_COMPUTEJUNCTIONS_VOLATILE
compute junctions with volatile options
Definition GUIAppEnum.h:270
@ MID_HOTKEY_CTRL_SHIFT_B_SAVEDATAELEMENTS
save Data Elements
Definition GUIAppEnum.h:204
@ MID_HOTKEY_F3_SUPERMODE_DEMAND
select demand supermode in netedit
Definition GUIAppEnum.h:236
@ MID_GNE_UNDOLISTDIALOG
open undo list dialog
@ MID_GNE_DEMANDVIEWOPTIONS_SHOWALLPERSONPLANS
show all person plans
Definition GUIAppEnum.h:941
@ MID_GNE_UNLOCK_ALLELEMENTS
unlock all element
Definition GUIAppEnum.h:919
@ MID_GNE_NETGENERATEOPTIONS
netgenerate options
Definition GUIAppEnum.h:773
@ MID_HOTKEY_SHIFT_S_LOCATESTOP
Locate stop - button.
Definition GUIAppEnum.h:188
@ MID_GNE_LOCK_TRANSHIP
lock tranships
Definition GUIAppEnum.h:907
@ MID_HOTKEY_CTRL_T_OPENNETEDIT_OPENSUMO
Open current SUMO simulation/network in netedit, or current netedit simulation/network in SUMO.
Definition GUIAppEnum.h:123
@ MID_GNE_DATAVIEWOPTIONS_TAZRELDRAWING
toggle TAZRel drawing
Definition GUIAppEnum.h:965
@ MID_GNE_TOGGLE_COMPUTE_NETWORK_DATA
enable/disable computing after switchin between supermodes
Definition GUIAppEnum.h:805
@ MID_GNE_TOOLBARFILE_SAVEADDITIONALELEMENTS_UNIFIED
save additionals unified
Definition GUIAppEnum.h:725
@ MID_GNE_LOCK_WALK
lock walks
Definition GUIAppEnum.h:899
@ MID_TOOLBAREDIT_LOADADDITIONALS
load additionals in sumo-gui/netedit after press ctrl+T
Definition GUIAppEnum.h:683
@ MID_HOTKEY_U_MODE_DECAL_TYPEDISTRIBUTION
hotkey for mode decal AND type distribution
Definition GUIAppEnum.h:69
@ MID_GNE_NETWORKVIEWOPTIONS_DRAWSPREADVEHICLES
Draw vehicles in begin position or spread in lane.
Definition GUIAppEnum.h:831
@ MID_GNE_LOCK_STOP
lock stops
Definition GUIAppEnum.h:909
@ MID_HOTKEY_CTRL_Y_REDO
Undo.
Definition GUIAppEnum.h:133
@ MID_GNE_RUNNETGENERATE
run netgenerate tool
Definition GUIAppEnum.h:783
@ MID_HOTKEY_CTRL_SHIFT_H_SAVEEDGETYPES
save Edge Types
Definition GUIAppEnum.h:212
@ MID_GNE_OPENPYTHONTOOLDIALOG
call tool
Definition GUIAppEnum.h:765
@ MID_GNE_NETWORKVIEWOPTIONS_MOVEELEVATION
move elevation instead of x,y
Definition GUIAppEnum.h:853
@ MID_HOTKEY_ALT_9_TOGGLEEDITOPTION
toggle edit option
Definition GUIAppEnum.h:161
@ MID_GNE_LOCK_WIRE
lock wires
Definition GUIAppEnum.h:879
@ MID_GNE_TOOLBARFILE_RELOAD_EDGETYPES
reload edge types
Definition GUIAppEnum.h:737
@ MID_GNE_NETWORKVIEWOPTIONS_HIDECONNECTIONS
hide connections
Definition GUIAppEnum.h:839
@ MID_GNE_NETWORKVIEWOPTIONS_SHOWCONNECTIONS
show connections
Definition GUIAppEnum.h:837
@ MID_HOTKEY_ALT_5_TOGGLEEDITOPTION
toggle edit option
Definition GUIAppEnum.h:153
@ MID_GNE_DATAVIEWOPTIONS_TAZRELONLYTO
toggle draw TAZRel only to
Definition GUIAppEnum.h:971
@ MID_HOTKEY_CTRL_W_CLOSESIMULATION
Close simulation - ID.
Definition GUIAppEnum.h:129
@ MID_HOTKEY_ALT_2_TOGGLEEDITOPTION
toggle edit option
Definition GUIAppEnum.h:147
@ MID_GNE_LOCK_ALLELEMENTS
lock all element
Definition GUIAppEnum.h:917
@ MID_HOTKEY_F7_JOIN_SELECTEDJUNCTIONS_ROUTES
join selected junctions in network mode and normalice demand element ids in demand mode
Definition GUIAppEnum.h:244
@ MID_HOTKEY_CTRL_D_SINGLESIMULATIONSTEP_OPENDEMANDELEMENTS
Perform a single simulation step in SUMO and open Demand Elements in netedit.
Definition GUIAppEnum.h:89
@ MID_HOTKEY_F5_COMPUTE_NETWORK_DEMAND
compute Network in network mode and Demand elements in demand mode
Definition GUIAppEnum.h:240
@ MID_GNE_DATAVIEWOPTIONS_TOGGLEDRAWJUNCTIONSHAPE
toggle draw junction shape
Definition GUIAppEnum.h:957
@ MID_HOTKEY_CTRL_O_OPENSIMULATION_OPENNETWORK
Open simulation in SUMO and open network in netedit.
Definition GUIAppEnum.h:111
@ MID_GNE_LOCK_MENUTITLE
selector for LockMenuTitle
@ MID_GNE_NETWORKVIEWOPTIONS_SHOWTAZELEMENTS
show TAZ elements
Definition GUIAppEnum.h:843
@ MID_GNE_DEMANDVIEWOPTIONS_LOCKPERSON
lock person
Definition GUIAppEnum.h:943
@ MID_GNE_LOCK_JPS_WALKABLEAREA
lock walkableAreas
Definition GUIAppEnum.h:887
@ MID_HOTKEY_Z_MODE_TAZ_TAZREL
hotkey for mode editing TAZ and TAZRel
Definition GUIAppEnum.h:75
@ MID_HOTKEY_F9_EDIT_VIEWSCHEME
open edit scheme menu
Definition GUIAppEnum.h:248
@ MID_GNE_DEMANDVIEWOPTIONS_TOGGLEDRAWJUNCTIONSHAPE
toggle draw junction shape
Definition GUIAppEnum.h:931
@ MID_HOTKEY_SHIFT_ESC_CLEARSELECTION
clear selection
Definition GUIAppEnum.h:278
@ MID_GNE_LOCK_SELECTEDELEMENTS
lock selected element
Definition GUIAppEnum.h:921
@ MID_HOTKEY_CTRL_J_TOGGLEDRAWJUNCTIONSHAPE
toggle draw junction shape
Definition GUIAppEnum.h:101
@ MID_GNE_TOOLBARFILE_SAVESUMOCONFIG_AS
save SUMOConfig as
Definition GUIAppEnum.h:719
@ MID_GNE_TOOLBARFILE_RELOAD_TLSPROGRAMS
reload TLS Programs
Definition GUIAppEnum.h:733
@ MID_HOTKEY_DEL
hot key delete selections or elements
Definition GUIAppEnum.h:288
@ MID_HOTKEY_A_MODE_STARTSIMULATION_ADDITIONALS_STOPS
hotkey for start simulation in SUMO and set editing mode additionals AND stops in netedit
Definition GUIAppEnum.h:43
@ MID_GNE_TOOLBARFILE_OPENMEANDATAELEMENTS
open meanData file
Definition GUIAppEnum.h:751
@ MID_LANGUAGE_PT
change language to portuguese
@ MID_LANGUAGE_TR
change language to turkish
@ MID_CHANGELOG
changelog button
Definition GUIAppEnum.h:657
@ MID_GNE_TOOLBARFILE_OPENFOREIGN
open foreign network
Definition GUIAppEnum.h:709
@ MID_GNE_TOGGLE_TIMEFORMAT
switch time format
Definition GUIAppEnum.h:811
@ MID_GNE_TOOLBARFILE_RELOAD_NETEDITCONFIG
reload neteditConfig
Definition GUIAppEnum.h:713
@ MID_HOTKEY_CTRL_B_EDITBREAKPOINT_OPENDATAELEMENTS
Edit simulation breakpoints in SUMO and open Data Elements in netedit.
Definition GUIAppEnum.h:85
@ MID_TOOLBAREDIT_LOADDEMAND
load demand in sumo-gui/netedit after press ctrl+T
Definition GUIAppEnum.h:685
@ MID_GNE_DEMANDVIEWOPTIONS_SHOWGRID
show grid
Definition GUIAppEnum.h:929
@ MID_HOTKEY_ALT_3_TOGGLEEDITOPTION
toggle edit option
Definition GUIAppEnum.h:149
@ MID_HOTKEY_F1_ONLINEDOCUMENTATION
open online documentation
Definition GUIAppEnum.h:232
@ MID_HOTKEY_CTRL_SHIFT_D_SAVEDEMANDELEMENTS
Save Demand Elements.
Definition GUIAppEnum.h:208
@ MID_GNE_POSTPROCESSINGPYTHONTOOL
call tool for post processing
Definition GUIAppEnum.h:769
@ MID_HOTKEY_CTRL_R_RELOAD
Reload the previously loaded simulation.
Definition GUIAppEnum.h:119
@ MID_HOTKEY_CTRL_S_STOPSIMULATION_SAVENETWORK
Stop the simulation in SUMO and save network in netedit.
Definition GUIAppEnum.h:117
@ MID_HOTKEY_D_MODE_SINGLESIMULATIONSTEP_DELETE
hotkey for perform a single simulation step in SUMO and set delete mode in netedit
Definition GUIAppEnum.h:49
@ MID_GNE_NETWORKVIEWOPTIONS_CHAINEDGES
create edges in chain mode
Definition GUIAppEnum.h:855
@ MID_HOTKEY_ESC
hot key <ESC> abort current edit operation
Definition GUIAppEnum.h:286
@ MID_HOTKEY_F10_OPTIONSMENU
open options menu
Definition GUIAppEnum.h:250
@ MID_HOTKEY_F11_FRONTELEMENT
set/clear front element
Definition GUIAppEnum.h:252
@ MID_HOTKEY_F8_CLEANINVALID_CROSSINGS_DEMANDELEMENTS
clean invalid crossings in network mode and demand elements in demand mode
Definition GUIAppEnum.h:246
@ MID_GNE_DATAVIEWOPTIONS_SHOWDEMANDELEMENTS
show demand elements
Definition GUIAppEnum.h:963
@ MID_GNE_TOOLBARFILE_RELOAD_MEANDATAELEMENTS
reload meanDatas
Definition GUIAppEnum.h:757
@ MID_GNE_TOOLBARFILE_SAVEMEANDATAELEMENTS_UNIFIED
save meanDatas unified
Definition GUIAppEnum.h:755
@ MID_GNE_LOCK_WALKINGAREA
lock walkingareas
Definition GUIAppEnum.h:875
@ MID_HOTKEY_CTRL_A_STARTSIMULATION_OPENADDITIONALELEMENTS
Start the simulation in SUMO and open Additionals Elements in netedit.
Definition GUIAppEnum.h:83
@ MID_HOTKEY_C_MODE_CONNECT_CONTAINER
hotkey for mode connecting lanes AND container
Definition GUIAppEnum.h:45
@ MID_HOTKEY_H_MODE_PROHIBITION_CONTAINERPLAN
hotkey for mode prohibition AND container plan
Definition GUIAppEnum.h:53
@ MID_HOTKEY_SHIFT_O_LOCATEPOI
Locate poi - button.
Definition GUIAppEnum.h:182
@ MID_HOTKEY_W_MODE_WIRE_ROUTEDISTRIBUTION
hotkey for mode editing overhead wires AND route distributions
Definition GUIAppEnum.h:73
@ MID_HOTKEY_T_MODE_TLS_TYPE
hotkey for mode editing TLS AND Vehicle Types
Definition GUIAppEnum.h:67
@ MID_GNE_DEMANDVIEWOPTIONS_HIDESHAPES
hide shapes
Definition GUIAppEnum.h:937
@ MID_GNE_TOGGLE_UNDOREDO
enable/disable undo-redo
Definition GUIAppEnum.h:807
@ MID_LANGUAGE_ZHT
change language to chinese (traditional)
@ MID_LANGUAGE_ES
change language to spanish
@ MID_GNE_LOCK_JPS_OBSTACLE
lock obstacles
Definition GUIAppEnum.h:889
@ MID_HOTKEY_SHIFT_A_LOCATEADDITIONAL
Locate additional structure - button.
Definition GUIAppEnum.h:172
@ MID_HOTKEY_ALT_4_TOGGLEEDITOPTION
toggle edit option
Definition GUIAppEnum.h:151
@ MID_GNE_TOOLBARFILE_SAVETLSPROGRAMS_AS
save TLS Programs as
Definition GUIAppEnum.h:731
@ MID_GNE_DATAVIEWOPTIONS_SHOWADDITIONALS
show additionals
Definition GUIAppEnum.h:959
@ MID_HOTKEY_SHIFT_R_LOCATEROUTE
Locate route - button.
Definition GUIAppEnum.h:186
@ MID_GNE_RUNPYTHONTOOL
run python
Definition GUIAppEnum.h:767
@ MID_GNE_NETWORKVIEWOPTIONS_SHOWBUBBLES
show junctions as bubbles
Definition GUIAppEnum.h:851
@ MID_HOTKEY_SHIFT_W_LOCATEWALKINGAREA
Locate edge - button.
Definition GUIAppEnum.h:194
@ MID_GNE_TOOLBARFILE_RELOAD_DEMANDELEMENTS
reload demand elements
Definition GUIAppEnum.h:743
@ MID_GNE_NETWORKVIEWOPTIONS_EXTENDSELECTION
extend selection
Definition GUIAppEnum.h:845
@ MID_HOTKEY_CTRL_I_EDITVIEWPORT
Open viewport editor.
Definition GUIAppEnum.h:99
@ MID_RECENTFILE
Loads a file previously loaded.
Definition GUIAppEnum.h:320
@ MID_HOTKEY_S_MODE_STOPSIMULATION_SELECT
hotkey for stop simulation in SUMO and set select mode in netedit
Definition GUIAppEnum.h:63
@ MID_GNE_NETWORKVIEWOPTIONS_SHOWSUBADDITIONALS
show sub-additionals
Definition GUIAppEnum.h:841
@ MID_GNE_LOCK_VEHICLE
lock vehicles
Definition GUIAppEnum.h:893
@ MID_HOTKEY_SHIFT_C_LOCATECONTAINER
Locate container - button.
Definition GUIAppEnum.h:174
@ MID_GNE_DEMANDVIEWOPTIONS_SHOWALLCONTAINERPLANS
show all container plans
Definition GUIAppEnum.h:945
@ MID_HOTKEY_CTRL_SHIFT_N_NEWWINDOW
open a new window (SUMO AND netedit)
Definition GUIAppEnum.h:218
@ MID_HOTKEY_SHIFT_V_LOCATEVEHICLE
Locate vehicle - button.
Definition GUIAppEnum.h:192
@ MID_GNE_LOCK_ADDITIONALELEMENT
lock additional elements
Definition GUIAppEnum.h:877
@ MID_LANGUAGE_HU
change language to hungarian
@ MID_HOTKEY_F4_SUPERMODE_DATA
select data supermode in netedit
Definition GUIAppEnum.h:238
@ MID_HOTKEY_SHIFT_L_LOCATEPOLY
Locate polygons - button.
Definition GUIAppEnum.h:180
@ MID_HOTKEY_F6_CLEAN_SOLITARYJUNCTIONS_UNUSEDROUTES
clean junctions without edges in network mode and unused routes in demand mode
Definition GUIAppEnum.h:242
@ MID_GNE_LOCK_EDGE
lock edges
Definition GUIAppEnum.h:867
@ MID_HOTKEY_ALT_1_TOGGLEEDITOPTION
toggle edit option
Definition GUIAppEnum.h:145
@ MID_HOTKEY_CTRL_K_OPENTLSPROGRAMS
Load file with TLS Programs.
Definition GUIAppEnum.h:103
@ MID_LANGUAGE_IT
change language to italian
@ MID_GNE_LOCK_ELEMENT
lock element (general, used if we press directly the menuCommand in the toolbar)
Definition GUIAppEnum.h:863
@ MID_GNE_TOOLBARFILE_SAVENETEDITCONFIG_AS
save neteditConfig as
Definition GUIAppEnum.h:715
@ MID_HOTKEY_SHIFT_E_LOCATEEDGE
Locate edge - button.
Definition GUIAppEnum.h:176
@ MID_CLEARMESSAGEWINDOW
Clear simulation output.
Definition GUIAppEnum.h:369
@ MID_HOTKEY_R_MODE_CROSSING_ROUTE_EDGERELDATA
hotkey for mode editing crossing, routes and edge rel datas
Definition GUIAppEnum.h:65
@ MID_TUTORIAL
tutorial button
Definition GUIAppEnum.h:661
@ MID_GNE_LOCK_TRANSPORT
lock transports
Definition GUIAppEnum.h:905
@ MID_GNE_TOGGLE_UNDOREDO_LOADING
enable/disable undo-redo during loading
Definition GUIAppEnum.h:809
@ MID_HOTKEY_CTRL_G_GAMINGMODE_TOGGLEGRID
Toggle Gaming mode in SUMO and grid in netedit.
Definition GUIAppEnum.h:95
@ MID_GNE_DATAVIEWOPTIONS_TAZDRAWFILL
toggle draw TAZ fill
Definition GUIAppEnum.h:967
@ MID_HOTKEY_ALT_6_TOGGLEEDITOPTION
toggle edit option
Definition GUIAppEnum.h:155
@ ID_LOADTHREAD_EVENT
The loading thread.
Definition GUIAppEnum.h:348
@ MID_HOTKEY_L_MODE_PERSONPLAN
hotkey for mode person plan
Definition GUIAppEnum.h:57
@ MID_GNE_LOCK_CONTAINER
lock containers
Definition GUIAppEnum.h:903
@ MID_HOTKEY_V_MODE_VEHICLE
hotkey for mode create vehicles
Definition GUIAppEnum.h:71
@ MID_HOTKEY_SHIFT_P_LOCATEPERSON
Locate person - button.
Definition GUIAppEnum.h:184
@ MID_GNE_TOOLBARFILE_SAVEDATAELEMENTS_UNIFIED
save data elements unified
Definition GUIAppEnum.h:747
@ MID_HOTKEY_I_MODE_INSPECT
hotkey for mode inspecting object attributes
Definition GUIAppEnum.h:55
@ MID_LANGUAGE_EN
change language to english
@ MID_GNE_NETWORKVIEWOPTIONS_SHOWDEMANDELEMENTS
show demand elements
Definition GUIAppEnum.h:833
@ MID_HOTKEY_SHIFT_J_LOCATEJUNCTION
Locate junction - button.
Definition GUIAppEnum.h:178
@ MID_HOTKEY_ALT_0_TOGGLEEDITOPTION
toggle edit option
Definition GUIAppEnum.h:143
@ MID_HOTKEY_CTRL_SHIFT_E_SAVENETEDITCONFIG
save netedit Config
Definition GUIAppEnum.h:210
@ MID_GNE_TOOLBARFILE_SAVEEDGETYPES_AS
save edgeTypes as
Definition GUIAppEnum.h:735
@ MID_HOTKEYS
hotkeys button
Definition GUIAppEnum.h:659
@ MID_GNE_DEMANDVIEWOPTIONS_HIDENONINSPECTED
hide non-inspected demand element
Definition GUIAppEnum.h:935
@ MID_GNE_LOCK_CONNECTION
lock connections
Definition GUIAppEnum.h:871
@ MID_LANGUAGE_DE
change language to german
@ MID_HOTKEY_ALT_F4_CLOSE
Main window closes.
Definition GUIAppEnum.h:163
@ MID_GNE_TOOLBARFILE_RELOADNETWORK
reload only network
Definition GUIAppEnum.h:707
@ MID_GNE_NETWORKVIEWOPTIONS_MERGEAUTOMATICALLY
don't ask before merging junctions
Definition GUIAppEnum.h:849
@ MID_HOTKEY_CTRL_SHIFT_M_SAVEMEANDATAELEMENTS
save Mean Datas
Definition GUIAppEnum.h:216
@ MID_HOTKEY_SHIFT_F2_TEMPLATE_COPY
copy template
Definition GUIAppEnum.h:266
@ MID_GNE_NETWORKVIEWOPTIONS_CHANGEALLPHASES
change all phases
Definition GUIAppEnum.h:847
@ MID_GNE_DATAVIEWOPTIONS_SHOWSHAPES
show shapes
Definition GUIAppEnum.h:961
@ MID_GNE_POSTPROCESSINGNETGENERATE
postprocesing netgenerate
Definition GUIAppEnum.h:785
@ MID_HOTKEY_E_MODE_EDGE_EDGEDATA
hotkey for mode adding edges AND edgeDatas
Definition GUIAppEnum.h:51
@ MID_GNE_DATAVIEWOPTIONS_TAZRELONLYFROM
toggle draw TAZRel only from
Definition GUIAppEnum.h:969
@ MID_GNE_TOOLBARFILE_SAVEADDITIONALELEMENTS_AS
save additionals element as
Definition GUIAppEnum.h:723
@ MID_HOTKEY_ALT_8_TOGGLEEDITOPTION
toggle edit option
Definition GUIAppEnum.h:159
@ MID_GNE_LOCK_ROUTE
lock routes
Definition GUIAppEnum.h:891
@ MID_GNE_LOCK_RIDE
lock rides
Definition GUIAppEnum.h:901
@ MID_GNE_TOOLBARFILE_RELOAD_SUMOCONFIG
reload SUMOConfig
Definition GUIAppEnum.h:717
@ MID_GNE_LOCK_LANE
lock lanes
Definition GUIAppEnum.h:869
@ MID_GNE_NETWORKVIEWOPTIONS_TOGGLEDRAWJUNCTIONSHAPE
toggle draw junction shape
Definition GUIAppEnum.h:829
@ MID_HOTKEY_CTRL_SHIFT_O_OPENNETCONVERTFILE
open Netconvert file
Definition GUIAppEnum.h:220
@ MID_GNE_RECOMPUTINGNEEDED
check if recomputing is needed
@ MID_HOTKEY_CTRL_M_OPENSUMOCONFIG
open sumo config
Definition GUIAppEnum.h:107
@ MID_GNE_TOOLBARFILE_SAVENETWORK_AS
save network as
Definition GUIAppEnum.h:721
@ MID_GNE_DEMANDVIEWOPTIONS_DRAWSPREADVEHICLES
Draw vehicles in begin position or spread in lane.
Definition GUIAppEnum.h:933
@ MID_GNE_DEMANDVIEWOPTIONS_SHOWOVERLAPPEDROUTES
show overlapped routes
Definition GUIAppEnum.h:949
@ MID_HOTKEY_CTRL_Z_UNDO
Redo.
Definition GUIAppEnum.h:135
@ MID_GNE_TOOLBARFILE_SAVEDATAELEMENTS_AS
save data elements as
Definition GUIAppEnum.h:745
@ MID_GNE_MODESMENUTITLE
selector for ModesMenuTitle
@ MID_LANGUAGE_JA
change language to japanese
@ MID_GNE_TOOLBARFILE_SAVEDEMANDELEMENTS_UNIFIED
save demand elements unified
Definition GUIAppEnum.h:741
@ MID_FEEDBACK
feedback button
Definition GUIAppEnum.h:663
@ MID_HOTKEY_CTRL_H_APPSETTINGS_OPENEDGETYPES
open app setting dialog in SUMO and open edge type files in netedit
Definition GUIAppEnum.h:97
@ MID_HOTKEY_BACKSPACE
hot key <Backspace> remove last sub-operation
Definition GUIAppEnum.h:292
@ MID_HOTKEY_CTRL_SHIFT_S_SAVESUMOCONFIG
save SUMOConfig (SUMO AND netedit)
Definition GUIAppEnum.h:222
@ MID_GNE_LOCK_PERSON
lock persons
Definition GUIAppEnum.h:895
@ MID_GNE_LOCK_CROSSING
lock crossings
Definition GUIAppEnum.h:873
@ MID_HOTKEY_ALT_7_TOGGLEEDITOPTION
toggle edit option
Definition GUIAppEnum.h:157
@ MID_HOTKEY_F12_ABOUT
open about dialog
Definition GUIAppEnum.h:256
@ MID_HOTKEY_CTRL_E_EDITSELECTION_LOADNETEDITCONFIG
Edit selection in SUMO and load neteditConfig in netedit.
Definition GUIAppEnum.h:91
@ MID_HOTKEY_ENTER
hot key <ENTER> accept current operation
Definition GUIAppEnum.h:290
@ MID_GNE_TOOLBARFILE_RELOAD_DATAELEMENTS
reload data elements
Definition GUIAppEnum.h:749
@ MID_HOTKEY_CTRL_SHIFT_K_SAVETLS
save TLS Programs
Definition GUIAppEnum.h:214
@ MID_HOTKEY_SHIFT_F1_TEMPLATE_SET
set template
Definition GUIAppEnum.h:264
@ MID_HOTKEY_SHIFT_T_LOCATETLS
Locate TLS - button.
Definition GUIAppEnum.h:190
@ MID_HOTKEY_M_MODE_MOVE_MEANDATA
hotkey for mode moving element AND mean data
Definition GUIAppEnum.h:59
@ MID_HOTKEY_F2_SUPERMODE_NETWORK
select network supermode in netedit
Definition GUIAppEnum.h:234
@ MID_GNE_LOCK_TAZRELDATA
lock TAZRelDatas
Definition GUIAppEnum.h:915
@ MID_GNE_DEMANDVIEWOPTIONS_LOCKCONTAINER
lock container
Definition GUIAppEnum.h:947
@ MID_HOTKEY_SHIFT_F12_FOCUSUPPERELEMENT
focus upper element of current frame (only used in netedit)
Definition GUIAppEnum.h:276
@ MID_HOTKEY_CTRL_N_OPENNETWORK_NEWNETWORK
open network in SUMO and create new empty network in netedit
Definition GUIAppEnum.h:109
@ MID_GNE_LOCK_PERSONTRIP
lock personTrips
Definition GUIAppEnum.h:897
@ MID_RUNTESTS
run tests
@ MID_GNE_TOOLBARFILE_RELOAD_ADDITIONALELEMENTS
reload additionals
Definition GUIAppEnum.h:729
@ MID_HOTKEY_SHIFT_F3_TEMPLATE_CLEAR
clear template
Definition GUIAppEnum.h:268
@ MID_GNE_NETWORKVIEWOPTIONS_SELECTEDGES
select edges
Definition GUIAppEnum.h:835
@ MID_LANGUAGE_ZH
change language to chinese (simplified)
@ MID_GNE_SAVEJOINEDJUNCTIONS
save joined junctions
Definition GUIAppEnum.h:711
@ MID_GNE_DEMANDVIEWOPTIONS_SHOWTRIPS
show all trips
Definition GUIAppEnum.h:939
@ MID_GNE_NETWORKVIEWOPTIONS_TOGGLEGRID
show grid
Definition GUIAppEnum.h:827
@ MID_GNE_TOOLBARFILE_SAVEMEANDATAELEMENTS_AS
save meanDatas as
Definition GUIAppEnum.h:753
@ MID_LANGUAGE_FR
change language to french
@ MID_GNE_TOOLBARFILE_SAVEJUPEDSIMELEMENTS_AS
save JuPedSim as
Definition GUIAppEnum.h:727
@ MID_GNE_LOCK_JUNCTION
lock junctions
Definition GUIAppEnum.h:865
@ MID_GNE_LOCK_POI
lock POIs
Definition GUIAppEnum.h:885
@ MID_HOTKEY_P_MODE_POLYGON_PERSON
hotkey for mode creating polygons
Definition GUIAppEnum.h:61
@ MID_HOTKEY_CTRL_L_SAVEASPLAINXML
save network as plain XML
Definition GUIAppEnum.h:105
@ MID_GNE_LOCK_EDGERELDATA
lock edgeRelDatas
Definition GUIAppEnum.h:913
@ MID_GNE_LOCK_EDGEDATA
lock edgeDatas
Definition GUIAppEnum.h:911
@ MID_GNE_TOOLBAREDIT_COMPUTEPATHMANAGER
compute path manager
Definition GUIAppEnum.h:803
@ MID_GNE_LOCK_TAZ
lock TAZs
Definition GUIAppEnum.h:881
@ MID_HOTKEY_CTRL_SHIFT_A_SAVEADDITIONALELEMENTS
Save Additional Elements.
Definition GUIAppEnum.h:202
@ MID_WINDOW
Main window-ID.
Definition GUIAppEnum.h:300
@ MID_LANGUAGE_KO
change language to korean
GUICompleteSchemeStorage gSchemeStorage
#define GUIDesignTextColorRed
red color (for invalid text)
Definition GUIDesigns.h:44
#define GUIDesignButtonStatusBarFixed
button rectangular with thick and raise frame with a width of 100
Definition GUIDesigns.h:124
#define GUIDesignHorizontalFrameStatusBar
Horizontal frame used in status bar.
Definition GUIDesigns.h:359
#define GUIDesignLabelStatusBar
label used in statusBar
Definition GUIDesigns.h:284
#define GUIDesignSplitter
Definition GUIDesigns.h:505
#define GUIDesignSplitterMDI
MDI Splitter.
Definition GUIDesigns.h:508
#define GUIDesignStatusBar
design used in status bar
Definition GUIDesigns.h:477
@ MESSAGE_OCCURRED
send when a message occurred
@ GLDEBUG_OCCURRED
send when a gldebug occurred
@ ERROR_OCCURRED
send when a error occurred
@ SIMULATION_LOADED
send when a simulation has been loaded
@ DEBUG_OCCURRED
send when a debug occurred
@ WARNING_OCCURRED
send when a warning occurred
GUISelectedStorage gSelected
A global holder of selected objects.
FXString gCurrentFolder
The folder used as last.
@ MODEMEANDATA
@ MODEADDITIONAL
@ SUPERMODEDEMAND
@ NETEDIT_MINI
@ VCLASS_SMALL_TAXI
@ MODECREATEEDGE
@ TOOL_TURNDEFS
@ SUPERMODENETWORK
@ SUPERMODEDATA
@ TOOL_CITYBRAIN
#define WRITE_MESSAGE(msg)
Definition MsgHandler.h:288
#define WRITE_ERROR(msg)
Definition MsgHandler.h:295
#define TL(string)
Definition MsgHandler.h:304
#define TLF(string,...)
Definition MsgHandler.h:306
#define PROGRESS_FAILED_MESSAGE()
Definition MsgHandler.h:294
std::vector< std::string > StringVector
Definition of a vector of strings.
Definition Option.h:42
@ SUMO_TAG_TYPES
types (edge)
@ GNE_TAG_JPS_OBSTACLE
polygon used for draw juPedSim obstacles
@ GNE_TAG_JPS_WALKABLEAREA
polygon used for draw juPedSim walkable areas
@ GNE_ATTR_SAVEFILE
save file
std::string toString(const T &t, std::streamsize accuracy=gPrecision)
Definition ToString.h:46
bool isErrorCreatingElement() const
get flag for mark if a element wasn't created
void forceOverwriteElements()
force overwritte elements (used if we're reloading elements)
bool parse()
parse
void setSelector(FXSelector sel)
set the selector
void setTarget(FXObject *tgt)
set the target
static bool isReadable(std::string path)
Checks whether the given file is readable.
static void resetFont()
to be called when the font context is invalidated
Definition GLHelper.cpp:666
std::string getConfigDirectory() const
get current config directory (if we defined a netedit, sumo or netconvert config)
void resetDefaultFilenames()
brief set default files for all buckets
std::string getDefaultFilename(const FileBucket::Type type) const
functions related with filenames
bool isFilenameDefined(const FileBucket::Type type) const
check if at least we have an additional file defined
std::string getConfigFilePrefix(const std::string &sufix) const
get current config patter (if we defined a netedit, sumo or netconvert config)
std::string getDefaultFolder(const FileBucket::Type type) const
get default folder associated with the given tipe
FileBucket * getBucket(const FileBucket::Type type, const std::string &filename, const bool create)
get bucket
void setDefaultFilenameFile(const FileBucket::Type type, const std::string &filename)
brief set default additional file
long onCmdOpenNetgenerateDialog(FXObject *, FXSelector, void *)
called when user press "netgenerate" button
GNEApplicationWindowHelper::SupermodeCommands mySupermodeCommands
Supermode Commands.
long onCmdToggleUndoRedoLoading(FXObject *, FXSelector, void *)
called when toggle checkbox disable undo redo during loading (file)
long onCmdSaveTLSProgramsAs(FXObject *, FXSelector, void *)
called when the command/FXCall save TLSPrograms as is executed
FXMenuTitle * myModesMenuTitle
menu title for modes
const std::string & isUndoRedoEnabledTemporally() const
check if undo-redo is enabled temporally
void create()
Creates the main window (required by FOX)
long onCmdToggleDrawJunctionShape(FXObject *, FXSelector, void *)
called if the user press key combination Ctrl + J to toggle draw junction shape
GNEApplicationWindowHelper::WindowsMenuCommands myWindowsMenuCommands
Windows Menu Commands.
GNELoadThread * myLoadThread
the thread that loads the network
void enableUndoRedoTemporally()
enable undo-redo temporally (for example, after creating an edge)
void clearUndoList()
clear undo list
GNENet * myNet
we are responsible for the net
long onCmdSaveEdgeTypes(FXObject *, FXSelector, void *)
called when the command/FXCall save edge types is executed
long onCmdOpenUndoListDialog(FXObject *, FXSelector, void *)
long onCmdReloadSumoConfig(FXObject *, FXSelector, void *)
called when the command/FXCall reload SumoConfig is executed
void handleEvent_Message(GUIEvent *e)
handle event of type message
long onCmdSaveAdditionalElementsAs(FXObject *, FXSelector, void *)
called when the command/FXCall save additionals as
long onCmdReloadDataElements(FXObject *, FXSelector, void *)
called when the command/FXCall reload data elements is executed
long onCmdLoadAdditionalsInSUMOGUI(FXObject *, FXSelector, void *)
called when user toggle windows checkbox "load additionals"
long onCmdOpenTLSPrograms(FXObject *, FXSelector, void *)
called when the command/FXCall open TLS programs is executed
long onUpdComputePathManager(FXObject *obj, FXSelector sel, void *ptr)
called when the update/FXCall compute path manager is executed
long onCmdSaveAdditionalElements(FXObject *, FXSelector, void *)
called when the command/FXCall save additionals is executed
void updateControls()
update control contents after undo/redo or recompute
long onUpdSaveMeanDataElementsUnified(FXObject *, FXSelector, void *)
called when the update/FXCall save meanDatas unified is executed
GNEApplicationWindowHelper::LockMenuCommands myLockMenuCommands
Lock Menu Commands.
const GNETagPropertiesDatabase * myTagPropertiesDatabase
tagProperties database
long onCmdSavePlainXML(FXObject *, FXSelector, void *)
called when the command/FXCall save plain xml is executed
long onCmdFeedback(FXObject *sender, FXSelector sel, void *ptr)
called if the user selects help->feedback
long onCmdNewNetwork(FXObject *, FXSelector, void *)
called when the command/FXCall new network is executed
long onCmdRunTests(FXObject *, FXSelector, void *)
run tests
long onCmdSavePlainXMLAs(FXObject *, FXSelector, void *)
called when the command/FXCall save as plain xml is executed
long onCmdOpenOptionsDialog(FXObject *, FXSelector, void *)
called when user press "options" button
GNEApplicationWindowHelper::HelpMenuCommands myHelpMenuCommands
Help Menu Commands.
GNEApplicationWindow()
FOX needs this for static members.
long onClipboardRequest(FXObject *sender, FXSelector sel, void *ptr)
called when the command/FXCall clipboard request is executed
long onCmdToggleUndoRedo(FXObject *, FXSelector, void *)
called when toggle checkbox disable undo redo (processing)
long onCmdSaveNeteditConfigAs(FXObject *, FXSelector, void *)
called when the command/FXCall save netedit config as is executed
long onUpdSaveNetwork(FXObject *, FXSelector, void *)
called when the update/FXCall save network is executed
std::string myUndoRedoListEnabled
string to check if undo/redo list is enabled (a String is used to keep the disabling reason)
std::map< std::string, FXMenuPane * > myMenuPaneToolMaps
map with menu pane tools and strings
long onCmdSaveSumoConfig(FXObject *, FXSelector, void *)
called when the command/FXCall save SumoConfig is executed
long onCmdOpenMeanDataElements(FXObject *, FXSelector, void *)
called when the command/FXCall open meanDatas is executed
long onUpdReloadDataElements(FXObject *, FXSelector, void *)
called when the command/FXCall reload data elements is updated
long onCmdClose(FXObject *, FXSelector, void *)
called when the command/FXCall close is executed
long onCmdEditViewport(FXObject *, FXSelector, void *)
Called on menu Edit->Viewport.
long onCmdToggleViewOption(FXObject *, FXSelector, void *)
toggle viewOption
FXEX::MFXThreadEvent myLoadThreadEvent
io-event with the load-thread
OptionsCont myOriginalNetgenerateOptions
original netgenerate options container
long onCmdToggleEditOptions(FXObject *, FXSelector, void *)
called if the user press key combination Alt + <0-9>
GNEApplicationWindowHelper::MenuBarFile myMenuBarFile
MenuBarFile.
OptionsCont myOriginalNeteditOptions
original netedit options container
void loadDemandElements(const std::string operation)
load demand elements from netedit options
long onCmdProcessButton(FXObject *sender, FXSelector sel, void *)
called when user press a process button (or a shortcut)
long onUpdRedo(FXObject *obj, FXSelector sel, void *ptr)
called when the update/FXCall redo is executed
GNEApplicationWindowHelper::ModesMenuCommands & getModesMenuCommands()
get modes Menu Commands (needed for show/hide menu commands)
long onCmdToggleTimeFormat(FXObject *sender, FXSelector sel, void *ptr)
called if the user press the toggle time format button
long onCmdRunNetgenerate(FXObject *sender, FXSelector sel, void *ptr)
called when run netgenerate is called
GNEApplicationWindowHelper::ProcessingMenuCommands myProcessingMenuCommands
Processing Menu Commands.
OptionsCont & getSumoOptions()
get SUMO options container
FXMenuPane * myToolsImportCityBrainMenu
GNEApplicationWindowHelper::EditMenuCommands & getEditMenuCommands()
get Edit Menu Commands (needed for show/hide menu commands)
void setStatusBarText(const std::string &statusBarText)
set text of the statusBar
GNEUndoList * myUndoList
the one and only undo list
long onUpdSaveDataElements(FXObject *, FXSelector, void *)
called when the update/FXCall save data elements is executed
FXMenuPane * myFileMenuDemandElements
long onCmdSmartReload(FXObject *, FXSelector, void *)
called when the command/FXCall smart reload is executed
void loadEdgeTypes(const std::string operation)
load meanData elements
long onCmdPaste(FXObject *, FXSelector, void *)
long onUpdPythonTool(FXObject *, FXSelector, void *)
called when the command/FXCall python tool is updated
long onCmdOpenNetwork(FXObject *, FXSelector, void *)
called when the command/FXCall open network is executed
GNEExternalRunner * myExternalRunner
external runner for running external tools
long onCmdComputePathManager(FXObject *, FXSelector, void *)
long onCmdToggleComputeNetworkData(FXObject *, FXSelector, void *)
called when toggle checkbox compute network when switching between supermodes
long onCmdCopyTemplate(FXObject *, FXSelector, void *)
GNEInternalTest * getInternalTest() const
get netedit test system
long onLoadThreadEvent(FXObject *, FXSelector, void *)
called when the command/FXCall load thread is executed
long onUpdSaveDemandElementsUnified(FXObject *, FXSelector, void *)
called when the update/FXCall save demand elements unified is executed
long onUpdRequireRecomputing(FXObject *sender, FXSelector sel, void *ptr)
update label for require recomputing
FXMDIMenu * myMDIMenu
The menu used for the MDI-windows.
long onCmdReloadDemandElements(FXObject *, FXSelector, void *)
called when the command/FXCall reload demand elements is executed
long onUpdSaveMeanDataElements(FXObject *, FXSelector, void *)
called when the update/FXCall save meanDatas is executed
long onUpdSaveDemandElements(FXObject *, FXSelector, void *)
called when the update/FXCall save demand elements is executed
OptionsCont myOriginalSumoOptions
original sumo options container
OptionsCont myNetgenerateOptions
netgenerate options container
SUMOTime getCurrentSimTime() const
get current simulation time (pure virtual but we don't need it)
long onCmdReloadEdgeTypes(FXObject *, FXSelector, void *)
called when the command/FXCall reload edge types is executed
FXMenuPane * myFileMenuMeanDataElements
long onCmdLockAllElements(FXObject *, FXSelector sel, void *)
called when user press lock all elements button
long onKeyPress(FXObject *o, FXSelector sel, void *data)
called when a key is pressed
long onCmdQuit(FXObject *, FXSelector, void *)
Called by FOX if the application shall be closed.
long onCmdSaveMeanDataElements(FXObject *, FXSelector, void *)
called when the command/FXCall save meanDatas is executed
long onCmdSaveEdgeTypesAs(FXObject *, FXSelector, void *)
called when the command/FXCall save edgeTypes as is executed
long onCmdClearSelectionShortcut(FXObject *sender, FXSelector sel, void *ptr)
called if the user hits key combination for clear selection
long onCmdClearMsgWindow(FXObject *, FXSelector, void *)
called when the command/FXCall clear message windows is executed
long onCmdLockElements(FXObject *, FXSelector sel, void *)
called when user press a lock menu check
MFXButtonTooltip * myRequireRecomputingButton
Button used for show if recomputing is needed.
long onCmdClearTemplate(FXObject *, FXSelector, void *)
GNEUndoList * getUndoList()
get pointer to undoList
long onUpdSaveNeteditConfig(FXObject *, FXSelector, void *)
called when the command/FXCall save netedit config is updated
long onUpdNeedsFrontElement(FXObject *, FXSelector, void *)
called when the update/FXCall needs front element is executed
FXMenuTitle * myLockMenuTitle
menu title for lock
void loadOptionOnStartup()
load net on startup
GNEViewNet * getViewNet()
get pointer to viewNet
long onCmdOpenSumoConfig(FXObject *, FXSelector, void *)
called when the command/FXCall open SumoConfig is executed
GNEApplicationWindowHelper::LocateMenuCommands myLocateMenuCommands
Locate Menu Commands.
void loadTrafficLights(const std::string operation)
load traffic lights
long onCmdAbout(FXObject *, FXSelector, void *)
called when the command/FXCall show about dialog is executed
GNEApplicationWindowHelper::FileBucketHandler * myFileBucketHandler
saving files handler
long onUpdReloadEdgeTypes(FXObject *, FXSelector, void *)
called when the command/FXCall reload edge types is updated
void disableUndoRedoTemporally(const std::string &reason)
disable undo-redo temporally giving a string with the reason (for example, if we're creating an edge)
long onCmdToggleGrid(FXObject *, FXSelector, void *)
called if the user press key combination Ctrl + G to toggle grid
void dependentBuild()
build dependent
long onCmdEditChosen(FXObject *, FXSelector, void *)
called when the command/FXCall edit chosen is executed
long onUpdReloadTLSPrograms(FXObject *, FXSelector, void *)
called when the command/FXCall reload TLS programs is updated
long onCmdOpenSumoOptionsDialog(FXObject *, FXSelector, void *)
called when user press "sumo options" button
GNEApplicationWindowHelper::EditMenuCommands myEditMenuCommands
Edit Menu Commands.
long onCmdSetSuperMode(FXObject *sender, FXSelector sel, void *ptr)
called if the user hits an edit-supermode hotkey
bool allowInputSignals(FXObject *obj) const
check if ignore input signal (using during netedit tests)
long onCmdReloadAdditionalElements(FXObject *, FXSelector, void *)
called when the command/FXCall reload additionals is executed
long onUpdSaveSumoConfig(FXObject *, FXSelector, void *)
called when the command/FXCall save SumoConfig is updated
void loadMeanDataElements(const std::string operation)
load meanData elements from netedit options
long onCmdAbort(FXObject *sender, FXSelector sel, void *ptr)
called if the user hits esc
GNEViewNet * myViewNet
pointer to current view net
GNEExternalRunner * getExternalRunner() const
get external runner
long onUpdOpenUndoListDialog(FXObject *, FXSelector, void *)
long onUpdNeedsNetworkElement(FXObject *, FXSelector, void *)
called when the update/FXCall needs at least one network element is executed
const FXString myTitlePrefix
the prefix for the window title
long onCmdOpenAdditionalElements(FXObject *, FXSelector, void *)
called when the command/FXCall open additionals is executed
GNEApplicationWindowHelper::FileBucketHandler * getFileBucketHandler() const
get file bucket handler
long onCmdSaveNetworkAs(FXObject *, FXSelector, void *)
called when the command/FXCall save network as is executed
double getTrackerInterval() const
get current tracker interval (pure virtual but we don't need it)
void fillMenuBar()
Builds the menu bar.
long onCmdFocusFrame(FXObject *sender, FXSelector sel, void *ptr)
called if the user hits key combination for focus on frame
long onCmdSaveMeanDataElementsAs(FXObject *, FXSelector, void *)
called when the command/FXCall save meanDatas as is executed
long onCmdToggleFrontElement(FXObject *, FXSelector, void *)
called if the user call toggle front element
void loadConfiguration(const std::string &configurationFile)
starts to load a configuration
GNEApplicationWindowHelper::LockMenuCommands & getLockMenuCommands()
get lock Menu Commands
long onCmdPostprocessingNetgenerate(FXObject *sender, FXSelector sel, void *ptr)
postprocessing netgenerate
long onCmdHelp(FXObject *sender, FXSelector sel, void *ptr)
called if the user selects help->Documentation
long onCmdSaveNeteditConfig(FXObject *, FXSelector, void *)
called when the command/FXCall save netedit config is executed
long onUpdRequireViewNet(FXObject *sender, FXSelector sel, void *ptr)
enable or disable sender object depending if viewNet exist
long onUpdReloadNeteditConfig(FXObject *, FXSelector, void *)
called when the command/FXCall reload netedit config is updated
OptionsCont & getNetgenerateOptions()
get netgenerate options container
long onCmdSaveDemandElements(FXObject *, FXSelector, void *)
called when the command/FXCall save demand elements is executed
long onCmdCut(FXObject *, FXSelector, void *)
called when user press Ctrl+Z
long onCmdNewWindow(FXObject *, FXSelector, void *)
long onCmdSaveJoinedJunctionsAs(FXObject *, FXSelector, void *)
called when the command/FXCall save joined is executed
long onCmdOpenEdgeTypes(FXObject *, FXSelector, void *)
called when the command/FXCall open edgeType is executed
long onCmdSaveJuPedSimElementsAs(FXObject *, FXSelector, void *)
called when the command/FXCall save JuPedSim elements as is executed
const GNETagPropertiesDatabase * getTagPropertiesDatabase() const
get tag properties database
void setExternalRunner(GNEExternalRunner *externalRunner)
set external runner
long onCmdLoadDemandInSUMOGUI(FXObject *, FXSelector, void *)
called when user toggle windows checkbox "load demand"
long onUpdLockMenuTitle(FXObject *, FXSelector sel, void *)
enable or disable lock menu title
bool myAmLoading
information whether the gui is currently loading and the load-options shall be greyed out
long onUpdSaveDataElementsUnified(FXObject *, FXSelector, void *)
called when the update/FXCall save data elements unified is executed
long onCmdReloadMeanDataElements(FXObject *, FXSelector, void *)
called when the command/FXCall reload meanDatas is executed
long onCmdRedo(FXObject *sender, FXSelector, void *)
long onCmdSaveDemandElementsAs(FXObject *, FXSelector, void *)
called when the command/FXCall save demand elements as is executed
long onCmdReloadTLSPrograms(FXObject *, FXSelector, void *)
called when the command/FXCall reload TLS programs is executed
long onCmdSaveDataElementsAs(FXObject *, FXSelector, void *)
called when the command/FXCall save data elements as is executed
void handleEvent_FileLoaded(GUIEvent *e)
handle event of type Network loaded
GNEApplicationWindowHelper::FileMenuCommands myFileMenuCommands
File Menu Commands.
void loadAdditionalElements(const std::string operation)
load additional elements from netedit options
GNEInternalTest * myInternalTest
internal test system
void loadOSM(const std::string &OSMFile)
starts to load a OSM File
long onUpdSaveAdditionalElements(FXObject *, FXSelector, void *)
called when the update/FXCall save additionals is executed
long onCmdOpenNeteditConfig(FXObject *, FXSelector, void *)
called when the command/FXCall open netedit config is executed
bool myAllowUndoRedoLoading
allow undo-redo loading (read from registry)
long onCmdOpenRecent(FXObject *, FXSelector, void *)
called when the command/FXCall open recent is executed
void closeAllWindows(const bool resetFilenames)
this method closes all windows and deletes the current simulation
bool myAllowUndoRedo
allow undo-redo (read from registry)
long onCmdChangelog(FXObject *sender, FXSelector sel, void *ptr)
called if the user selects help->Changelog
long onUpdOpen(FXObject *, FXSelector, void *)
called when the command/FXCall on update open executed
long onCmdSetMode(FXObject *sender, FXSelector sel, void *ptr)
called if the user hits an edit-mode hotkey
bool myHadDependentBuild
check if had dependent build
long onCmdBackspace(FXObject *sender, FXSelector sel, void *ptr)
called if the user hits backspace
void updateRecomputingLabel()
update recomputing label
bool askSaveElements(FXObject *sender, FXSelector sel, void *ptr)
warns about unsaved changes and gives the user the option to abort
long onUpdReloadMeanDataElements(FXObject *, FXSelector, void *)
called when the command/FXCall reload meanDatas is updated
long onCmdCopy(FXObject *, FXSelector, void *)
long onCmdOpenSUMOGUI(FXObject *sender, FXSelector sel, void *ptr)
called if the user hints ctrl + T
long onCmdOpenDemandElements(FXObject *, FXSelector, void *)
called when the command/FXCall open demand is executed
FXMenuPane * myToolsVisualizationMenu
void loadNetwork(const std::string &networkFile)
load network
long onUpdToggleViewOption(FXObject *, FXSelector, void *)
update viewOption
GNEApplicationWindowHelper::ToolsMenuCommands myToolsMenuCommands
Tools Menu Commands.
long onCmdUnlockAllElements(FXObject *, FXSelector sel, void *)
called when user press unlock all elements button
long onUpdReloadSumoConfig(FXObject *, FXSelector, void *)
called when the command/FXCall reload SumoConfig is updated
long onUpdNeedsNetwork(FXObject *, FXSelector, void *)
called when the update/FXCall needs network is executed
long onUpdReloadAdditionalElements(FXObject *, FXSelector, void *)
called when the command/FXCall reload additionals is updated
GNEApplicationWindowHelper::ToolbarsGrip & getToolbarsGrip()
get ToolbarsGrip
long onUpdSaveJuPedSimElementsAs(FXObject *, FXSelector, void *)
called when the update/FXCall save juPedSim as is executed
long onUpdReloadNetwork(FXObject *, FXSelector, void *)
called when the update/FXCall network reload is executed
OptionsCont mySumoOptions
sumo options container
bool consoleOptionsLoaded()
check if console options was already loaded
long onCmdSaveDataElements(FXObject *, FXSelector, void *)
called when the command/FXCall save data elements is executed
long onCmdOpenPythonToolDialog(FXObject *obj, FXSelector, void *)
called when user press over a tool dialog button
long onCmdLocate(FXObject *, FXSelector, void *)
called when the command/FXCall locate is executed
long onCmdDel(FXObject *sender, FXSelector sel, void *ptr)
called if the user hits del
long onCmdHotkeys(FXObject *sender, FXSelector sel, void *ptr)
called if the user selects help->Hotkeys
long onCmdOpenDataElements(FXObject *, FXSelector, void *)
called when the command/FXCall open data is executed
long onCmdRunPythonTool(FXObject *obj, FXSelector, void *)
called when user run a tool
void updateSuperModeMenuCommands(const Supermode supermode)
update FXMenuCommands depending of supermode
OptionsCont myNetconvertOptions
netconvert options container
bool myConsoleOptionsLoaded
flag for check if console options was already loaded
long onUpdReloadDemandElements(FXObject *, FXSelector, void *)
called when the command/FXCall reload demand elements is updated
void createNewNetwork()
create new network
long onCmdEnter(FXObject *sender, FXSelector sel, void *ptr)
called if the user hits enter
FXCursor * getDefaultCursor()
get default cursor
long onCmdSetTemplate(FXObject *, FXSelector, void *)
GNEApplicationWindowHelper::FileMenuCommands & getFileMenuCommands()
get file Menu Commands (needed for show/hide menu commands)
long onCmdSaveDataElementsUnified(FXObject *, FXSelector, void *)
called when the command/FXCall save data elements unified is executed
long onCmdTutorial(FXObject *sender, FXSelector sel, void *ptr)
called if the user selects help->Tutorial
long onCmdOpenNetgenerateOptionsDialog(FXObject *, FXSelector, void *)
called when user press "netgenerate options" button
long onUpdUndo(FXObject *obj, FXSelector sel, void *ptr)
called when the update/FXCall undo is executed
const GNEApplicationWindowHelper::ProcessingMenuCommands & getProcessingMenuCommands() const
get processing Menu Commands
long onCmdSaveDemandElementsUnified(FXObject *, FXSelector, void *)
called when the command/FXCall save demand elements unified is executed
long onCmdPostProcessingPythonTool(FXObject *obj, FXSelector, void *)
post processing after run tool
GUIMessageWindow * myMessageWindow
A window to display messages, warnings and error in.
long onCmdReloadNetwork(FXObject *, FXSelector, void *)
called when the command/FXCall network reload is executed
long onUpdSaveAdditionalElementsUnified(FXObject *, FXSelector, void *)
called when the update/FXCall save additionals unified is executed
long onUpdSmartReload(FXObject *, FXSelector, void *)
called when the update/FXCall smart reload is executed
FXMenuPane * myFileMenuRecentNetworks
FXSplitter * myMainSplitter
The splitter that divides the main window into view and the log window.
long onCmdLockSelectElements(FXObject *, FXSelector sel, void *)
called when user press lock select elements button
long onCmdOpenNetconvertConfig(FXObject *, FXSelector, void *)
called when the command/FXCall open netconvertconfiguration is executed
long onCmdSaveTLSPrograms(FXObject *, FXSelector, void *)
called when the command/FXCall save TLSPrograms is executed
long onUpdSaveEdgeTypes(FXObject *, FXSelector, void *)
called when the command/FXCall save edge types is updated
long onCmdUndo(FXObject *sender, FXSelector, void *)
called when user press Ctrl+Z
long onCmdReloadNeteditConfig(FXObject *, FXSelector, void *)
called when the command/FXCall reload netedit config is executed
long onCmdSaveNetwork(FXObject *, FXSelector, void *)
called when the command/FXCall save network is executed
FXMenuPane * myFileMenu
the submenus
long computeJunctionWithVolatileOptions(FXObject *sender, FXSelector sel, void *ptr)
called if the user selects Processing->compute junctions with volatile options
GNEApplicationWindowHelper::ToolbarsGrip myToolbarsGrip
Toolbars Grip.
long onUpdToggleTimeFormat(FXObject *sender, FXSelector sel, void *ptr)
update toggle time format button
MFXSynchQue< GUIEvent * > myThreadEvents
List of load requests.
long onCmdSaveAdditionalElementsUnified(FXObject *, FXSelector, void *)
called when the command/FXCall save additionals unified is executed
long onKeyRelease(FXObject *o, FXSelector sel, void *data)
called when a key is released
void loadDataElements(const std::string operation)
load data elements from netedit options
GNEApplicationWindowHelper::ModesMenuCommands myModesMenuCommands
Modes Menu Commands.
long onUpdSaveTLSPrograms(FXObject *, FXSelector, void *)
called when the command/FXCall save TLSPrograms is updated
FXGLCanvas * getBuildGLCanvas() const
get build GL Canvas (must be implemented in all children)
long onCmdEditViewScheme(FXObject *, FXSelector, void *)
Called on menu Edit->Visualization.
long onCmdSaveSumoConfigAs(FXObject *, FXSelector, void *)
called when the command/FXCall save SumoConfig as is executed
long onCmdOpenForeign(FXObject *, FXSelector, void *)
called when the command/FXCall open foreign is executed
long onCmdSaveMeanDataElementsUnified(FXObject *, FXSelector, void *)
called when the command/FXCall save meanDatas unified is executed
void refreshAttributesEditor()
refresh attribute editor
GNEAttributesEditorType * getNeteditAttributesEditor() const
get netedit attributes editor
void abortReparenting()
abort selecting parent
void refreshAttributesEditor()
refresh attribute editor
GNEAttributesEditor * getContainerAttributesEditor() const
get attributes editor
void refreshEdgeTypeSelector()
refresh edge type selector
EdgeTypeSelector * getEdgeTypeSelector() const
get edgeType selector
Result getResult() const
get result to indicate if this dialog was closed accepting or rejecting changes
Result
list of possible results when closing the dialog
Definition GNEDialog.h:70
void addLaneType(GNELaneType *laneType)
add laneType
GNENet * getNet() const
get the loaded net
const std::string & getSettingsFile() const
get the name of the settings file to load
bool getViewportFromRegistry() const
get whether loading viewport from registry
const std::string & getFile() const
get the name of the loaded file
GNEEvent_FileLoaded::Type getType() const
get event type
std::string getFilename() const
Return file name, if any.
virtual void updateFrameAfterUndoRedo()
function called after undo/redo in the current frame (can be reimplemented in frame children)
Definition GNEFrame.cpp:187
void forceOverwriteElements()
force overwritte elements (used if we're reloading elements)
bool isErrorCreatingElement() const
get flag for check if a element wasn't created
void clearTemplate()
clear template (used by shortcut)
void setTemplate()
set template (used by shortcut)
void copyTemplate()
copy template (used by shortcut)
TemplateEditor * getTemplateEditor() const
get template editor
void clearInspection()
clear inspection
GNEAttributesEditor * getAttributesEditor() const
get AttributesEditor
void refreshInspection()
refresh current inspection
void runNeteditInternalTests(GNEApplicationWindow *applicationWindow)
run netedit internal test
void newNetwork()
begins the creation of an empty network
static void fillOptions(OptionsCont &neteditOptions)
clears and initializes the OptionsCont
void loadNetworkOrConfig()
begins the loading of an existent network or config
static void setDefaultOptions(OptionsCont &neteditOptions)
sets required options for proper functioning
const std::unordered_map< SumoXMLTag, std::unordered_map< const GUIGlObject *, GNEDemandElement * >, std::hash< int > > & getDemandElements() const
get demand elements
const std::unordered_map< const GUIGlObject *, GNECrossing * > & getCrossings() const
get crossings
int getNumberOfMeanDatas() const
get number of meanDatas
const std::unordered_map< SumoXMLTag, std::map< const std::string, GNEMeanData * >, std::hash< int > > & getMeanDatas() const
get meanDatas
const std::map< const std::string, GNEDataSet * > & getDataSets() const
get demand elements
const std::map< std::string, GNEEdge * > & getEdges() const
map with the ID and pointer to edges of net
int getNumberOfDemandElements() const
get number of current demand elements saved in AttributeCarriers (default vTypes are NOT included)
int getNumberOfAdditionals() const
get number of additionals
bool requireJunctionTazOption() const
check if we have elements that requires the option junction-taz
const std::map< std::string, GNEJunction * > & getJunctions() const
get junctions
const std::map< std::string, GNEEdgeType * > & getEdgeTypes() const
map with the ID and pointer to edgeTypes of net
const std::unordered_map< SumoXMLTag, std::unordered_map< const GUIGlObject *, GNEAdditional * >, std::hash< int > > & getAdditionals() const
get additionals
GNEDialog::Result askSaveMeanDataElements(GNEDialog::Result &commonResult) const
warns about unsaved changes in meanData elements and gives the user the option to abort
void dataElementsSaved()
mark demand elements as saved
GNEDialog::Result askSaveDemandElements(GNEDialog::Result &commonResult) const
warns about unsaved changes in demand elements and gives the user the option to abort
void requireSaveNetwork()
inform that network has to be saved
void demandElementsSaved()
mark demand elements as saved
void additionalsSaved()
mark additionals as saved
void requireSaveNeteditConfig()
inform that netedit config has to be saved
void requireSaveSumoConfig()
inform that SumoConfig has to be saved
bool isSumoConfigSaved() const
check if SumoConfig is saved
void neteditConfigSaved()
mark netedit config as saved
void meanDatasSaved()
mark mean data elements as saved
bool isDemandElementsSaved() const
check if demand elements are saved
GNEDialog::Result askSaveAdditionalElements(GNEDialog::Result &commonResult) const
warns about unsaved changes in additionals and gives the user the option to abort
bool isDataElementsSaved() const
check if data elements are saved
bool isNetworkSaved() const
check if network is saved
bool isMeanDatasSaved() const
check if mean data elements are saved
bool isNeteditConfigSaved() const
check if netedit config is saved
void networkSaved()
mark network as saved
GNEDialog::Result askSaveNetwork(GNEDialog::Result &commonResult) const
warns about unsaved changes in network and gives the user the option to abort
bool isAdditionalsSaved() const
check if additionals are saved
GNEDialog::Result askSaveDataElements(GNEDialog::Result &commonResult) const
warns about unsaved changes in data elements and gives the user the option to abort
void clearAdditionalElements(GNEUndoList *undoList)
clear additionals
Definition GNENet.cpp:2129
void removeSolitaryJunctions(GNEUndoList *undoList)
removes junctions that have no edges
Definition GNENet.cpp:1786
bool joinSelectedJunctions(GNEUndoList *undoList)
join selected junctions
Definition GNENet.cpp:1626
bool saveMeanDatas()
save meanData elements of the network
Definition GNENet.cpp:2397
void saveTLSPrograms(const std::string &filename)
save TLS Programs elements of the network
Definition GNENet.cpp:2822
void saveJoined(const std::string &filename)
save log of joined junctions (and nothing else)
Definition GNENet.cpp:1436
GNENetHelper::SavingStatus * getSavingStatus() const
get saving status
Definition GNENet.cpp:186
void enableUpdateData()
Definition GNENet.cpp:2887
void saveEdgeTypes(const std::string &filename)
save edgeTypes elements of the network
Definition GNENet.cpp:2841
void clearDataElements(GNEUndoList *undoList)
clear data elements
Definition GNENet.cpp:2164
bool saveDataElements()
save data set elements of the network
Definition GNENet.cpp:2332
void clearDemandElements(GNEUndoList *undoList)
clear demand elements
Definition GNENet.cpp:2142
GNEPathManager * getDemandPathManager()
get demand path manager
Definition GNENet.cpp:198
void adjustPersonPlans(GNEUndoList *undoList)
adjust person plans
Definition GNENet.cpp:1892
void computeNetwork(GNEApplicationWindow *window, bool force=false, bool volatileOptions=false)
trigger full netbuild computation param[in] window The window to inform about delay param[in] force W...
Definition GNENet.cpp:1464
void cleanInvalidDemandElements(GNEUndoList *undoList)
clean invalid demand elements
Definition GNENet.cpp:1937
void cleanUnusedRoutes(GNEUndoList *undoList)
clean unused routes
Definition GNENet.cpp:1802
GNENetHelper::AttributeCarriers * getAttributeCarriers() const
get all attribute carriers used in this net
Definition GNENet.cpp:174
void clearMeanDataElements(GNEUndoList *undoList)
clear meanDatas
Definition GNENet.cpp:2175
void disableUpdateData()
disable update data elements after inserting or removing an element in net
Definition GNENet.cpp:2898
bool saveAdditionals()
save additional elements
Definition GNENet.cpp:2221
void saveNetwork()
save the network
Definition GNENet.cpp:1391
bool saveJuPedSimElements(const std::string &filename)
save JuPedSim elements
Definition GNENet.cpp:2266
bool isNetRecomputed() const
check if net require recomputing
Definition GNENet.cpp:1620
bool cleanInvalidCrossings(GNEUndoList *undoList)
clear invalid crossings
Definition GNENet.cpp:1744
void joinRoutes(GNEUndoList *undoList)
join routes
Definition GNENet.cpp:1828
GNEViewParent * getViewParent() const
get view parent (used for simplify code)
Definition GNENet.cpp:150
void savePlain(const std::string &prefix, const OptionsCont &netconvertOptions)
save plain xml representation of the network (and nothing else)
Definition GNENet.cpp:1427
bool saveDemandElements()
save demand element elements of the network
Definition GNENet.cpp:2283
void computeDemandElements(GNEApplicationWindow *window)
compute demand elements param[in] window The window to inform about delay
Definition GNENet.cpp:1563
bool isOptionModified() const
check if option was modified
void updatePathCalculator()
update DijkstraRouter (needed a good calculation of dijkstra path after modifying network)
bool isPathCalculatorUpdated() const
check if pathCalculator is updated
PathCalculator * getPathCalculator()
obtain instance of PathCalculator
GNEAttributesEditor * getPersonAttributesEditor() const
get attributes creator
void loadFromFile(const std::string &file) const
load from file
void clearCurrentSelection() const
clear current selection with possibility of undo/redo
GNESelectorFrame::SelectionOperation * getSelectionOperationModul() const
get selection operation modul
bool isOptionModified() const
check if option was modified
bool isChangesPending() const
return true if there is changes to save
const std::vector< CurrentTAZ::TAZEdgeColor > & getEdgeAndTAZChildrenSelected() const
get map with edge and TAZChildren
void clearSelectedEdges()
clear current TAZ children
TAZSelectionStatistics * getTAZSelectionStatisticsModule() const
get TAZ Selection Statistics module
TAZSaveChanges * getTAZSaveChangesModule() const
get TAZ Save Changes module
bool parseTLSPrograms(const std::string &file)
parse TLS Programs from a file
void end()
End undo command sub-group. If the sub-group is still empty, it will be deleted; otherwise,...
void undo()
undo the last command group
long onUpdUndo(FXObject *, FXSelector, void *)
event after Undo
void begin(GUIIcon icon, const std::string &description)
Begin undo command sub-group with current supermode. This begins a new group of commands that are tre...
void abortAllChangeGroups()
reverts and discards ALL active chained change groups
Supermode getRedoSupermode() const
get redo supermode
long onUpdRedo(FXObject *, FXSelector, void *)
event after Redo
Supermode getUndoSupermode() const
get undo supermode
void redo()
redo the last command group
void add(GNEChange *command, bool doit=false, bool merge=true)
Add new command, executing it if desired. The new command will be merged with the previous command if...
GNEAttributesEditor * getVehicleAttributesEditor() const
get attributes creator
const std::unordered_set< GNEAttributeCarrier * > & getACs() const
get hash table with all inspected ACs
const std::unordered_set< GNEAttributeCarrier * > & getACs() const
get hash table with all fronted ACs
long onCmdToggleShowDemandElementsNetwork(FXObject *, FXSelector, void *)
toggle show demand elements (network)
const GNEViewNetHelper::DataViewOptions & getDataViewOptions() const
get data view options
GNENet * getNet() const
get the net object
void hotkeyBackSpace()
handle backspace keypress
const GNEViewNetHelper::EditModes & getEditModes() const
get edit modes
long onCmdToggleShowDemandElementsData(FXObject *, FXSelector, void *)
toggle show demand elements (data)
void abortOperation(bool clearSelection=true)
abort current edition operation
GNEViewNetHelper::InspectedElements & getInspectedElements()
get inspected elements
long onCmdToggleDrawSpreadVehicles(FXObject *, FXSelector, void *)
toggle draw vehicles in begin position or spread in lane
long onCmdToggleShowConnections(FXObject *, FXSelector, void *)
toggle show connections
long onCmdToggleShowTAZElements(FXObject *, FXSelector, void *)
toggle show TAZ elements
long onCmdToggleMoveElevation(FXObject *, FXSelector, void *)
toggle move elevation
long onCmdToggleShowAllPersonPlans(FXObject *, FXSelector, void *)
toggle show all person plans in super mode demand
long onCmdToggleTAZRelOnlyTo(FXObject *, FXSelector, void *)
toggle TAZRez only to
const GNEViewNetHelper::NetworkViewOptions & getNetworkViewOptions() const
get network view options
void hotkeyFocusFrame()
handle focus frame keypress
long onCmdToggleChainEdges(FXObject *, FXSelector, void *)
toggle chain edges
long onCmdToggleLockContainer(FXObject *, FXSelector, void *)
toggle lock container in super mode demand
long onCmdToggleShowGrid(FXObject *, FXSelector, void *)
toggle show grid
GNEViewNetHelper::MarkFrontElements & getMarkFrontElements()
get marked for drawing front elements
long onCmdToggleHideNonInspecteDemandElements(FXObject *, FXSelector, void *)
toggle hide non inspected demand elements
GNEViewParent * getViewParent() const
get the net object
long onCmdToggleDrawJunctionShape(FXObject *, FXSelector, void *)
toggle draw junction shape
long onCmdToggleShowShapes(FXObject *, FXSelector, void *)
toggle show shapes in super mode data
long onCmdToggleMergeAutomatically(FXObject *, FXSelector, void *)
toggle warn for merge
GNEViewNetHelper::SaveElements & getSaveElements()
get variable used to save elements
GNEUndoList * getUndoList() const
get the undoList object
void saveVisualizationSettings() const
long onCmdSetSupermode(FXObject *, FXSelector sel, void *)
long onCmdToggleExtendSelection(FXObject *, FXSelector, void *)
toggle extend selection
bool aksChangeSupermode(const std::string &operation, Supermode expectedSupermode)
ask about change supermode
long onCmdSetMode(FXObject *, FXSelector sel, void *)
called when user press a mode button (Network or demand)
void hotkeyEnter()
handle enter keypress
long onCmdToggleShowOverlappedRoutes(FXObject *, FXSelector, void *)
toggle hide non inspected demand elements
long onCmdToggleAutoOppositeEdge(FXObject *, FXSelector, void *)
toggle autoOpposite edge
GNEViewNetHelper::LockManager & getLockManager()
get lock manager
void updateControls()
update control contents after undo/redo or recompute
void hotkeyDel()
handle del keypress
long onCmdToggleChangeAllPhases(FXObject *, FXSelector, void *)
toggle change all phases
long onCmdToggleTAZRelDrawing(FXObject *, FXSelector, void *)
toggle TAZRel drawing
long onCmdToggleShowJunctionBubbles(FXObject *, FXSelector, void *)
toggle show junction bubbles
long onCmdToggleShowAdditionalSubElements(FXObject *, FXSelector, void *)
toggle show additional sub-elements
long onCmdToggleShowAllContainerPlans(FXObject *, FXSelector, void *)
toggle show all container plans in super mode demand
long onCmdToggleTAZRelOnlyFrom(FXObject *, FXSelector, void *)
toggle TAZRez only from
long onCmdToggleShowAdditionals(FXObject *, FXSelector, void *)
toggle show additionals in super mode data
long onCmdToggleLockPerson(FXObject *, FXSelector, void *)
toggle lock person in super mode demand
GNEViewNetHelper::TimeFormat & getTimeFormat()
get variable used to switch between time formats
long onCmdToggleSelectEdges(FXObject *, FXSelector, void *)
toggle select edges
long onCmdToggleShowTrips(FXObject *, FXSelector, void *)
toggle show all trips in super mode demand
long onCmdToggleHideShapes(FXObject *, FXSelector, void *)
toggle hide shapes in super mode demand
const GNEViewNetHelper::DemandViewOptions & getDemandViewOptions() const
get demand view options
long onCmdToggleHideConnections(FXObject *, FXSelector, void *)
toggle hide connections
void forceSupemodeNetwork()
force supermode network(used after load/create new network)
A single child window which contains a view of the simulation area.
void updateUndoRedoButtons()
update toolbar undo/redo buttons (called when user press Ctrl+Z/Y)
long onKeyPress(FXObject *o, FXSelector sel, void *data)
Called when user press a key.
GNESelectorFrame * getSelectorFrame() const
get frame for select elements
GNEVehicleFrame * getVehicleFrame() const
get frame for DEMAND_VEHICLE
GNETAZFrame * getTAZFrame() const
get frame for NETWORK_TAZ
GNETLSEditorFrame * getTLSEditorFrame() const
get frame for NETWORK_TLS
GNEApplicationWindow * getGNEAppWindows() const
get GNE Application Windows
GNEContainerFrame * getContainerFrame() const
get frame for DEMAND_CONTAINER
GNEPersonFrame * getPersonFrame() const
get frame for DEMAND_PERSON
GNEInspectorFrame * getInspectorFrame() const
get frame for inspect elements
GNECreateEdgeFrame * getCreateEdgeFrame() const
get frame for NETWORK_CREATEEDGE
GNEFrame * getCurrentShownFrame() const
get current frame (note: it can be null)
long onCmdLocate(FXObject *, FXSelector, void *)
locator-callback
long onKeyRelease(FXObject *o, FXSelector sel, void *data)
Called when user releases a key.
void saveViewport(const double x, const double y, const double z, const double rot)
Makes the given viewport the default.
static void close()
close GUICursorSubSys
static void initCursors(FXApp *a)
Initiate GUICursorSubSys.
static FXMenuTitle * buildFXMenuTitle(FXComposite *p, const std::string &text, FXIcon *icon, FXMenuPane *menuPane)
build menu title
static FXMenuCommand * buildFXMenuCommandShortcut(FXComposite *p, const std::string &text, const std::string &shortcut, const std::string &info, FXIcon *icon, FXObject *tgt, FXSelector sel)
build menu command
The application's "Feedback" dialog.
void create()
Creates the widget.
Editor for the list of chosen objects.
const std::string & getMsg() const
Returns the message.
GUIEventType getOwnType() const
returns the event type
Definition GUIEvent.h:89
GUISUMOAbstractView * getView() const
return GUISUMOAbstractView
static FXIcon * getIcon(const GUIIcon which)
returns a icon previously defined in the enum GUIIcon
static void initIcons(FXApp *a)
Initiate GUIIconSubSys.
static void close()
close GUIIconSubSys
void setWindowSizeAndPos()
perform initial window positioning and sizing according to user options / previous call
std::vector< FXMainWindow * > myTrackerWindows
list of tracker windows
FXMenuPane * myLanguageMenu
Language menu common to all applications.
FXLabel * myCartesianCoordinate
Labels for the current cartesian, geo-coordinate and test coordinates.
std::map< std::string, std::string > myOnlineMaps
online mapping services for the context menu
MFXStaticToolTip * myStaticTooltipMenu
static toolTip used in menus
FXMDIClient * myMDIClient
The multi view panel.
void buildLanguageMenu(FXMenuBar *menuBar)
long onCmdChangeLanguage(FXObject *, FXSelector, void *)
FXHorizontalFrame * myGeoFrame
FXHorizontalFrame * myTestFrame
FXHorizontalFrame * myCartesianFrame
FXLabel * myTestCoordinate
FXMutex myTrackerLock
A lock to make the removal and addition of trackers secure.
void storeWindowSizeAndPos()
record window position and size in registry
FXLabel * myGeoCoordinate
FXStatusBar * myStatusbar
The status bar.
FXGLVisual * myGLVisual
The gl-visual used.
std::vector< GUIGlChildWindow * > myGLWindows
list of GLWindows
long onUpdChangeLanguage(FXObject *, FXSelector, void *)
A logging window for the gui.
void addSeparator()
Adds a a separator to this log window.
void unregisterMsgHandlers()
unregister message handlers
void clear()
Clears the window.
void appendMsg(GUIEventType eType, const std::string &msg)
Adds new text to the window.
void registerMsgHandlers()
register message handlers
virtual double getXPos() const =0
Returns the x-offset of the field to show stored in this changer.
virtual double getYPos() const =0
Returns the y-offset of the field to show stored in this changer.
virtual double getZPos() const =0
Returns the camera height corresponding to the current zoom factor.
void addDecals(const std::vector< Decal > &decals)
add decals
void showViewschemeEditor()
show viewsscheme editor
virtual void showViewportEditor()
show viewport editor
GUIPerspectiveChanger & getChanger() const
get changer
std::vector< Decal > & getDecals()
The list of decals to show.
virtual void setViewportFromToRot(const Position &lookFrom, const Position &lookAt, double rotation)
applies the given viewport settings
void destroyPopup()
destroys the popup
An XML-handler for visualisation schemes.
const std::vector< std::string > & addSettings(GUISUMOAbstractView *view=0) const
Adds the parsed settings to the global list of settings.
void applyViewport(GUISUMOAbstractView *view) const
Sets the viewport which has been parsed.
void setSnapshots(GUISUMOAbstractView *view) const
Makes a snapshot if it has been parsed.
const std::vector< GUISUMOAbstractView::Decal > & getDecals() const
Returns the parsed decals.
static void buildAccelerators(FXAccelTable *accelTable, FXObject *target, const bool sumogui)
build accelerators
static void close()
close GUITextureSubSys
static void resetTextures()
Reset textures.
static void initTextures(FXApp *a)
Initiate GUITextureSubSys for textures.
static std::string clipped
Definition GUIUserIO.h:58
bool parse()
parse
static void resetLoaded()
resets loaded location elements
bool isRunning() const
check if test is running
void stopTests()
stop tests
bool amChecked() const
check if this MFXCheckableButton is checked
void toggleCheck()
Toggle current check state.
FXbool getCheck() const
Get check state (TRUE, FALSE or MAYBE)
void setCheck(FXbool s=TRUE)
Set check state (TRUE, FALSE or MAYBE)
static FXString getTitleText(const FXString &appname, FXString filename="")
Returns the title text in dependence to an optional file name.
Definition MFXUtils.cpp:61
static bool checkOptions(OptionsCont &oc)
Checks set options from the OptionsCont-singleton for being valid.
Definition NBFrame.cpp:764
A storage for available edgeTypes of edges.
Definition NBTypeCont.h:52
static bool checkOptions(OptionsCont &oc)
Checks set options for being valid.
Definition NIFrame.cpp:397
static bool load(SUMOSAXHandler &handler, const std::vector< std::string > &files, const std::string &type, const bool stringParse=false)
Importer for edge type information stored in XML.
static bool checkOptions(OptionsCont &oc)
Checks set options for being valid.
Definition NWFrame.cpp:148
A storage for options typed value containers)
Definition OptionsCont.h:89
void addDescription(const std::string &name, const std::string &subtopic, const std::string &description)
Adds a description for an option.
void writeConfiguration(std::ostream &os, const bool filled, const bool complete, const bool addComments, const std::string &relativeTo="", const bool forceRelative=false, const bool inComment=false, const std::string &indent="") const
Writes the configuration.
void setApplicationName(const std::string &appName, const std::string &fullName)
Sets the application name.
void doRegister(const std::string &name, Option *o)
Adds an option under the given name.
void setApplicationDescription(const std::string &appDesc)
Sets the application description.
bool set(const std::string &name, const std::string &value, const bool append=false)
Sets the given value for the named option.
std::string getValueString(const std::string &name) const
Returns the string-value of the named option (all options)
void resetWritable()
Resets all options to be writeable.
static OptionsCont & getOptions()
Retrieves the options.
A point in 2D or 3D with translation and scaling methods.
Definition Position.h:37
void set(double x, double y)
set positions x and y
Definition Position.h:82
double x() const
Returns the x-position.
Definition Position.h:52
double y() const
Returns the y-position.
Definition Position.h:57
static StringBijection< SumoConfigFileExtension > SumoConfigFileExtensions
sumo config file extensions
static StringBijection< AdditionalFileExtension > AdditionalFileExtensions
additional file extensions
static StringBijection< MeanDataFileExtension > MeanDataFileExtensions
mean data file extensions
static StringBijection< TLSFileExtension > TLSFileExtensions
TLS file extensions.
static StringBijection< RouteFileExtension > RouteFileExtensions
route file extensions
static StringBijection< NetconvertConfigFileExtension > NetconvertConfigFileExtensions
netconvert config file extensions
static StringBijection< OSMFileExtension > OSMFileExtensions
OSM file extensions.
static StringBijection< EdgeDataFileExtension > EdgeDataFileExtensions
edgedata file extensions
static StringBijection< JunctionFileExtension > JunctionFileExtensions
juntion file extensions
static StringBijection< NeteditConfigFileExtension > NeteditConfigFileExtensions
netedit config file extensions
static StringBijection< NetFileExtension > NetFileExtensions
net file extensions
static StringBijection< EdgeTypeFileExtension > EdgeTypeFileExtensions
edge file extensions
static std::string escapeShell(const std::string &orig)
Escape special characters with backslash.
static std::string transcodeToLocal(const std::string &utf8String)
convert a string from UTF-8 to the local codepage
static unsigned long runHiddenCommand(const std::string &cmd)
run a shell command without popping up any windows (particuarly on win32)
Definition SysUtils.cpp:69
static bool checkOptions(OptionsCont &oc)
checks shared options and sets StdDefs
static void parseTemplate(OptionsCont &options, const std::string &templateString)
run parser
static void setValidation(const std::string &validationScheme, const std::string &netValidationScheme, const std::string &routeValidationScheme)
Enables or disables validation.
Definition XMLSubSys.cpp:83
@ SEL_THREAD_EVENT
Definition fxexdefs.h:173
@ SEL_THREAD
Definition fxexdefs.h:155
DemandViewOptions demandViewOptions
demand view options
FXMenuCheck * menuCheckAllowUndoRedo
checkBox for allow undo-redo
NetworkViewOptions networkViewOptions
network view options
void buildUndoRedoMenuCommands(FXMenuPane *editMenu)
build undo-redo menu commands
void buildViewMenuCommands(FXMenuPane *editMenu)
build view menu commands
FXMenuCheck * loadAdditionalsInSUMOGUI
menu check for load additionals in SUMO GUI
FXMenuCommand * undoLastChange
FXMenuCommand for undo last change.
FXMenuCommand * toggleFrontElement
FXMenuCommand for toggle front element.
FXMenuCheck * loadDemandInSUMOGUI
menu check for load demand in SUMO GUI
FXMenuCommand * redoLastChange
FXMenuCommand for redo last change.
void buildOpenSUMOMenuCommands(FXMenuPane *editMenu)
build open sumo menu commands
void buildFrontElementMenuCommand(FXMenuPane *editMenu)
build front element commands
void buildFileMenuCommands(FXMenuPane *fileMenu, FXMenuPane *fileMenuNEEDITConfig, FXMenuPane *fileMenuSumoConfig, FXMenuPane *fileMenuTLS, FXMenuPane *fileMenuEdgeTypes, FXMenuPane *fileMenuAdditionals, FXMenuPane *fileMenuDemandElements, FXMenuPane *fileMenuDataElements, FXMenuPane *fileMenuMeanDataElements)
build menu commands
FXMenuCheck * menuCheckAllowUndoRedoLoading
checkBox for allow undo-redo loading
void buildHelpMenuCommands(FXMenuPane *helpMenu)
build menu commands
void buildLocateMenuCommands(FXMenuPane *locateMenu)
build menu commands
void buildLockMenuCommands(FXMenuPane *editMenu)
build menu commands
MFXMenuCheckIcon * menuCheckLockConnections
menu check to lock connections
void hideNetworkLockMenuCommands()
show network processing menu commands
MFXMenuCheckIcon * menuCheckLockPersons
menu check to lock persons
MFXMenuCheckIcon * menuCheckLockVehicles
menu check to lock vehicles
MFXMenuCheckIcon * menuCheckLockCrossings
menu check to lock crossings
MFXMenuCheckIcon * menuCheckLockTAZs
menu check to lock TAZs
void hideDemandLockMenuCommands()
show demand processing menu commands
MFXMenuCheckIcon * menuCheckLockEdgeTAZRels
menu check to lock edgeTAZRels
void hideDataLockMenuCommands()
show data processing menu commands
void showDataLockMenuCommands()
show data processing menu commands
MFXMenuCheckIcon * menuCheckLockPersonTrips
menu check to lock personTrips
MFXMenuCheckIcon * menuCheckLockWires
menu check to lock Wires
MFXMenuCheckIcon * menuCheckLockPOIs
menu check to lock POIs
MFXMenuCheckIcon * menuCheckLockPolygons
menu check to lock polygons
MFXMenuCheckIcon * menuCheckLockWalkingAreas
menu check to lock walkingAreas
MFXMenuCheckIcon * menuCheckLockEdges
menu check to lock edges
MFXMenuCheckIcon * menuCheckLockRides
menu check to lock rides
MFXMenuCheckIcon * menuCheckLockContainers
menu check to lock containers
MFXMenuCheckIcon * menuCheckLockJpsWalkableAreas
menu check to lock jps walkableareas
MFXMenuCheckIcon * menuCheckLockEdgeRelDatas
menu check to lock edgeRelDatas
MFXMenuCheckIcon * menuCheckLockStops
menu check to lock stops
MFXMenuCheckIcon * menuCheckLockLanes
menu check to lock lanes
MFXMenuCheckIcon * menuCheckLockAdditionals
menu check to lock additionals
void showNetworkLockMenuCommands()
show network processing menu commands
MFXMenuCheckIcon * menuCheckLockWalks
menu check to lock walks
MFXMenuCheckIcon * menuCheckLockJpsObstacles
menu check to lock jps obstacles
void showDemandLockMenuCommands()
show demand processing menu commands
MFXMenuCheckIcon * menuCheckLockTranships
menu check to lock tranships
MFXMenuCheckIcon * menuCheckLockTransports
menu check to lock transports
void buildRecentConfigFiles(FXMenuPane *fileMenu, FXMenuPane *fileMenuRecentConfigFiles)
build recent config
MFXRecentNetworks myRecentConfigs
List of recent configs.
MFXRecentNetworks myRecentNetworks
List of recent networks.
void buildRecentNetworkFiles(FXMenuPane *fileMenu, FXMenuPane *fileMenuRecentNetworkFiles)
build recent network
void buildModesMenuCommands(FXMenuPane *modesMenu)
build modes menu commands
DemandMenuCommands demandMenuCommands
Demand Menu Commands.
void setDefaultView(Supermode supermode)
set default view
void setJuPedSimView(Supermode supermode)
set JuPedSim view
NetworkMenuCommands networkMenuCommands
Network Menu Commands.
void showDataProcessingMenuCommands()
show data processing menu commands
MFXMenuCheckIcon * menuCheckRecomputeDataMode
checkBox for recomputing when changing data mode
void showDemandProcessingMenuCommands()
show demand processing menu commands
void hideDemandProcessingMenuCommands()
show demand processing menu commands
void hideDataProcessingMenuCommands()
show data processing menu commands
void buildProcessingMenuCommands(FXMenuPane *processingMenu)
build menu commands
void showNetworkProcessingMenuCommands()
show network processing menu commands
void hideNetworkProcessingMenuCommands()
show network processing menu commands
void buildSupermodeCommands(FXMenuPane *editMenu)
build menu commands
FXMenuBar * menu
The application menu bar (for file, edit, processing...)
long postProcessing(FXObject *menuCommand) const
run postprocessing
void buildTools(FXMenuPane *toolsMenu, const std::map< std::string, FXMenuPane * > &menuPaneToolMaps)
build tools (and menu commands)
long runToolDialog(FXObject *menuCommand) const
run tool dialog
void buildWindowsMenuCommands(FXMenuPane *windowsMenu, FXStatusBar *statusbar, GUIMessageWindow *messageWindow)
build menu commands
static bool toggleEditOptionsDemand(GNEViewNet *viewNet, const MFXCheckableButton *menuCheck, FXObject *obj, FXSelector sel)
toggle edit options Demand menu commands (called in GNEApplicationWindow::onCmdToggleEditOptions)
static bool toggleEditOptionsData(GNEViewNet *viewNet, const MFXCheckableButton *menuCheck, FXObject *obj, FXSelector sel)
toggle edit options Data menu commands (called in GNEApplicationWindow::onCmdToggleEditOptions)
static bool toggleEditOptionsNetwork(GNEViewNet *viewNet, const MFXCheckableButton *menuCheck, FXObject *obj, FXSelector sel)
toggle edit options Network menu commands (called in GNEApplicationWindow::onCmdToggleEditOptions)
MFXCheckableButton * menuCheckToggleTAZDrawFill
menu check to toggle TAZ draw fill
MFXCheckableButton * menuCheckShowAdditionals
menu check to show Additionals
MFXCheckableButton * menuCheckShowShapes
menu check to show Shapes
MFXCheckableButton * menuCheckToggleTAZRelOnlyFrom
menu check to toggle TAZRel only from
MFXCheckableButton * menuCheckToggleDrawJunctionShape
checkable button to show junction shapes
void getVisibleDataMenuCommands(std::vector< MFXCheckableButton * > &commands) const
get visible demand menu commands
MFXCheckableButton * menuCheckToggleTAZRelDrawing
menu check to toggle TAZ Rel drawing
MFXCheckableButton * menuCheckShowDemandElements
menu check to show Demand Elements
MFXCheckableButton * menuCheckToggleTAZRelOnlyTo
menu check to toggle TAZRel only to
MFXCheckableButton * menuCheckShowAllTrips
show all trips
MFXCheckableButton * menuCheckToggleGrid
menu check to show grid button
MFXCheckableButton * menuCheckToggleDrawJunctionShape
checkable button to show junction shapes
MFXCheckableButton * menuCheckDrawSpreadVehicles
menu check to draw vehicles in begin position or spread in lane
MFXCheckableButton * menuCheckShowOverlappedRoutes
show overlapped routes
MFXCheckableButton * menuCheckShowAllPersonPlans
show all person plans
MFXCheckableButton * menuCheckShowAllContainerPlans
show all container plans
MFXCheckableButton * menuCheckHideNonInspectedDemandElements
Hide non inspected demand elements.
MFXCheckableButton * menuCheckHideShapes
Hide shapes (Polygons and POIs)
MFXCheckableButton * menuCheckLockPerson
Lock Person.
void getVisibleDemandMenuCommands(std::vector< MFXCheckableButton * > &commands) const
get visible demand menu commands
MFXCheckableButton * menuCheckLockContainer
Lock Container.
DataEditMode dataEditMode
the current Data edit mode
bool isDefaultView() const
check if default view is enabled
DemandEditMode demandEditMode
the current Demand edit mode
Supermode currentSupermode
the current supermode
NetworkEditMode networkEditMode
the current Network edit mode
bool isCurrentSupermodeDemand() const
@check if current supermode is Demand
bool isCurrentSupermodeData() const
@check if current supermode is Data
bool isCurrentSupermodeNetwork() const
@check if current supermode is Network
bool isJuPedSimView() const
check if default view is enabled
MFXCheckableButton * menuCheckSelectEdges
checkable button to select only edges
MFXCheckableButton * menuCheckChainEdges
checkable button to the endpoint for a created edge should be set as the new source
MFXCheckableButton * menuCheckShowDemandElements
checkable button to show Demand Elements
MFXCheckableButton * menuCheckMoveElevation
checkable button to apply movement to elevation
MFXCheckableButton * menuCheckShowTAZElements
checkable button to show TAZ elements
void getVisibleNetworkMenuCommands(std::vector< MFXCheckableButton * > &commands) const
get visible network menu commands
MFXCheckableButton * menuCheckAutoOppositeEdge
check checkable to create auto create opposite edge
MFXCheckableButton * menuCheckDrawSpreadVehicles
checkable button to draw vehicles in begin position or spread in lane
MFXCheckableButton * menuCheckShowConnections
checkable button to show connections
MFXCheckableButton * menuCheckHideConnections
checkable button to hide connections in connect mode
MFXCheckableButton * menuCheckToggleDrawJunctionShape
checkable button to show junction shapes
MFXCheckableButton * menuCheckToggleGrid
checkable button to show grid button
MFXCheckableButton * menuCheckMergeAutomatically
checkable button to we should't warn about merging junctions
MFXCheckableButton * menuCheckShowJunctionBubble
checkable button to show connection as bubble in "Move" mode.
MFXCheckableButton * menuCheckShowAdditionalSubElements
checkable button to show additional sub-elements
MFXCheckableButton * menuCheckChangeAllPhases
checkable button to set change all phases
MFXCheckableButton * menuCheckExtendSelection
checkable button to extend to edge nodes
void setSaveIndividualFiles(bool value)
enable or disable save individual files
void switchTimeFormat()
switch time format
void updateButtonLabel()
update button label