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-2025 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
480 // tools
483 // other
484 FXMAPFUNC(SEL_CLIPBOARD_REQUEST, 0, GNEApplicationWindow::onClipboardRequest),
491 FXMAPFUNC(SEL_COMMAND, MID_RUNTESTS, GNEApplicationWindow::onCmdRunTests),
492};
493
494// Object implementation
495FXIMPLEMENT(GNEApplicationWindow, FXMainWindow, GNEApplicationWindowMap, ARRAYNUMBER(GNEApplicationWindowMap))
496
497// ===========================================================================
498// GNEApplicationWindow method definitions
499// ===========================================================================
500#ifdef _MSC_VER
501#pragma warning(push)
502#pragma warning(disable: 4355) // mask warning about "this" in initializers
503#endif
504GNEApplicationWindow::GNEApplicationWindow(FXApp* app, const GNETagPropertiesDatabase* tagPropertiesDatabase, const std::string& configPattern) :
505 GUIMainWindow(app),
506 myTagPropertiesDatabase(tagPropertiesDatabase),
507 myUndoList(new GNEUndoList(this)),
508 myConfigPattern(configPattern),
509 myToolbarsGrip(this),
510 myMenuBarFile(this),
511 myFileMenuCommands(this),
512 myModesMenuCommands(this),
513 myEditMenuCommands(this),
514 myLockMenuCommands(this),
515 myProcessingMenuCommands(this),
516 myLocateMenuCommands(this),
517 myToolsMenuCommands(this),
518 myWindowsMenuCommands(this),
519 myHelpMenuCommands(this),
520 mySupermodeCommands(this),
521 myFileBucketHandler(new GNEApplicationWindowHelper::FileBucketHandler(this, OptionsCont::getOptions(), mySumoOptions)),
522 myTitlePrefix("netedit " VERSION_STRING),
523 myAllowUndoRedo(getApp()->reg().readBoolEntry("NETEDIT", "AllowUndoRedo", true) == TRUE),
524 myAllowUndoRedoLoading(getApp()->reg().readBoolEntry("NETEDIT", "AllowUndoRedoLoading", true) == TRUE) {
525 // init icons
527 // init Textures
529 // init cursors
531 // set tooltip options
532 app->setTooltipTime(1000000000);
533 app->setTooltipPause(1000000000);
534 // set SUMO Options descriptions
535 mySumoOptions.setApplicationDescription(TL("A microscopic, multi-modal traffic simulation."));
536 mySumoOptions.setApplicationName("sumo", "Eclipse SUMO sumo " VERSION_STRING);
537 // set default netedit options
540 // parse options
546 // add extra option for automatic closing
547 myNetgenerateOptions.doRegister("close-dialog-automatic", new Option_Bool(true));
548 myNetgenerateOptions.addDescription("close-dialog-automatic", "report", TL("Close dialog automatically"));
549}
550#ifdef _MSC_VER
551#pragma warning(pop)
552#endif
553
554
555void
557 // do this not twice
559 // do not translate debug messages
560 WRITE_ERROR("DEBUG: GNEApplicationWindow::dependentBuild called twice");
561 return;
562 }
563 myHadDependentBuild = true;
564 setTarget(this);
565 setSelector(MID_WINDOW);
566 // build toolbar menu
568 // build the thread - io
571 // build the status bar
572 myStatusbar = new FXStatusBar(this, GUIDesignStatusBar);
573 // build geo coordinates label
574 auto requireRecomputingFrame = new FXHorizontalFrame(myStatusbar, GUIDesignHorizontalFrameStatusBar);
576 TL("Recomputing"), nullptr, this, MID_GNE_RECOMPUTINGNEEDED, GUIDesignButtonStatusBarFixed);
577 myRequireRecomputingButton->setHelpText(TL("Recomputing is needed"));
578 // build geo coordinates label
580 myGeoCoordinate = new FXLabel(myGeoFrame, TL("N/A"), nullptr, GUIDesignLabelStatusBar);
581 myGeoCoordinate->setHelpText(TL("Original coordinate (before coordinate transformation in netconvert)"));
582 // build cartesian coordinates label
584 myCartesianCoordinate = new FXLabel(myCartesianFrame, TL("N/A"), nullptr, GUIDesignLabelStatusBar);
585 myCartesianCoordinate->setHelpText(TL("Network coordinate"));
586 // build test coordinates label (only if gui-testing is enabled)
588 myTestCoordinate = new FXLabel(myTestFrame, TL("N/A"), nullptr, GUIDesignLabelStatusBar);
589 myTestCoordinate->setHelpText(TL("Test coordinate"));
591 myTestFrame->hide();
592 // make the window a mdi-window
593 myMainSplitter = new FXSplitter(this, GUIDesignSplitter | SPLITTER_VERTICAL | SPLITTER_REVERSED);
595 myMDIMenu = new FXMDIMenu(this, myMDIClient);
596 // build the message window
598 myMainSplitter->setSplit(1, 65);
599 // fill menu and tool bar
600 fillMenuBar();
601 // build additional threads
603 // check if create internal test system
604 if (OptionsCont::getOptions().getString("test-file").size() > 0) {
605 myInternalTest = new GNEInternalTest(OptionsCont::getOptions().getString("test-file"));
606 }
607 // set the status bar
608 setStatusBarText(TL("Ready."));
609 // set the caption
610 setTitle(myTitlePrefix);
611 // set Netedit ICON
614 // build netedit Accelerators (hotkeys)
615 GUIShortcutsSubSys::buildAccelerators(getAccelTable(), this, false);
616}
617
618
619void
621 // set windows size and position
623 // set current folder
624 gCurrentFolder = getApp()->reg().readStringEntry("SETTINGS", "basedir", "");
625 // Create main window
626 FXMainWindow::create();
627 // get text width
628 const auto textWidth = getApp()->getNormalFont()->getTextWidth("8", 1) * 22;
629 // adjust cartesian and geo frame
630 myCartesianFrame->setWidth(textWidth);
631 myGeoFrame->setWidth(textWidth);
632 // fill online maps
633 if (myOnlineMaps.empty()) {
634 myOnlineMaps["GeoHack"] = "https://geohack.toolforge.org/geohack.php?params=%lat;%lon_scale:1000";
635 myOnlineMaps["Google Maps"] = "https://www.google.com/maps?ll=%lat,%lon&t=h&z=18";
636 myOnlineMaps["OSM"] = "https://www.openstreetmap.org/?mlat=%lat&mlon=%lon&zoom=18&layers=M";
637 }
638 // show application windows
639 show(PLACEMENT_DEFAULT);
640 // check if maximice
641 if (!OptionsCont::getOptions().isSet("window-size")) {
642 if (getApp()->reg().readIntEntry("SETTINGS", "maximized", 0) == 1) {
643 maximize();
644 }
645 }
646}
647
648
650 closeAllWindows(true);
651 // Close icons
653 // Close gifs (Textures)
656 // delete visuals
657 delete myGLVisual;
658 // must delete menus to avoid segfault on removing accelerators
659 // (http://www.fox-toolkit.net/faq#TOC-What-happens-when-the-application-s)
662 delete myFileMenuTLS;
663 delete myFileMenuEdgeTypes;
670 delete myFileMenu;
671 delete myModesMenu;
672 delete myEditMenu;
673 delete myLockMenu;
674 delete myProcessingMenu;
675 delete myLocatorMenu;
676 delete myToolsMenu;
677 delete myToolsDetectorMenu;
678 delete myToolsDistrictMenu;
679 delete myToolsDRTMenu;
681 delete myToolsImportMenu;
684 delete myToolsImportVissim;
685 delete myToolsImportVisum;
686 delete myToolsNetMenu;
687 delete myToolsRouteMenu;
688 delete myToolsOutputMenu;
689 delete myToolsShapes;
690 delete myToolsTLS;
691 delete myToolsTurnDefs;
693 delete myToolsXML;
694 delete myWindowMenu;
695 delete myHelpMenu;
696 delete myLanguageMenu;
697 // Delete load thread
698 delete myLoadThread;
699 if (myInternalTest) {
700 delete myInternalTest;
701 }
702 // drop all events
703 while (!myThreadEvents.empty()) {
704 // get the next event
707 delete e;
708 }
709 // delete undoList and dialog
710 delete myUndoList;
711}
712
713
714long
715GNEApplicationWindow::onCmdQuit(FXObject* sender, FXSelector sel, void* ptr) {
716 if (askSaveElements(sender, sel, ptr)) {
718 getApp()->reg().writeStringEntry("SETTINGS", "basedir", gCurrentFolder.text());
719 if (isMaximized()) {
720 getApp()->reg().writeIntEntry("SETTINGS", "maximized", 1);
721 } else {
722 getApp()->reg().writeIntEntry("SETTINGS", "maximized", 0);
723 }
724 getApp()->exit(0);
725 }
726 return 1;
727}
728
729
730long
731GNEApplicationWindow::onCmdEditChosen(FXObject*, FXSelector, void*) {
732 GUIDialog_GLChosenEditor* chooser =
734 chooser->create();
735 chooser->show();
736 return 1;
737}
738
739
740long
741GNEApplicationWindow::onCmdNewNetwork(FXObject*, FXSelector, void*) {
742 // check if close current simulation
743 if (onCmdClose(0, 0, 0) == 1) {
744 // create new network
746 }
747 return 1;
748}
749
750
751long
753 auto& neteditOptions = OptionsCont::getOptions();
754 // get netconvert file dialog
755 const GNEFileDialog netConvertFileDialog(this, TL("netconvert config file"),
760 // continue depending of dialog
761 if ((netConvertFileDialog.getResult() == GNEDialog::Result::ACCEPT) && (onCmdClose(0, 0, 0) == 1)) {
762 // stop test before calling load thread
763 if (myInternalTest) {
765 }
766 // reset netedit options
767 myLoadThread->fillOptions(neteditOptions);
768 myLoadThread->setDefaultOptions(neteditOptions);
769 // set netconvert configuration file to load
770 neteditOptions.resetWritable();
771 neteditOptions.set("netccfg-file", netConvertFileDialog.getFilename());
772 // run load thread
774 // update view
775 update();
776 }
777 return 1;
778}
779
780
781long
782GNEApplicationWindow::onCmdOpenNetwork(FXObject*, FXSelector, void*) {
783 // get netconvert filename
784 const GNEFileDialog networkFileDialog(this, TL("network file"),
789 // continue depending of dialog
790 if ((networkFileDialog.getResult() == GNEDialog::Result::ACCEPT) && (onCmdClose(0, 0, 0) == 1)) {
791 // load network
792 loadNetwork(networkFileDialog.getFilename());
793 }
794 return 0;
795}
796
797
798long
799GNEApplicationWindow::onCmdOpenForeign(FXObject*, FXSelector, void*) {
800 // get OSM file dilaog
801 const GNEFileDialog OSMFileDialog(this, TL("OpenStreetMap file"),
806 // continue depending of dialog
807 if ((OSMFileDialog.getResult() == GNEDialog::Result::ACCEPT) && (onCmdClose(0, 0, 0) == 1)) {
808 loadOSM(OSMFileDialog.getFilename());
809 }
810 return 1;
811}
812
813
814long
815GNEApplicationWindow::onCmdOpenNeteditConfig(FXObject*, FXSelector, void*) {
816 auto& neteditOptions = OptionsCont::getOptions();
817 // get netconvert filename
818 const GNEFileDialog neteditConfigFileDialog(this, TL("netedit config file"),
823 // continue depending of dialog
824 if ((neteditConfigFileDialog.getResult() == GNEDialog::Result::ACCEPT) && (onCmdClose(0, 0, 0) == 1)) {
825 // stop test before calling load thread
826 if (myInternalTest) {
828 }
829 // reset netedit options
830 myLoadThread->fillOptions(neteditOptions);
831 myLoadThread->setDefaultOptions(neteditOptions);
832 // set netedit configuration file to load
833 neteditOptions.resetWritable();
834 neteditOptions.set("netecfg-file", neteditConfigFileDialog.getFilename());
835 // run load thread
837 // update view
838 update();
839 }
840 return 1;
841}
842
843
844long
845GNEApplicationWindow::onCmdOpenSumoConfig(FXObject*, FXSelector, void*) {
846 auto& neteditOptions = OptionsCont::getOptions();
847 // get netconvert filename
848 const GNEFileDialog sumoConfigFileDialog(this, TL("sumo config file"),
853 // continue depending of dialog
854 if ((sumoConfigFileDialog.getResult() == GNEDialog::Result::ACCEPT) && (onCmdClose(0, 0, 0) == 1)) {
855 // stop test before calling load thread
856 if (myInternalTest) {
858 }
859 // reset options
860 myLoadThread->fillOptions(neteditOptions);
861 myLoadThread->setDefaultOptions(neteditOptions);
862 // set sumo configuration file to load
863 neteditOptions.resetWritable();
864 neteditOptions.set("sumocfg-file", sumoConfigFileDialog.getFilename());
865 // run load thread
867 // update view
868 update();
869 }
870 return 1;
871}
872
873
874long
876 // get existent configuration file
878 // check if close current simulation
879 if (onCmdClose(0, 0, 0) == 1) {
880 // stop test before calling load thread
881 if (myInternalTest) {
883 }
884 auto& neteditOptions = OptionsCont::getOptions();
885 // reset options
886 myLoadThread->fillOptions(neteditOptions);
887 myLoadThread->setDefaultOptions(neteditOptions);
888 // set netedit configuration file to load
889 neteditOptions.resetWritable();
890 neteditOptions.set("netecfg-file", neteditConfigFile);
891 // run load thread
893 // update view
894 update();
895 }
896 return 1;
897}
898
899
900long
901GNEApplicationWindow::onCmdReloadSumoConfig(FXObject*, FXSelector, void*) {
902 // get existent sumo config file
904 // check if close current simulation
905 if (onCmdClose(0, 0, 0) == 1) {
906 // stop test before calling load thread
907 if (myInternalTest) {
909 }
910 auto& neteditOptions = OptionsCont::getOptions();
911 // reset options
912 myLoadThread->fillOptions(neteditOptions);
913 myLoadThread->setDefaultOptions(neteditOptions);
914 // set configuration file to load
915 neteditOptions.resetWritable();
916 neteditOptions.set("sumocfg-file", sumoConfigFile);
917 // run load thread
919 // update view
920 update();
921 }
922 return 1;
923}
924
925
926long
927GNEApplicationWindow::onUpdReloadNeteditConfig(FXObject* sender, FXSelector, void*) {
928 // check if file exist
930 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
931 } else {
932 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
933 }
934}
935
936
937long
938GNEApplicationWindow::onUpdReloadSumoConfig(FXObject* sender, FXSelector, void*) {
939 // check if file exist
941 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
942 } else {
943 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
944 }
945}
946
947
948long
949GNEApplicationWindow::onCmdOpenTLSPrograms(FXObject*, FXSelector, void*) {
950 // get netconvert filename
951 const GNEFileDialog TLSfileDialog(this, TL("Traffic Light definitions file"),
956 // continue depending of dialog
957 if (TLSfileDialog.getResult() == GNEDialog::Result::ACCEPT) {
958 // set tls type in bucket
960 // load traffic lights
961 loadTrafficLights("loading");
962 }
963 return 1;
964}
965
966
967long
968GNEApplicationWindow::onCmdReloadTLSPrograms(FXObject*, FXSelector, void*) {
969 // load traffic lights
970 loadTrafficLights("reloading");
971 return 1;
972}
973
974
975long
976GNEApplicationWindow::onUpdReloadTLSPrograms(FXObject* sender, FXSelector, void*) {
977 // check if file exist
979 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
980 } else {
981 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
982 }
983}
984
985
986long
987GNEApplicationWindow::onCmdOpenEdgeTypes(FXObject*, FXSelector, void*) {
988 // get netconvert filename
989 const GNEFileDialog edgeTypesFileDialog(this, TL("EdgeTypes file"),
994 // continue depending of dialog
995 if (edgeTypesFileDialog.getResult() == GNEDialog::Result::ACCEPT) {
996 // set tls type in bucket
998 // load edge types
999 loadEdgeTypes("loading");
1000 }
1001 return 1;
1002}
1003
1004
1005long
1006GNEApplicationWindow::onCmdReloadEdgeTypes(FXObject*, FXSelector, void*) {
1007 // load edge types
1008 loadEdgeTypes("reloading");
1009 return 0;
1010}
1011
1012
1013long
1014GNEApplicationWindow::onUpdReloadEdgeTypes(FXObject* sender, FXSelector, void*) {
1015 // check if file exist
1017 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
1018 } else {
1019 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
1020 }
1021}
1022
1023
1024long
1025GNEApplicationWindow::onCmdSmartReload(FXObject*, FXSelector sel, void*) {
1026 auto& neteditOptions = OptionsCont::getOptions();
1027 // check if close current file
1028 if (onCmdClose(0, sel, 0) == 1) {
1029 // stop test before calling load thread
1030 if (myInternalTest) {
1032 }
1033 // store size, position and viewport
1035 gSchemeStorage.saveViewport(0, 0, -1, 0); // recenter view
1036 // set flag
1037 myAmLoading = true;
1038 // get files
1042 // fill (reset) all options
1043 myLoadThread->fillOptions(neteditOptions);
1044 // set default options defined in GNELoadThread::setDefaultOptions(...)
1045 myLoadThread->setDefaultOptions(neteditOptions);
1046 // set file to load
1047 neteditOptions.resetWritable();
1048 if (neteditConfig.size() > 0) {
1049 // set netedit config
1051 // set status bar
1052 setStatusBarText(TLF("Reloading netedit config file '%'", neteditConfig));
1053 } else if (sumoConfig.size() > 0) {
1054 // set sumo config
1056 // set status bar
1057 setStatusBarText(TLF("Reloading sumo config file '%'", sumoConfig));
1058 } else if (networkFile.size() > 0) {
1059 // set network config
1061 // set status bar
1062 setStatusBarText(TLF("Reloading network file '%'", networkFile));
1063 } else {
1064 // nothing to load
1065 return 0;
1066 }
1067 // load network
1069 }
1070 return 1;
1071}
1072
1073
1074long
1075GNEApplicationWindow::onUpdSmartReload(FXObject* sender, FXSelector, void*) {
1076 // declare strings
1077 FXString neteditConfig = TL("&Reload Netedit config");
1078 FXString sumoConfig = TL("&Reload Sumo config");
1079 FXString netFile = TL("&Reload Network");
1080 FXString reload = TL("&Reload");
1081 // check options
1082 if (myNet == nullptr) {
1083 sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
1084 sender->handle(this, FXSEL(SEL_COMMAND, ID_SETSTRINGVALUE), &reload);
1086 sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
1087 sender->handle(this, FXSEL(SEL_COMMAND, ID_SETSTRINGVALUE), &neteditConfig);
1089 sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
1090 sender->handle(this, FXSEL(SEL_COMMAND, ID_SETSTRINGVALUE), &sumoConfig);
1092 sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
1093 sender->handle(this, FXSEL(SEL_COMMAND, ID_SETSTRINGVALUE), &netFile);
1094 } else {
1095 sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
1096 sender->handle(this, FXSEL(SEL_COMMAND, ID_SETSTRINGVALUE), &reload);
1097 }
1098 return 1;
1099}
1100
1101
1102long
1103GNEApplicationWindow::onCmdReloadNetwork(FXObject*, FXSelector sel, void*) {
1104 auto& neteditOptions = OptionsCont::getOptions();
1105 // check if close current file
1106 if (onCmdClose(0, sel, 0) == 1) {
1107 // stop test before calling load thread
1108 if (myInternalTest) {
1110 }
1111 // store size, position and viewport
1113 gSchemeStorage.saveViewport(0, 0, -1, 0); // recenter view
1114 // set flag
1115 myAmLoading = true;
1116 // get network
1117 const std::string networkFile = myFileBucketHandler->getDefaultFilename(FileBucket::Type::NETWORK);
1118 // fill (reset) all options
1119 myLoadThread->fillOptions(neteditOptions);
1120 // set default options defined in GNELoadThread::setDefaultOptions(...)
1121 myLoadThread->setDefaultOptions(neteditOptions);
1122 // set file to load
1124 // set status bar
1125 setStatusBarText(TLF("Reloading network file '%'", networkFile));
1126 // loaad network
1128 }
1129 return 1;
1130}
1131
1132
1133long
1134GNEApplicationWindow::onUpdReloadNetwork(FXObject* sender, FXSelector, void*) {
1135 if (myNet == nullptr) {
1136 sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
1137 sender->handle(this, FXSEL(SEL_COMMAND, ID_HIDE), nullptr);
1140 sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
1141 sender->handle(this, FXSEL(SEL_COMMAND, ID_SHOW), nullptr);
1142 } else {
1143 sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
1144 sender->handle(this, FXSEL(SEL_COMMAND, ID_HIDE), nullptr);
1145 }
1146 return 1;
1147}
1148
1149
1150long
1151GNEApplicationWindow::onCmdOpenRecent(FXObject*, FXSelector, void* fileData) {
1152 // first check that current edited Net can be closed (und therefore the undo-list cleared, see #5753)
1153 if (myAmLoading) {
1154 myStatusbar->getStatusLine()->setText(TL("Already loading!"));
1155 } else if (onCmdClose(0, 0, 0) == 1) {
1156 // get filedata
1157 const std::string recentFile = ((const char*)fileData);
1158 // check if we're loading a network o a config
1159 if ((recentFile.find(".netecfg") != std::string::npos) ||
1160 (recentFile.find(".sumocfg") != std::string::npos) ||
1161 (recentFile.find(".netccfg") != std::string::npos)) {
1162 // load config
1163 loadConfiguration(recentFile);
1164 } else {
1165 // load network
1166 loadNetwork(recentFile);
1167 }
1168 }
1169 return 1;
1170}
1171
1172
1173long
1174GNEApplicationWindow::onCmdClose(FXObject* sender, FXSelector sel, void* ptr) {
1175 if (myViewNet == nullptr) {
1176 return 1;
1177 } else if (askSaveElements(sender, sel, ptr)) {
1178 // check if is reloading
1179 const bool reloading = (FXSELID(sel) == MID_GNE_TOOLBARFILE_RELOADNETWORK) || (FXSELID(sel) == MID_HOTKEY_CTRL_R_RELOAD);
1180 // close all windows
1181 closeAllWindows(!reloading);
1182 // add a separator to the log
1184 // hide all menu commands
1188 // hide view options
1192 return 1;
1193 } else {
1194 return 0;
1195 }
1196}
1197
1198
1199long
1200GNEApplicationWindow::onCmdLocate(FXObject*, FXSelector sel, void*) {
1201 if (myMDIClient->numChildren() > 0) {
1202 GNEViewParent* w = dynamic_cast<GNEViewParent*>(myMDIClient->getActiveChild());
1203 if (w != nullptr) {
1204 w->onCmdLocate(nullptr, sel, nullptr);
1205 }
1206 }
1207 return 1;
1208}
1209
1210
1211long
1212GNEApplicationWindow::onCmdOpenPythonToolDialog(FXObject* obj, FXSelector, void*) {
1213 return myToolsMenuCommands.showTool(obj);
1214}
1215
1216
1217long
1218GNEApplicationWindow::onCmdRunPythonTool(FXObject* obj, FXSelector, void*) {
1220}
1221
1222
1223long
1226}
1227
1228
1229long
1230GNEApplicationWindow::onUpdPythonTool(FXObject*, FXSelector, void*) {
1231 // currently always enabled
1232 return 1;
1233}
1234
1235
1236long
1237GNEApplicationWindow::onUpdOpen(FXObject* sender, FXSelector, void*) {
1238 sender->handle(this, myAmLoading ? FXSEL(SEL_COMMAND, ID_DISABLE) : FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
1239 return 1;
1240}
1241
1242
1243long
1244GNEApplicationWindow::onCmdClearMsgWindow(FXObject*, FXSelector, void*) {
1246 return 1;
1247}
1248
1249
1250long
1252 return 1;
1253}
1254
1255
1256long
1258 return 1;
1259}
1260
1261
1262long
1263GNEApplicationWindow::onCmdAbout(FXObject*, FXSelector, void*) {
1264 // create and open about dialog
1265 GNEAboutDialog(this);
1266 return 1;
1267}
1268
1269
1270long GNEApplicationWindow::onClipboardRequest(FXObject*, FXSelector, void* ptr) {
1271 FXEvent* event = (FXEvent*)ptr;
1272 FXString string = GUIUserIO::clipped.c_str();
1273 setDNDData(FROM_CLIPBOARD, event->target, string);
1274 return 1;
1275}
1276
1277
1278long
1279GNEApplicationWindow::onLoadThreadEvent(FXObject*, FXSelector, void*) {
1280 eventOccurred();
1281 return 1;
1282}
1283
1284
1285void
1287 // load events
1288 while (!myThreadEvents.empty()) {
1289 // get the next event
1292 // process
1293 switch (e->getOwnType()) {
1296 break;
1303 break;
1304 default:
1305 break;
1306 }
1307 delete e;
1308 }
1309}
1310
1311
1312void
1314 myAmLoading = false;
1315 GNEEvent_FileLoaded* fileLoadedEvent = static_cast<GNEEvent_FileLoaded*>(e);
1316 // check whether the loading was successful
1317 if (fileLoadedEvent->getNet() == nullptr) {
1318 // report failure
1319 std::string failureMessage;
1320 switch (fileLoadedEvent->getType()) {
1322 failureMessage = TLF("Loading of netedit config '%' failed", fileLoadedEvent->getFile());
1323 break;
1325 failureMessage = TLF("Loading of sumo config '%' failed", fileLoadedEvent->getFile());
1326 break;
1328 failureMessage = TLF("Loading of netconvert config '%' failed", fileLoadedEvent->getFile());
1329 break;
1331 failureMessage = TLF("Loading of network '%' failed", fileLoadedEvent->getFile());
1332 break;
1334 failureMessage = TLF("Loading of OSM Network '%' failed", fileLoadedEvent->getFile());
1335 break;
1337 failureMessage = TL("Invalid Options. Nothing loaded");
1338 break;
1340 failureMessage = TL("Could not build projection. Nothing loaded");
1341 break;
1343 failureMessage = TL("Invalid extension for config file. Only .netecfg, .sumocfg or .netccfg are allowed");
1344 break;
1345 default:
1346 failureMessage = TL("Invalid input network option. Load with either sumo/netedit/netconvert config or with --new option");
1347 break;
1348 }
1349 // write info
1350 WRITE_ERROR(failureMessage);
1351 setStatusBarText(failureMessage);
1352 } else {
1353 // report success
1354 std::string successMessage;
1355 switch (fileLoadedEvent->getType()) {
1357 successMessage = TLF("Netedit config '%' loaded", fileLoadedEvent->getFile());
1358 break;
1360 successMessage = TLF("Sumo config '%' loaded", fileLoadedEvent->getFile());
1361 break;
1363 successMessage = TLF("Netconvert config '%' loaded", fileLoadedEvent->getFile());
1364 break;
1366 successMessage = TLF("Network '%' loaded", fileLoadedEvent->getFile());
1367 break;
1369 successMessage = TLF("OSM Network '%' loaded", fileLoadedEvent->getFile());
1370 break;
1372 successMessage = TLF("Network '%' loaded through console", fileLoadedEvent->getFile());
1373 break;
1375 successMessage = TL("New network successfully created");
1376 break;
1377 default:
1378 throw ProcessError("Invalid sucess mesage. Check if all cases were covered");
1379 }
1380 // write info
1381 WRITE_MESSAGE(successMessage);
1382 setStatusBarText(successMessage);
1383 // set new Net
1384 myNet = fileLoadedEvent->getNet();
1385 // set size and pos
1387 // build viewparent toolbar grips before creating view parent
1389 // initialise netedit View
1390 GNEViewParent* viewParent = new GNEViewParent(myMDIClient, myMDIMenu, "netedit VIEW", this, nullptr, myNet, myUndoList, nullptr, MDI_TRACKING, 10, 10, 300, 200);
1391 // create it maximized
1392 viewParent->maximize();
1393 // mark it as Active child
1394 myMDIClient->setActiveChild(viewParent);
1395 // cast pointer myViewNet
1396 myViewNet = dynamic_cast<GNEViewNet*>(viewParent->getView());
1397 // set settings in view
1398 if (viewParent->getView() && (fileLoadedEvent->getSettingsFile().size() > 0)) {
1399 GUISettingsHandler settings(fileLoadedEvent->getSettingsFile(), true, true);
1400 settings.addSettings(viewParent->getView());
1401 viewParent->getView()->addDecals(settings.getDecals());
1402 settings.applyViewport(viewParent->getView());
1403 settings.setSnapshots(viewParent->getView());
1404 }
1405 // set network name on the caption
1406 setTitle(MFXUtils::getTitleText(myTitlePrefix, fileLoadedEvent->getFile().c_str()));
1407 // force supermode network
1409 // update view port
1410 if (fileLoadedEvent->getViewportFromRegistry()) {
1411 Position off;
1412 off.set(getApp()->reg().readRealEntry("viewport", "x"), getApp()->reg().readRealEntry("viewport", "y"), getApp()->reg().readRealEntry("viewport", "z"));
1413 Position p(off.x(), off.y(), 0);
1414 myViewNet->setViewportFromToRot(off, p, 0);
1415 }
1416 // load elements
1417 loadAdditionalElements("loading");
1418 loadDemandElements("loading");
1419 loadDataElements("loading");
1420 loadMeanDataElements("loading");
1421 // load selection
1422 if (!OptionsCont::getOptions().isDefault("selection-file")) {
1424 }
1426 }
1428 // update app
1429 update();
1430 // restore focus
1431 setFocus();
1432}
1433
1434
1435void
1440
1441// ---------------------------------------------------------------------------
1442// private methods
1443// ---------------------------------------------------------------------------
1444
1445void
1447 // build file menu
1448 myFileMenu = new FXMenuPane(this, LAYOUT_FIX_HEIGHT);
1450 myFileMenuNeteditConfig = new FXMenuPane(this);
1451 myFileMenuSumoConfig = new FXMenuPane(this);
1452 myFileMenuTLS = new FXMenuPane(this);
1453 myFileMenuEdgeTypes = new FXMenuPane(this);
1454 myFileMenuAdditionals = new FXMenuPane(this);
1455 myFileMenuDemandElements = new FXMenuPane(this);
1456 myFileMenuDataElements = new FXMenuPane(this);
1457 myFileMenuMeanDataElements = new FXMenuPane(this);
1458 myFileMenuRecentNetworks = new FXMenuPane(this);
1459 myFileMenuRecentConfigs = new FXMenuPane(this);
1463 // add separator for recent files
1464 new FXMenuSeparator(myFileMenu);
1465 // build recent files
1468 new FXMenuSeparator(myFileMenu);
1469 GUIDesigns::buildFXMenuCommandShortcut(myFileMenu, TL("&Quit"), "Ctrl+Q", TL("Quit the Application."),
1470 nullptr, this, MID_HOTKEY_CTRL_Q_CLOSE);
1471 // build modes menu
1472 myModesMenu = new FXMenuPane(this);
1474 myModesMenuTitle->setTarget(this);
1476 // build Supermode commands and hide it
1478 // add separator
1479 new FXSeparator(myModesMenu);
1480 // build modes menu commands
1482 // build edit menu
1483 myEditMenu = new FXMenuPane(this);
1485 // build edit menu commands
1487 // build separator
1488 new FXMenuSeparator(myEditMenu);
1489 // build view options
1493 // hide view options
1497 // build view menu commands
1499 // build separator
1500 new FXMenuSeparator(myEditMenu);
1501 // build front element menu commands
1503 // build separator
1504 new FXMenuSeparator(myEditMenu);
1505 // build open in sumo menu commands
1507 // build lock menu
1508 myLockMenu = new FXMenuPane(this);
1510 myLockMenuTitle->setTarget(this);
1512 // build lock menu commands
1514 // build processing menu (trigger netbuild computations)
1515 myProcessingMenu = new FXMenuPane(this);
1518 // build locate menu
1519 myLocatorMenu = new FXMenuPane(this);
1522 // build tools menu
1523 myToolsMenu = new FXMenuPane(this);
1524 myToolsAssignMenu = new FXMenuPane(this);
1525 myToolsDetectorMenu = new FXMenuPane(this);
1526 myToolsDistrictMenu = new FXMenuPane(this);
1527 myToolsDRTMenu = new FXMenuPane(this);
1528 myToolsEmissionsMenu = new FXMenuPane(this);
1529 myToolsImportMenu = new FXMenuPane(this);
1530 myToolsImportCityBrainMenu = new FXMenuPane(this);
1531 myToolsImportGTFSMenu = new FXMenuPane(this);
1532 myToolsImportVissim = new FXMenuPane(this);
1533 myToolsImportVisum = new FXMenuPane(this);
1534 myToolsNetMenu = new FXMenuPane(this);
1535 myToolsRouteMenu = new FXMenuPane(this);
1536 myToolsOutputMenu = new FXMenuPane(this);
1537 myToolsShapes = new FXMenuPane(this);
1538 myToolsTLS = new FXMenuPane(this);
1539 myToolsTriggerMenu = new FXMenuPane(this);
1540 myToolsTurnDefs = new FXMenuPane(this);
1541 myToolsVisualizationMenu = new FXMenuPane(this);
1542 myToolsXML = new FXMenuPane(this);
1544 // build tools menu cascasde
1545 new FXMenuCascade(myToolsMenu, TL("Assign"), nullptr, myToolsAssignMenu);
1546 new FXMenuCascade(myToolsMenu, TL("Detectors"), GUIIconSubSys::getIcon(GUIIcon::E1), myToolsDetectorMenu);
1547 new FXMenuCascade(myToolsMenu, TL("Districts"), GUIIconSubSys::getIcon(GUIIcon::TAZ), myToolsDistrictMenu);
1549 //new FXMenuCascade(myToolsMenu, TL("Emissions"), GUIIconSubSys::getIcon(GUIIcon::TOOL_EMISSIONS), myToolsEmissionsMenu);
1558 //new FXMenuCascade(myToolsMenu, TL("Shapes"), GUIIconSubSys::getIcon(GUIIcon::MODESHAPE), myToolsShapes);
1559 new FXMenuCascade(myToolsMenu, TL("TLS"), GUIIconSubSys::getIcon(GUIIcon::MODETLS), myToolsTLS);
1560 new FXMenuCascade(myToolsMenu, TL("Trigger"), nullptr, myToolsTriggerMenu);
1564 // add separators between folders
1565 new FXMenuSeparator(myToolsMenu);
1566 new FXMenuSeparator(myToolsImportMenu);
1567 // create map with tool Menu panes and their associated folder
1574 myMenuPaneToolMaps["import/citybrain"] = myToolsImportCityBrainMenu;
1576 myMenuPaneToolMaps["import/vissim"] = myToolsImportVissim;
1577 myMenuPaneToolMaps["import/visum"] = myToolsImportVisum;
1584 myMenuPaneToolMaps["turn-defs"] = myToolsTurnDefs;
1587 // build tools
1589 // build windows menu
1590 myWindowMenu = new FXMenuPane(this);
1593 // build language menu
1595 // build help menu
1596 myHelpMenu = new FXMenuPane(this);
1599}
1600
1601
1602FXGLCanvas*
1604 // netedit uses only a single View, then return nullptr
1605 return nullptr;
1606}
1607
1608
1611 return 0;
1612}
1613
1614
1615double
1617 return 1;
1618}
1619
1620
1625
1626
1631
1632
1637
1638
1643
1644
1645void
1647 if (myViewNet && myViewNet->getNet()) {
1648 // show
1650 // set label depending of recomputing
1652 myRequireRecomputingButton->setText("");
1653 myRequireRecomputingButton->setTipText(TL("Network computed"));
1655 myRequireRecomputingButton->setBackColor(FXRGBA(240, 255, 205, 255));
1656 } else {
1657 myRequireRecomputingButton->setText(TL("Press F5"));
1658 myRequireRecomputingButton->setTipText(TL("Network requires recomputing"));
1660 myRequireRecomputingButton->setBackColor(FXRGBA(253, 255, 206, 255));
1661 }
1662 } else {
1663 // hide
1665 }
1666}
1667
1668
1669void
1670GNEApplicationWindow::closeAllWindows(const bool resetFilenames) {
1671 // first check if net must be deleted
1672 if (myNet != nullptr) {
1673 delete myNet;
1674 myNet = nullptr;
1676 }
1677 // reset default filenames
1678 if (resetFilenames) {
1680 }
1681 // check if view has to be saved
1682 if (myViewNet) {
1684 // clear decals
1685 myViewNet->getDecals().clear();
1686 }
1687 // lock tracker
1688 myTrackerLock.lock();
1689 // remove trackers and other external windows
1690 while (!myGLWindows.empty()) {
1691 delete myGLWindows.front();
1692 }
1693 myViewNet = nullptr;
1694 for (FXMainWindow* const window : myTrackerWindows) {
1695 window->destroy();
1696 delete window;
1697 }
1698 myTrackerWindows.clear();
1699 // reset the caption
1700 setTitle(myTitlePrefix);
1701 // unlock tracker
1702 myTrackerLock.unlock();
1703 // remove coordinate information
1704 myGeoCoordinate->setText(TL("N/A"));
1705 myCartesianCoordinate->setText(TL("N/A"));
1706 myTestCoordinate->setText(TL("N/A"));
1707 myTestFrame->hide();
1709 // Reset textures
1711 // reset fonts
1713}
1714
1715
1716FXCursor*
1718 return getApp()->getDefaultCursor(DEF_ARROW_CURSOR);
1719}
1720
1721
1722void
1724 auto& neteditOptions = OptionsCont::getOptions();
1725 if (neteditOptions.getBool("new")) {
1726 // save output file
1727 const auto outputFile = neteditOptions.getString("output-file");
1728 // create new network reset all options
1730 // check if define network file using this ouput file
1731 if (!outputFile.empty()) {
1733 }
1734 } else {
1735 // set flag
1736 myAmLoading = true;
1737 // set status bar
1738 setStatusBarText(TL("Loading console arguments."));
1739 // load console arguments
1741 // add it into recent networks and configs
1744 }
1747 }
1748 }
1749}
1750
1751
1752void
1754 auto& neteditOptions = OptionsCont::getOptions();
1755 // save windows size and position
1757 // enable loading flag and disable reloading flag
1758 myAmLoading = true;
1759 // recenter view
1760 gSchemeStorage.saveViewport(0, 0, -1, 0);
1761 // fill (reset) all options
1762 GNELoadThread::fillOptions(neteditOptions);
1763 // set default options defined in GNELoadThread::setDefaultOptions(...)
1764 GNELoadThread::setDefaultOptions(neteditOptions);
1765 // update status bar
1766 setStatusBarText(TL("Creating new network."));
1767 // create new network
1769 // update window
1770 update();
1771}
1772
1773
1774void
1775GNEApplicationWindow::loadNetwork(const std::string& networkFile) {
1776 if (networkFile.empty()) {
1777 WRITE_ERROR(TL("Trying to load an empty network."));
1778 } else {
1779 auto& neteditOptions = OptionsCont::getOptions();
1780 // stop test before calling load thread
1781 if (myInternalTest) {
1783 }
1784 // store size, position and viewport
1786 gSchemeStorage.saveViewport(0, 0, -1, 0); // recenter view
1787 // set flag
1788 myAmLoading = true;
1789 // fill (reset) all options
1790 myLoadThread->fillOptions(neteditOptions);
1791 // set default options defined in GNELoadThread::setDefaultOptions(...)
1792 myLoadThread->setDefaultOptions(neteditOptions);
1793 // update default net file
1795 // set status bar
1796 setStatusBarText(TLF("Loading network file '%'.", networkFile));
1797 // load network
1799 // add it into recent nets
1800 myMenuBarFile.myRecentNetworks.appendFile(networkFile.c_str());
1801 }
1802}
1803
1804
1805void
1806GNEApplicationWindow::loadConfiguration(const std::string& configurationFile) {
1807 if (configurationFile.empty()) {
1808 WRITE_ERROR(TL("Trying to load an empty configuration."));
1809 } else {
1810 auto& neteditOptions = OptionsCont::getOptions();
1811 // store size, position and viewport
1813 gSchemeStorage.saveViewport(0, 0, -1, 0); // recenter view
1814 // set flag
1815 myAmLoading = true;
1816 // fill (reset) all options
1817 myLoadThread->fillOptions(neteditOptions);
1818 // set default options defined in GNELoadThread::setDefaultOptions(...)
1819 myLoadThread->setDefaultOptions(neteditOptions);
1820 // set file to load
1821 neteditOptions.resetWritable();
1822 neteditOptions.set("configuration-file", configurationFile);
1823 // set status bar
1824 setStatusBarText(TLF("Loading configuration file '%'.", configurationFile));
1825 // load config
1827 // add it into recent configs
1828 myMenuBarFile.myRecentConfigs.appendFile(configurationFile.c_str());
1829 }
1830}
1831
1832
1833void
1834GNEApplicationWindow::loadOSM(const std::string& OSMFile) {
1835 auto& neteditOptions = OptionsCont::getOptions();
1836 // store size, position and viewport
1838 gSchemeStorage.saveViewport(0, 0, -1, 0); // recenter view
1839 // set flag
1840 myAmLoading = true;
1841 // fill (reset) all options
1842 myLoadThread->fillOptions(neteditOptions);
1843 // set default options defined in GNELoadThread::setDefaultOptions(...)
1844 myLoadThread->setDefaultOptions(neteditOptions);
1845 // recommended osm options
1846 // https://sumo.dlr.de/wiki/Networks/Import/OpenStreetMap#Recommended_NETCONVERT_Options
1847 neteditOptions.set("osm-files", OSMFile);
1848 neteditOptions.set("geometry.remove", "true");
1849 neteditOptions.set("ramps.guess", "true");
1850 neteditOptions.set("junctions.join", "true");
1851 neteditOptions.set("tls.guess-signals", "true");
1852 neteditOptions.set("tls.discard-simple", "true");
1853 // open netedit options dialog
1854 const GNENeteditOptionsDialog neteditOptionsDialog(this, neteditOptions, myOriginalNeteditOptions);
1855 // open wizard dialog
1856 if (neteditOptionsDialog.getResult() == GNEDialog::Result::ACCEPT) {
1857 // needed to set projection parameters
1858 NIFrame::checkOptions(neteditOptions);
1859 // set file to load
1860 neteditOptions.resetWritable();
1861 neteditOptions.set("configuration-file", OSMFile);
1862 // set status bar
1863 setStatusBarText(TLF("Loading OSM file '%'.", OSMFile));
1864 // load config
1866 }
1867}
1868
1869void
1870GNEApplicationWindow::setStatusBarText(const std::string& statusBarText) {
1871 myStatusbar->getStatusLine()->setText(statusBarText.c_str());
1872 myStatusbar->getStatusLine()->setNormalText(statusBarText.c_str());
1873}
1874
1875
1876long
1877GNEApplicationWindow::computeJunctionWithVolatileOptions(FXObject* sender, FXSelector sel, void* ptr) {
1878 // open question dialog box
1879 const GNEQuestionBasicDialog questionDialog(this, GNEDialog::Buttons::YES_NO,
1880 TL("Recompute with volatile options"),
1881 TL("Changes produced in the net due a recomputing with"),
1882 TL("volatile options cannot be undone. Continue?"));
1883 // check result
1884 if (questionDialog.getResult() == GNEDialog::Result::ACCEPT) {
1885 // save all elements
1886 onCmdSaveAdditionalElements(sender, sel, ptr);
1887 onCmdSaveDemandElements(sender, sel, ptr);
1888 onCmdSaveDataElements(sender, sel, ptr);
1889 onCmdSaveMeanDataElements(sender, sel, ptr);
1890 // compute with volatile options
1891 myNet->computeNetwork(this, true, true);
1893 }
1894 return 1;
1895}
1896
1897
1898bool
1901 myConsoleOptionsLoaded = false;
1902 return true;
1903 } else {
1904 return false;
1905 }
1906}
1907
1908
1913
1914
1919
1920
1921void
1925
1926
1927long
1928GNEApplicationWindow::onCmdSetSuperMode(FXObject* sender, FXSelector sel, void* ptr) {
1929 // check that currently there is a View
1930 if (myViewNet) {
1931 myViewNet->onCmdSetSupermode(sender, sel, ptr);
1932 }
1933 return 1;
1934}
1935
1936
1937long
1938GNEApplicationWindow::onCmdSetMode(FXObject* sender, FXSelector sel, void* ptr) {
1939 // check that currently there is a View
1940 if (myViewNet) {
1941 myViewNet->onCmdSetMode(sender, sel, ptr);
1942 }
1943 return 1;
1944}
1945
1946
1947long
1948GNEApplicationWindow::onCmdLockElements(FXObject*, FXSelector sel, void*) {
1949 if (myViewNet) {
1950 // check if we're calling the functions using internal test
1951 switch (FXSELID(sel)) {
1954 break;
1955 case MID_GNE_LOCK_EDGE:
1957 break;
1958 case MID_GNE_LOCK_LANE:
1960 break;
1963 break;
1966 break;
1969 break;
1972 break;
1973 case MID_GNE_LOCK_WIRE:
1975 break;
1976 case MID_GNE_LOCK_TAZ:
1978 break;
1981 break;
1982 case MID_GNE_LOCK_POI:
1984 break;
1987 break;
1990 break;
1991 case MID_GNE_LOCK_ROUTE:
1993 break;
1996 break;
1999 break;
2002 break;
2003 case MID_GNE_LOCK_WALK:
2005 break;
2006 case MID_GNE_LOCK_RIDE:
2008 break;
2011 break;
2014 break;
2017 break;
2018 case MID_GNE_LOCK_STOP:
2020 break;
2023 break;
2026 break;
2029 break;
2030 default:
2031 break;
2032 }
2034 }
2035 return 1;
2036}
2037
2038
2039long
2040GNEApplicationWindow::onCmdLockAllElements(FXObject*, FXSelector, void*) {
2041 // lock all
2044 return 1;
2045}
2046
2047
2048long
2050 // unlock all
2053 return 1;
2054}
2055
2056
2057long
2059 if (myViewNet) {
2060 myViewNet->update();
2061 }
2062 return 1;
2063}
2064
2065
2066long
2067GNEApplicationWindow::onUpdLockMenuTitle(FXObject*, FXSelector, void*) {
2068 if (myViewNet) {
2070 // supermode network
2076 myLockMenuTitle->enable();
2077 } else {
2078 myLockMenuTitle->disable();
2079 }
2081 // supermode demand
2086 myLockMenuTitle->enable();
2087 } else {
2088 myLockMenuTitle->disable();
2089 }
2091 // supermode data
2095 myLockMenuTitle->enable();
2096 } else {
2097 myLockMenuTitle->disable();
2098 }
2099 } else {
2100 myLockMenuTitle->disable();
2101 }
2102 } else {
2103 myLockMenuTitle->disable();
2104 }
2105 return 1;
2106}
2107
2108
2109long
2110GNEApplicationWindow::onCmdProcessButton(FXObject* sender, FXSelector sel, void* ptr) {
2111 // first check if there is a view
2112 if (myViewNet) {
2113 // process depending of supermode
2115 // check what FXMenuCommand was called
2116 switch (FXSELID(sel)) {
2118 myNet->computeNetwork(this, true, false);
2120 break;
2122 computeJunctionWithVolatileOptions(sender, sel, ptr);
2123 break;
2126 break;
2129 break;
2132 break;
2133 default:
2134 break;
2135 }
2137 // check what FXMenuCommand was called
2138 switch (FXSELID(sel)) {
2142 break;
2145 break;
2148 break;
2151 break;
2154 break;
2155 default:
2156 break;
2157 }
2158 }
2159 // refresh to update undo-redo button
2160 myViewNet->getViewParent()->getGNEAppWindows()->forceRefresh();
2161 }
2162 return 1;
2163}
2164
2165
2166long
2167GNEApplicationWindow::onCmdNewWindow(FXObject*, FXSelector sel, void* /*ptr*/) {
2168 // get extra arguments
2169 std::string extraArg;
2171 extraArg = " -s \"" + StringUtils::escapeShell(myNetgenerateOptions.getValueString("output-file")) + "\" ";
2172 }
2173 FXRegistry reg("SUMO netedit", "netedit");
2174 std::string netedit = "netedit";
2175 const char* sumoPath = getenv("SUMO_HOME");
2176 if (sumoPath != nullptr) {
2177#ifdef DEBUG
2178 std::string newPath = std::string(sumoPath) + "/bin/neteditD";
2179#else
2180 std::string newPath = std::string(sumoPath) + "/bin/netedit";
2181#endif
2182 if (FileHelpers::isReadable(newPath) || FileHelpers::isReadable(newPath + ".exe")) {
2183 netedit = "\"" + newPath + "\"";
2184 }
2185 }
2186 std::string cmd = netedit + extraArg;
2187 // start in background
2188#ifndef WIN32
2189 cmd = cmd + " &";
2190#else
2191 // see "help start" for the parameters
2192 cmd = "start /B \"\" " + cmd;
2193#endif
2194 WRITE_MESSAGE(TLF("Running '%'.", cmd));
2195 // yay! fun with dangerous commands... Never use this over the internet
2197 return 1;
2198}
2199
2200
2201long
2202GNEApplicationWindow::onCmdOpenSUMOGUI(FXObject* obj, FXSelector sel, void* ptr) {
2203 // input parameters
2204 std::string inputParameters;
2205 // if we have only a network, then load directly without creating a SumoConfig
2207 ((myEditMenuCommands.loadAdditionalsInSUMOGUI->getCheck() == FALSE) && (myEditMenuCommands.loadDemandInSUMOGUI->getCheck() == FALSE))) {
2208 // force save network
2209 if (onCmdSaveNetwork(obj, sel, ptr) == 0) {
2210 // network wasn't saved, then stop
2211 return 0;
2212 }
2213 inputParameters = " --registry-viewport -n \"" + myFileBucketHandler->getDefaultFilename(FileBucket::Type::NETWORK) + "\"";
2214 // write info
2216 } else {
2217 // force save SumoConfig
2218 if (onCmdSaveSumoConfig(obj, sel, ptr) == 0) {
2219 // SumoConfig wasn't saved, then stop
2220 return 0;
2221 }
2222 inputParameters = " --registry-viewport -c \"" + myFileBucketHandler->getDefaultFilename(FileBucket::Type::SUMO_CONFIG) + "\"";
2223 // write info
2224 WRITE_MESSAGE(TLF("Loading sumo config '%' in SUMO-GUI.", myFileBucketHandler->getDefaultFilename(FileBucket::Type::SUMO_CONFIG)));
2225 }
2226 // save current viewport in registry
2227 FXRegistry reg("SUMO GUI", "sumo-gui");
2228 reg.read();
2229 reg.writeRealEntry("viewport", "x", myViewNet->getChanger().getXPos());
2230 reg.writeRealEntry("viewport", "y", myViewNet->getChanger().getYPos());
2231 reg.writeRealEntry("viewport", "z", myViewNet->getChanger().getZPos());
2232 reg.write();
2233 // declare executable
2234 std::string sumoGuiExecutable = "sumo-gui";
2235 // if SUMO_HOME is defined, update executable
2236 const char* sumoHome = getenv("SUMO_HOME");
2237 if (sumoHome != nullptr) {
2238 std::string newPath = std::string(sumoHome) + "/bin/sumo-gui";
2239 if (FileHelpers::isReadable(newPath) || FileHelpers::isReadable(newPath + ".exe")) {
2240 sumoGuiExecutable = "\"" + newPath + "\"";
2241 }
2242 }
2243 // declare command
2244 std::string cmd = sumoGuiExecutable + inputParameters;
2245 // start in background
2246#ifndef WIN32
2247 cmd = cmd + " &";
2248#else
2249 // see "help start" for the parameters
2250 cmd = "start /B \"\" " + cmd;
2251#endif
2252 WRITE_MESSAGE(TLF("Running '%'.", cmd));
2253 // yay! fun with dangerous commands... Never use this over the internet
2255 return 1;
2256}
2257
2258
2259long
2260GNEApplicationWindow::onCmdAbort(FXObject*, FXSelector, void*) {
2261 // check that view exists
2262 if (myViewNet) {
2263 // first check if we're selecting a subset of edges in TAZ Frame
2265 // clear current selection
2267 } else if (myViewNet->getViewParent()->getInspectorFrame()->shown()) {
2268 // check if stop select parent
2270 // and stop select paretn
2272 } else {
2273 // clear inspected elements
2275 }
2276 } else {
2277 // abort current operation
2279 }
2280 }
2281 return 1;
2282}
2283
2284
2285long
2286GNEApplicationWindow::onCmdDel(FXObject*, FXSelector, void*) {
2287 // check that view exists
2288 if (myViewNet) {
2290 }
2291 return 1;
2292}
2293
2294
2295long
2296GNEApplicationWindow::onCmdEnter(FXObject*, FXSelector, void*) {
2297 // check that view exists
2298 if (myViewNet) {
2300 }
2301 return 1;
2302}
2303
2304
2305long
2306GNEApplicationWindow::onCmdBackspace(FXObject*, FXSelector, void*) {
2307 // check that view exists
2308 if (myViewNet) {
2310 }
2311 return 1;
2312}
2313
2314
2315long
2316GNEApplicationWindow::onCmdFocusFrame(FXObject*, FXSelector, void*) {
2317 // check that view exists
2318 if (myViewNet) {
2320 }
2321 return 1;
2322}
2323
2324
2325long
2327 // check that view exists
2328 if (myViewNet) {
2330 }
2331 return 1;
2332}
2333
2334
2335long
2336GNEApplicationWindow::onCmdToggleTimeFormat(FXObject*, FXSelector, void*) {
2337 // check that view exists
2338 if (myViewNet) {
2340 // refresh flow frames
2341 if (myViewNet->getViewParent()->getVehicleFrame()->shown()) {
2343 }
2344 if (myViewNet->getViewParent()->getPersonFrame()->shown()) {
2346 }
2347 if (myViewNet->getViewParent()->getContainerFrame()->shown()) {
2349 }
2350 // refresh inspector frame
2351 if (myViewNet->getViewParent()->getInspectorFrame()->shown()) {
2353 }
2354 }
2355 return 1;
2356}
2357
2358
2359long
2360GNEApplicationWindow::onUpdToggleTimeFormat(FXObject*, FXSelector, void*) {
2361 // check that view exists
2362 if (myViewNet) {
2364 }
2365 return 1;
2366}
2367
2368
2369long
2370GNEApplicationWindow::onCmdRunTests(FXObject*, FXSelector, void*) {
2373 }
2374 return 1;
2375}
2376
2377
2378long
2379GNEApplicationWindow::onUpdRequireViewNet(FXObject* sender, FXSelector, void*) {
2380 // enable or disable sender element depending of viewNet
2381 return sender->handle(this, myViewNet ? FXSEL(SEL_COMMAND, ID_ENABLE) : FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2382}
2383
2384
2385long
2388 return 1;
2389}
2390
2391
2392long
2393GNEApplicationWindow::onCmdRunNetgenerate(FXObject*, FXSelector, void*) {
2394 GNERunNetgenerateDialog netgenerateDialog(this, &myNetgenerateOptions);
2395 return 1;
2396}
2397
2398
2399long
2400GNEApplicationWindow::onCmdPostprocessingNetgenerate(FXObject* obj, FXSelector, void* ptr) {
2402}
2403
2404
2405long
2406GNEApplicationWindow::onCmdEditViewport(FXObject*, FXSelector, void*) {
2407 // check that view exists
2408 if (myViewNet) {
2410 }
2411 return 1;
2412}
2413
2414
2415long
2416GNEApplicationWindow::onCmdEditViewScheme(FXObject*, FXSelector, void*) {
2417 // check that view exists
2418 if (myViewNet) {
2420 }
2421 return 1;
2422}
2423
2424
2425long
2426GNEApplicationWindow::onCmdToggleGrid(FXObject* sender, FXSelector sel, void* ptr) {
2427 // check that view exists
2428 if (myViewNet) {
2429 // Call manually toggle grid function
2430 myViewNet->onCmdToggleShowGrid(sender, sel, ptr);
2431 }
2432 return 1;
2433}
2434
2435
2436long
2437GNEApplicationWindow::onCmdToggleDrawJunctionShape(FXObject* sender, FXSelector sel, void* ptr) {
2438 // check that view exists
2439 if (myViewNet) {
2440 // Call manually toggle junction shape function
2441 myViewNet->onCmdToggleDrawJunctionShape(sender, sel, ptr);
2442 }
2443 return 1;
2444}
2445
2446
2447long
2449 if (myViewNet) {
2450 // check if all element are front
2451 bool allFront = true;
2452 for (auto& AC : myViewNet->getInspectedElements().getACs()) {
2453 if (!AC->isMarkedForDrawingFront()) {
2454 allFront = false;
2455 break;
2456 }
2457 }
2458 // first unfront all elements
2460 // only mark front elements if we have at least one non-front element
2461 if (!allFront) {
2462 for (auto& AC : myViewNet->getInspectedElements().getACs()) {
2463 AC->markForDrawingFront();
2464 }
2465 }
2466 myViewNet->update();
2468 }
2469 return 1;
2470}
2471
2472
2473long
2474GNEApplicationWindow::onCmdToggleEditOptions(FXObject* sender, FXSelector sel, void* /* ptr */) {
2475 // first check that we have a ViewNet
2476 if (myViewNet) {
2477 // first check what selector was called
2478 int numericalKeyPressed = sel - FXSEL(SEL_COMMAND, MID_HOTKEY_ALT_0_TOGGLEEDITOPTION) - 1;
2479 // check that numericalKeyPressed is valid
2480 if ((numericalKeyPressed < 0) || (numericalKeyPressed > 10)) {
2481 return 0;
2482 }
2483 // declare a vector in which save visible menu commands
2484 std::vector<MFXCheckableButton*> visibleMenuCommands;
2485 // get common, network and demand visible menu commands
2489 // now check that numericalKeyPressed isn't greater than visible view options
2490 if (numericalKeyPressed >= (int)visibleMenuCommands.size()) {
2491 return 0;
2492 }
2493 // toggle edit options
2495 visibleMenuCommands.at(numericalKeyPressed), sender, sel)) {
2496 return 1;
2498 visibleMenuCommands.at(numericalKeyPressed), sender, sel)) {
2499 return 1;
2501 visibleMenuCommands.at(numericalKeyPressed), sender, sel)) {
2502 return 1;
2503 }
2504 }
2505 return 0;
2506}
2507
2508
2509long
2510GNEApplicationWindow::onCmdHelp(FXObject*, FXSelector, void*) {
2511 MFXLinkLabel::fxexecute("https://sumo.dlr.de/docs/netedit.html");
2512 return 1;
2513}
2514
2515
2516long
2517GNEApplicationWindow::onCmdChangelog(FXObject*, FXSelector, void*) {
2518 // update in every version
2519 MFXLinkLabel::fxexecute("https://sumo.dlr.de/docs/ChangeLog.html");
2520 return 1;
2521}
2522
2523
2524long
2525GNEApplicationWindow::onCmdHotkeys(FXObject*, FXSelector, void*) {
2526 MFXLinkLabel::fxexecute("https://sumo.dlr.de/docs/Netedit/shortcuts.html");
2527 return 1;
2528}
2529
2530
2531long
2534 return getApp()->reg().writeBoolEntry("NETEDIT", "RecomputeData", true);
2535 } else {
2536 return getApp()->reg().writeBoolEntry("NETEDIT", "RecomputeData", false);
2537 }
2538}
2539
2540
2541long
2542GNEApplicationWindow::onCmdToggleUndoRedo(FXObject*, FXSelector, void*) {
2543 if (myEditMenuCommands.menuCheckAllowUndoRedo->getCheck() == TRUE) {
2544 myAllowUndoRedo = true;
2545 return getApp()->reg().writeBoolEntry("NETEDIT", "AllowUndoRedo", true);
2546 } else {
2547 myAllowUndoRedo = false;
2548 // drop undo-redo list after changing flag
2549 myUndoList->clear();
2550 return getApp()->reg().writeBoolEntry("NETEDIT", "AllowUndoRedo", false);
2551 }
2552}
2553
2554
2555long
2557 if (myFileMenuCommands.menuCheckAllowUndoRedoLoading->getCheck() == TRUE) {
2559 return getApp()->reg().writeBoolEntry("NETEDIT", "AllowUndoRedoLoading", true);
2560 } else {
2561 myAllowUndoRedoLoading = false;
2562 return getApp()->reg().writeBoolEntry("NETEDIT", "AllowUndoRedoLoading", false);
2563 }
2564}
2565
2566
2567long
2568GNEApplicationWindow::onCmdTutorial(FXObject*, FXSelector, void*) {
2569 MFXLinkLabel::fxexecute("https://sumo.dlr.de/docs/Tutorials/index.html");
2570 return 1;
2571}
2572
2573
2574long
2575GNEApplicationWindow::onCmdFeedback(FXObject*, FXSelector, void*) {
2576 // create and open feedback dialog
2577 GUIDialog_Feedback* feedback = new GUIDialog_Feedback(this);
2578 feedback->create();
2579 feedback->show(PLACEMENT_OWNER);
2580 return 1;
2581}
2582
2583
2584long
2586 auto& neteditOptions = OptionsCont::getOptions();
2587 // open netedit option dialog
2588 const GNENeteditOptionsDialog neteditOptionsDialog(this, neteditOptions, myOriginalNeteditOptions);
2589 // continue depending of result
2590 if (neteditOptionsDialog.getResult() == GNEDialog::Result::ACCEPT) {
2591 NIFrame::checkOptions(neteditOptions); // needed to set projection parameters
2592 NBFrame::checkOptions(neteditOptions);
2593 NWFrame::checkOptions(neteditOptions);
2594 SystemFrame::checkOptions(neteditOptions); // needed to set precision
2595 // check if mark netedit config as unsaved
2596 if (neteditOptionsDialog.isOptionModified() && myNet) {
2598 }
2599 }
2600 return 1;
2601}
2602
2603
2604long
2606 // open sumo option dialog
2607 const GNESumoOptionsDialog sumoOptionsDialog(this, mySumoOptions, myOriginalSumoOptions);
2608 // continue depending of result
2609 if ((sumoOptionsDialog.getResult() == GNEDialog::Result::ACCEPT) && sumoOptionsDialog.isOptionModified() && myNet) {
2611 }
2612 return 1;
2613}
2614
2615
2616long
2619 return 1;
2620}
2621
2622
2623long
2625 // open netgenerate options dialog
2627 return 1;
2628}
2629
2630
2631long
2632GNEApplicationWindow::onCmdUndo(FXObject* sender, FXSelector, void*) {
2633 // Check conditions
2634 if (myViewNet == nullptr) {
2635 return 0;
2636 } else if ((myInternalTest != sender) && !myEditMenuCommands.undoLastChange->isEnabled()) {
2637 return 0;
2638 } else {
2639 // check supermode (currently ignore supermode data)
2642 // abort if user doesn't press "yes"
2644 return 0;
2645 }
2646 }
2648 // update current show frame after undo
2651 }
2652 // update file bucket options (needed to maintain integrity)
2654 // update manually undo/redo menu commands (see #6005)
2657 // update toolbar undo-redo buttons
2659 return 1;
2660 }
2661}
2662
2663
2664long
2665GNEApplicationWindow::onCmdRedo(FXObject* sender, FXSelector, void*) {
2666 // Check conditions
2667 if (myViewNet == nullptr) {
2668 return 0;
2669 } else if ((myInternalTest != sender) && !myEditMenuCommands.redoLastChange->isEnabled()) {
2670 return 0;
2671 } else {
2672 // check supermode (currently ignore supermode data)
2675 // abort if user doesn't press "yes"
2677 return 0;
2678 }
2679 }
2681 // update current show frame after redo
2684 }
2685 // update file bucket options (needed to maintain integrity)
2687 // update manually undo/redo menu commands (see #6005)
2690 // update toolbar undo-redo buttons
2692 return 1;
2693 }
2694}
2695
2696
2697long
2699 // open UndoList Dialog
2700 GNEUndoListDialog(this);
2701 return 1;
2702}
2703
2704
2705long
2706GNEApplicationWindow::onUpdOpenUndoListDialog(FXObject* sender, FXSelector, void*) {
2707 // check if net exist and there is something to undo/redo
2708 if (myNet && (myEditMenuCommands.undoLastChange->isEnabled() || myEditMenuCommands.redoLastChange->isEnabled())) {
2709 sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
2710 } else {
2711 sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2712 }
2713 return 1;
2714}
2715
2716
2717long
2719 // first check viewNet
2721 // update demand path calculator
2723 }
2724 return 1;
2725}
2726
2727
2728long
2729GNEApplicationWindow::onCmdCut(FXObject*, FXSelector, void*) {
2730 // Prepared for #6042
2731 return 1;
2732}
2733
2734
2735long
2736GNEApplicationWindow::onCmdCopy(FXObject*, FXSelector, void*) {
2737 // Prepared for #6042
2738 return 1;
2739}
2740
2741
2742long
2743GNEApplicationWindow::onCmdPaste(FXObject*, FXSelector, void*) {
2744 // Prepared for #6042
2745 return 1;
2746}
2747
2748
2749long
2750GNEApplicationWindow::onCmdSetTemplate(FXObject*, FXSelector, void*) {
2751 // first check if myViewNet exist
2752 if (myViewNet) {
2753 // call set template in inspector frame
2755 }
2756 return 1;
2757}
2758
2759
2760long
2761GNEApplicationWindow::onCmdCopyTemplate(FXObject*, FXSelector, void*) {
2762 // first check if myViewNet exist
2763 if (myViewNet) {
2764 // call copy template in inspector frame
2766 }
2767 return 1;
2768}
2769
2770
2771long
2772GNEApplicationWindow::onCmdClearTemplate(FXObject*, FXSelector, void*) {
2773 // first check if myViewNet exist
2774 if (myViewNet) {
2775 // call clear template in inspector frame
2777 }
2778 return 1;
2779}
2780
2781
2782long
2783GNEApplicationWindow::onUpdNeedsNetwork(FXObject* sender, FXSelector, void*) {
2784 // check if net exist
2785 if (myNet) {
2787 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
2788 } else {
2790 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2791 }
2792}
2793
2794
2795long
2796GNEApplicationWindow::onUpdNeedsNetworkElement(FXObject* sender, FXSelector, void*) {
2797 // check if at least there is one edge in the network
2798 if (myNet && (myNet->getAttributeCarriers()->getEdges().size() > 0)) {
2799 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
2800 } else {
2801 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2802 }
2803}
2804
2805
2806long
2807GNEApplicationWindow::onUpdNeedsFrontElement(FXObject* sender, FXSelector, void*) {
2808 // check if net, viewnet and front attribute exist
2809 if (myViewNet && (myViewNet->getInspectedElements().getACs().size() > 0)) {
2810 // check if all element are front
2811 bool allFront = true;
2812 for (auto& AC : myViewNet->getInspectedElements().getACs()) {
2813 if (!AC->isMarkedForDrawingFront()) {
2814 allFront = false;
2815 break;
2816 }
2817 }
2818 // set button text depending of all selected
2819 if (allFront) {
2820 myEditMenuCommands.toggleFrontElement->setText(TL("Unfront element"));
2821 myEditMenuCommands.toggleFrontElement->setTipText(TL("Unfront inspected elements"));
2822 } else {
2823 myEditMenuCommands.toggleFrontElement->setText(TL("Front element"));
2824 myEditMenuCommands.toggleFrontElement->setTipText(TL("Mark element to be drawn above everything else"));
2825 }
2826 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
2827 } else if (myViewNet && (myViewNet->getMarkFrontElements().getACs().size() > 0)) {
2828 myEditMenuCommands.toggleFrontElement->setText(TL("Unfront all element"));
2829 myEditMenuCommands.toggleFrontElement->setTipText(TL("Unfront all elements"));
2830 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
2831 } else {
2832 myEditMenuCommands.toggleFrontElement->setText(TL("Front element (only inspected elements)"));
2833 myEditMenuCommands.toggleFrontElement->setTipText(TL("Mark element to be drawn above everything else"));
2834 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2835 }
2836}
2837
2838
2839long
2840GNEApplicationWindow::onUpdSaveNetwork(FXObject* sender, FXSelector, void*) {
2841 if (myNet == nullptr) {
2842 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2843 } else if (myNet->getSavingStatus()->isNetworkSaved()) {
2844 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2845 } else {
2846 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
2847 }
2848}
2849
2850
2851long
2852GNEApplicationWindow::onUpdSaveAdditionalElements(FXObject* sender, FXSelector, void*) {
2853 if (myNet == nullptr) {
2854 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2856 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2857 } else {
2858 return sender->handle(this, myNet->getSavingStatus()->isAdditionalsSaved() ? FXSEL(SEL_COMMAND, ID_DISABLE) : FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
2859 }
2860}
2861
2862
2863long
2865 if (myNet == nullptr) {
2866 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2867 } else if (myNet->getAttributeCarriers()->getNumberOfAdditionals() == 0) {
2868 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2869 } else {
2870 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
2871 }
2872}
2873
2874
2875long
2876GNEApplicationWindow::onUpdSaveJuPedSimElementsAs(FXObject* sender, FXSelector, void*) {
2877 if (myNet == nullptr) {
2878 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2879 } else if (myNet->getAttributeCarriers()->getAdditionals().at(GNE_TAG_JPS_WALKABLEAREA).size() > 0) {
2880 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
2881 } else if (myNet->getAttributeCarriers()->getAdditionals().at(GNE_TAG_JPS_OBSTACLE).size() > 0) {
2882 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
2883 } else {
2884 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2885 }
2886}
2887
2888
2889long
2890GNEApplicationWindow::onUpdSaveDemandElements(FXObject* sender, FXSelector, void*) {
2891 if (myNet == nullptr) {
2892 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2893 } else if (myNet->getSavingStatus()->isDemandElementsSaved()) {
2894 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2895 } else {
2896 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
2897 }
2898
2899}
2900
2901
2902long
2903GNEApplicationWindow::onUpdSaveDemandElementsUnified(FXObject* sender, FXSelector, void*) {
2904 if (myNet == nullptr) {
2905 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2907 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2908 } else {
2909 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
2910 }
2911}
2912
2913
2914long
2915GNEApplicationWindow::onUpdSaveDataElements(FXObject* sender, FXSelector, void*) {
2916 if (myNet == nullptr) {
2917 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2918 } else if (myNet->getSavingStatus()->isDataElementsSaved()) {
2919 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2920 } else {
2921 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
2922 }
2923
2924}
2925
2926
2927long
2928GNEApplicationWindow::onUpdSaveDataElementsUnified(FXObject* sender, FXSelector, void*) {
2929 if (myNet == nullptr) {
2930 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2931 } else if (myNet->getAttributeCarriers()->getDataSets().size() == 0) {
2932 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2933 } else {
2934 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
2935 }
2936
2937}
2938
2939
2940long
2941GNEApplicationWindow::onUpdSaveMeanDataElements(FXObject* sender, FXSelector, void*) {
2942 if (myNet == nullptr) {
2943 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2944 } else if (myNet->getSavingStatus()->isMeanDatasSaved()) {
2945 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2946 } else {
2947 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
2948 }
2949}
2950
2951
2952long
2954 if (myNet == nullptr) {
2955 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2956 } else if (myNet->getAttributeCarriers()->getNumberOfMeanDatas() == 0) {
2957 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2958 } else {
2959 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
2960 }
2961
2962}
2963
2964
2965long
2966GNEApplicationWindow::onUpdUndo(FXObject* sender, FXSelector sel, void* ptr) {
2967 return myUndoList->onUpdUndo(sender, sel, ptr);
2968}
2969
2970
2971long
2972GNEApplicationWindow::onUpdRedo(FXObject* sender, FXSelector sel, void* ptr) {
2973 return myUndoList->onUpdRedo(sender, sel, ptr);
2974}
2975
2976
2977long
2978GNEApplicationWindow::onUpdComputePathManager(FXObject* sender, FXSelector /*sel*/, void* /*ptr*/) {
2979 // first check viewNet
2980 if (myViewNet) {
2981 // check supermode network
2983 // disable
2984 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2986 // disable
2987 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2988 } else {
2989 // enable
2990 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
2991 }
2992 } else {
2993 // disable
2994 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
2995 }
2996}
2997
2998
2999long
3000GNEApplicationWindow::onCmdToggleViewOption(FXObject* sender, FXSelector sel, void* ptr) {
3001 // check viewNet
3002 if (myViewNet) {
3003 // continue depending of selector
3004 switch (FXSELID(sel)) {
3005 // Network
3007 return myViewNet->onCmdToggleShowGrid(sender, sel, ptr);
3009 return myViewNet->onCmdToggleDrawJunctionShape(sender, sel, ptr);
3011 return myViewNet->onCmdToggleDrawSpreadVehicles(sender, sel, ptr);
3013 return myViewNet->onCmdToggleShowDemandElementsNetwork(sender, sel, ptr);
3015 return myViewNet->onCmdToggleSelectEdges(sender, sel, ptr);
3017 return myViewNet->onCmdToggleShowConnections(sender, sel, ptr);
3019 return myViewNet->onCmdToggleHideConnections(sender, sel, ptr);
3021 return myViewNet->onCmdToggleShowAdditionalSubElements(sender, sel, ptr);
3023 return myViewNet->onCmdToggleShowTAZElements(sender, sel, ptr);
3025 return myViewNet->onCmdToggleExtendSelection(sender, sel, ptr);
3027 return myViewNet->onCmdToggleChangeAllPhases(sender, sel, ptr);
3029 return myViewNet->onCmdToggleMergeAutomatically(sender, sel, ptr);
3031 return myViewNet->onCmdToggleShowJunctionBubbles(sender, sel, ptr);
3033 return myViewNet->onCmdToggleMoveElevation(sender, sel, ptr);
3035 return myViewNet->onCmdToggleChainEdges(sender, sel, ptr);
3037 return myViewNet->onCmdToggleAutoOppositeEdge(sender, sel, ptr);
3038 // Demand
3040 return myViewNet->onCmdToggleShowGrid(sender, sel, ptr);
3042 return myViewNet->onCmdToggleDrawJunctionShape(sender, sel, ptr);
3044 return myViewNet->onCmdToggleDrawSpreadVehicles(sender, sel, ptr);
3046 return myViewNet->onCmdToggleHideNonInspecteDemandElements(sender, sel, ptr);
3048 return myViewNet->onCmdToggleHideShapes(sender, sel, ptr);
3050 return myViewNet->onCmdToggleShowTrips(sender, sel, ptr);
3052 return myViewNet->onCmdToggleShowAllPersonPlans(sender, sel, ptr);
3054 return myViewNet->onCmdToggleLockPerson(sender, sel, ptr);
3056 return myViewNet->onCmdToggleShowAllContainerPlans(sender, sel, ptr);
3058 return myViewNet->onCmdToggleLockContainer(sender, sel, ptr);
3060 return myViewNet->onCmdToggleShowOverlappedRoutes(sender, sel, ptr);
3061 // Data
3063 return myViewNet->onCmdToggleDrawJunctionShape(sender, sel, ptr);
3065 return myViewNet->onCmdToggleShowAdditionals(sender, sel, ptr);
3067 return myViewNet->onCmdToggleShowShapes(sender, sel, ptr);
3069 return myViewNet->onCmdToggleShowDemandElementsData(sender, sel, ptr);
3071 return myViewNet->onCmdToggleTAZRelDrawing(sender, sel, ptr);
3073 return myViewNet->onCmdToggleTAZRelDrawing(sender, sel, ptr);
3075 return myViewNet->onCmdToggleTAZRelOnlyFrom(sender, sel, ptr);
3077 return myViewNet->onCmdToggleTAZRelOnlyTo(sender, sel, ptr);
3078 default:
3079 return 0;
3080 }
3081 } else {
3082 return 0;
3083 }
3084}
3085
3086
3087long
3088GNEApplicationWindow::onUpdToggleViewOption(FXObject* sender, FXSelector sel, void* /*ptr*/) {
3089 // get menuCheck
3090 MFXMenuCheckIcon* menuCheck = dynamic_cast<MFXMenuCheckIcon*>(sender);
3091 // check viewNet
3092 if (myViewNet && menuCheck) {
3093 // continue depending of selector
3094 switch (FXSELID(sel)) {
3095 // Network
3098 menuCheck->setCheck(TRUE);
3099 } else {
3100 menuCheck->setCheck(FALSE);
3101 }
3102 break;
3105 menuCheck->setCheck(TRUE);
3106 } else {
3107 menuCheck->setCheck(FALSE);
3108 }
3109 break;
3112 menuCheck->setCheck(TRUE);
3113 } else {
3114 menuCheck->setCheck(FALSE);
3115 }
3116 break;
3119 menuCheck->setCheck(TRUE);
3120 } else {
3121 menuCheck->setCheck(FALSE);
3122 }
3123 break;
3126 menuCheck->setCheck(TRUE);
3127 } else {
3128 menuCheck->setCheck(FALSE);
3129 }
3130 break;
3133 menuCheck->setCheck(TRUE);
3134 } else {
3135 menuCheck->setCheck(FALSE);
3136 }
3137 break;
3140 menuCheck->setCheck(TRUE);
3141 } else {
3142 menuCheck->setCheck(FALSE);
3143 }
3144 break;
3147 menuCheck->setCheck(TRUE);
3148 } else {
3149 menuCheck->setCheck(FALSE);
3150 }
3151 break;
3154 menuCheck->setCheck(TRUE);
3155 } else {
3156 menuCheck->setCheck(FALSE);
3157 }
3158 break;
3161 menuCheck->setCheck(TRUE);
3162 } else {
3163 menuCheck->setCheck(FALSE);
3164 }
3165 break;
3168 menuCheck->setCheck(TRUE);
3169 } else {
3170 menuCheck->setCheck(FALSE);
3171 }
3172 break;
3175 menuCheck->setCheck(TRUE);
3176 } else {
3177 menuCheck->setCheck(FALSE);
3178 }
3179 break;
3182 menuCheck->setCheck(TRUE);
3183 } else {
3184 menuCheck->setCheck(FALSE);
3185 }
3186 break;
3189 menuCheck->setCheck(TRUE);
3190 } else {
3191 menuCheck->setCheck(FALSE);
3192 }
3193 break;
3196 menuCheck->setCheck(TRUE);
3197 } else {
3198 menuCheck->setCheck(FALSE);
3199 }
3200 break;
3203 menuCheck->setCheck(TRUE);
3204 } else {
3205 menuCheck->setCheck(FALSE);
3206 }
3207 break;
3208 // Demand
3211 menuCheck->setCheck(TRUE);
3212 } else {
3213 menuCheck->setCheck(FALSE);
3214 }
3215 break;
3218 menuCheck->setCheck(TRUE);
3219 } else {
3220 menuCheck->setCheck(FALSE);
3221 }
3222 break;
3225 menuCheck->setCheck(TRUE);
3226 } else {
3227 menuCheck->setCheck(FALSE);
3228 }
3229 break;
3232 menuCheck->setCheck(TRUE);
3233 } else {
3234 menuCheck->setCheck(FALSE);
3235 }
3236 break;
3239 menuCheck->setCheck(TRUE);
3240 } else {
3241 menuCheck->setCheck(FALSE);
3242 }
3243 break;
3246 menuCheck->setCheck(TRUE);
3247 } else {
3248 menuCheck->setCheck(FALSE);
3249 }
3250 break;
3253 menuCheck->setCheck(TRUE);
3254 } else {
3255 menuCheck->setCheck(FALSE);
3256 }
3257 // special case for lock persons
3259 menuCheck->enable();
3260 } else {
3261 menuCheck->disable();
3262 }
3263 break;
3266 menuCheck->setCheck(TRUE);
3267 } else {
3268 menuCheck->setCheck(FALSE);
3269 }
3270 break;
3273 menuCheck->setCheck(TRUE);
3274 } else {
3275 menuCheck->setCheck(FALSE);
3276 }
3277 // special case for lock containers
3279 menuCheck->enable();
3280 } else {
3281 menuCheck->disable();
3282 }
3283 break;
3286 menuCheck->setCheck(TRUE);
3287 } else {
3288 menuCheck->setCheck(FALSE);
3289 }
3290 break;
3293 menuCheck->setCheck(TRUE);
3294 } else {
3295 menuCheck->setCheck(FALSE);
3296 }
3297 break;
3298 // Data
3301 menuCheck->setCheck(TRUE);
3302 } else {
3303 menuCheck->setCheck(FALSE);
3304 }
3305 break;
3308 menuCheck->setCheck(TRUE);
3309 } else {
3310 menuCheck->setCheck(FALSE);
3311 }
3312 break;
3315 menuCheck->setCheck(TRUE);
3316 } else {
3317 menuCheck->setCheck(FALSE);
3318 }
3319 break;
3322 menuCheck->setCheck(TRUE);
3323 } else {
3324 menuCheck->setCheck(FALSE);
3325 }
3326 break;
3329 menuCheck->setCheck(TRUE);
3330 } else {
3331 menuCheck->setCheck(FALSE);
3332 }
3333 break;
3336 menuCheck->setCheck(TRUE);
3337 } else {
3338 menuCheck->setCheck(FALSE);
3339 }
3340 break;
3341
3344 menuCheck->setCheck(TRUE);
3345 } else {
3346 menuCheck->setCheck(FALSE);
3347 }
3348 break;
3351 menuCheck->setCheck(TRUE);
3352 } else {
3353 menuCheck->setCheck(FALSE);
3354 }
3355 break;
3356 default:
3357 break;
3358 }
3359 }
3360 return 0;
3361}
3362
3363
3364long
3365GNEApplicationWindow::onCmdSaveNetwork(FXObject* sender, FXSelector sel, void* ptr) {
3366 auto& neteditOptions = OptionsCont::getOptions();
3367 // check if we're forcing to saving additionals
3369 neteditOptions.getBool("force-saving")) {
3370 WRITE_MESSAGE(TL("Force save network"));
3371 } else if (myNet->getSavingStatus()->isNetworkSaved()) {
3372 // nothing to save
3373 return 1;
3374 }
3375 // first check if we have to set the output filename
3378 }
3379 // function onCmdSaveNetworkAs must be executed if this is the first save
3381 return onCmdSaveNetworkAs(sender, sel, ptr);
3382 } else {
3383 // always recompute before saving
3384 myNet->computeNetwork(this);
3385 bool saved = false;
3386 try {
3387 // obtain invalid networkElements (currently only edges or crossings
3388 std::vector<GNENetworkElement*> invalidNetworkElements;
3389 // iterate over crossings and edges
3390 for (const auto& edge : myViewNet->getNet()->getAttributeCarriers()->getEdges()) {
3391 if (!edge.second->isNetworkElementValid()) {
3392 invalidNetworkElements.push_back(edge.second);
3393 }
3394 }
3395 for (const auto& crossing : myViewNet->getNet()->getAttributeCarriers()->getCrossings()) {
3396 if (!crossing.second->isNetworkElementValid()) {
3397 invalidNetworkElements.push_back(crossing.second);
3398 }
3399 }
3400 // if there are invalid network elements, open GNEFixNetworkElements
3401 if (invalidNetworkElements.size() > 0) {
3402 // create fix network elements dialog
3403 const GNEFixNetworkElements fixNetworkElementsDialog(this, invalidNetworkElements);
3404 // continue depending of result
3405 if (fixNetworkElementsDialog.getResult() == GNEDialog::Result::ACCEPT) {
3406 // Save network
3407 myNet->saveNetwork();
3408 saved = true;
3409 } else {
3410 // stop
3411 return 0;
3412 }
3413 } else {
3414 // Save network
3415 myNet->saveNetwork();
3416 saved = true;
3417 }
3418 } catch (IOError& e) {
3419 // open error message box
3420 GNEErrorBasicDialog(this, TL("Saving network failed"), e.what());
3421 }
3422 if (saved) {
3423 // write info
3425 // After saving a net successfully, add it into Recent Nets list.
3428 } else {
3431 return 0;
3432 }
3433 return 1;
3434 }
3435}
3436
3437
3438long
3439GNEApplicationWindow::onCmdSaveNetworkAs(FXObject* sender, FXSelector sel, void* ptr) {
3440 // get network file file
3441 const GNEFileDialog networkFileDialog(this, TL("network file"),
3446 // continue depending of dialog
3447 if (networkFileDialog.getResult() == GNEDialog::Result::ACCEPT) {
3448 // update default network file
3450 // update netedit title with the network name
3451 setTitle(MFXUtils::getTitleText(myTitlePrefix, networkFileDialog.getFilename().c_str()));
3452 // enable save network
3454 // save network
3455 return onCmdSaveNetwork(sender, sel, ptr);
3456 } else {
3457 return 0;
3458 }
3459}
3460
3461
3462long
3463GNEApplicationWindow::onCmdSavePlainXML(FXObject* sender, FXSelector sel, void* ptr) {
3464 // first check if we have to set the output filename
3467 }
3468 // function onCmdSaveNetworkAs must be executed if this is the first save
3470 return onCmdSavePlainXMLAs(sender, sel, ptr);
3471 } else {
3472 // start saving plain XML
3473 getApp()->beginWaitCursor();
3474 try {
3475 // we use the prefix instead the netconvert config
3477 // save plain xml
3478 myNet->savePlain(plainXMLPrefix, myNetconvertOptions);
3479 // write info
3480 WRITE_MESSAGE(TLF("Plain XML saved with prefix '%'.", plainXMLPrefix));
3481 } catch (IOError& e) {
3482 // open message box
3483 GNEErrorBasicDialog(this, TL("Saving plain xml failed"), e.what());
3484 }
3485 // end saving plain XML
3486 getApp()->endWaitCursor();
3487 // set focus again in viewNet
3488 myViewNet->setFocus();
3489 }
3490 return 1;
3491}
3492
3493
3494long
3495GNEApplicationWindow::onCmdSavePlainXMLAs(FXObject* sender, FXSelector sel, void* ptr) {
3496 // get neteditConfig filename
3497 const GNEFileDialog plainXMLFileDialog(this, TL("plain XML file"),
3502 // continue depending of dialog
3503 if (plainXMLFileDialog.getResult() == GNEDialog::Result::ACCEPT) {
3504 // update default netconvert file
3506 // save plain xml
3507 return onCmdSavePlainXML(sender, sel, ptr);
3508 }
3509 return 1;
3510}
3511
3512
3513long
3515 // get neteditConfig filename
3516 const GNEFileDialog joinedJunctionsFileDialog(this, TL("joined junctions file"),
3521 // continue depending of dialog
3522 if (joinedJunctionsFileDialog.getResult() == GNEDialog::Result::ACCEPT) {
3523 getApp()->beginWaitCursor();
3524 try {
3525 myNet->saveJoined(joinedJunctionsFileDialog.getFilename());
3526 // write info
3527 WRITE_MESSAGE(TLF("Joined junctions saved to '%'.", joinedJunctionsFileDialog.getFilename()));
3528 } catch (IOError& e) {
3529 // opening error message
3530 GNEErrorBasicDialog(this, TL("Saving joined junctions failed"), e.what());
3531 }
3532 getApp()->endWaitCursor();
3533 // set focus again in viewNet
3534 myViewNet->setFocus();
3535 }
3536 return 1;
3537}
3538
3539
3540long
3541GNEApplicationWindow::onCmdSaveNeteditConfig(FXObject* sender, FXSelector sel, void* ptr) {
3542 // first check if netedit config is already saved
3544 return 1;
3545 }
3546 // Check if configuration file was already set at start of netedit or with a previous save
3548 return onCmdSaveNeteditConfigAs(sender, sel, ptr);
3549 } else {
3550 // save all elements giving automatic names based on patter if their file isn't defined
3551 if (onCmdSaveNetwork(sender, sel, ptr) != 1) {
3552 WRITE_MESSAGE(TL("Saving of netedit configuration aborted (due network)."));
3553 return 0;
3554 }
3555 if (onCmdSaveAdditionalElements(sender, sel, ptr) != 1) {
3556 WRITE_MESSAGE(TL("Saving of netedit configuration aborted (due additional file)."));
3557 return 0;
3558 }
3559 if (onCmdSaveDemandElements(sender, sel, ptr) != 1) {
3560 WRITE_MESSAGE(TL("Saving of netedit configuration aborted (due demand file)."));
3561 return 0;
3562 }
3563 if (onCmdSaveDataElements(sender, sel, ptr) != 1) {
3564 WRITE_MESSAGE(TL("Saving of netedit configuration aborted (due data file)."));
3565 return 0;
3566 }
3567 if (onCmdSaveMeanDataElements(sender, sel, ptr) != 1) {
3568 WRITE_MESSAGE(TL("Saving of netedit configuration aborted (due meanData file)."));
3569 return 0;
3570 }
3571 // get netedit config file
3573 // configuration
3574 std::ofstream out(StringUtils::transcodeToLocal(neteditConfigFile));
3575 if (out.good()) {
3576 const auto& neteditOptions = OptionsCont::getOptions();
3577 // write netedit config
3578 neteditOptions.writeConfiguration(out, true, false, false, neteditConfigFile, true);
3579 // write info
3580 WRITE_MESSAGE(TLF("Netedit configuration saved in '%'.", neteditConfigFile));
3581 // config saved
3583 // After saving a config successfully, add it into recent configs
3584 myMenuBarFile.myRecentConfigs.appendFile(neteditConfigFile.c_str());
3585 // if we have a sumo config defined, save it also
3587 // get SumoConfig file
3589 std::ofstream out(StringUtils::transcodeToLocal(sumoConfigFile));
3590 if (out.good()) {
3591 // before saving sumo config, check if force enable option junction-taz
3593 mySumoOptions.set("junction-taz", "true");
3594 }
3595 // write SUMO config
3596 mySumoOptions.writeConfiguration(out, true, false, false, sumoConfigFile, true);
3597 // write info
3598 WRITE_MESSAGE(TLF("SUMO configuration saved in '%'.", sumoConfigFile));
3599 // After saving a config successfully, add it into recent configs
3600 myMenuBarFile.myRecentConfigs.appendFile(sumoConfigFile.c_str());
3601 }
3602 }
3603 // save in plain XML (netconvert) if the option is enabled (usually used in netedit tests)
3604 if (neteditOptions.getBool("autosave-netconvert-file")) {
3605 onCmdSavePlainXML(sender, sel, ptr);
3606 }
3607 } else {
3608 WRITE_ERROR(TLF("Could not save netedit configuration in '%'.", neteditConfigFile));
3609 }
3610 out.close();
3611 return 1;
3612 }
3613}
3614
3615
3616long
3617GNEApplicationWindow::onCmdSaveNeteditConfigAs(FXObject* sender, FXSelector sel, void* ptr) {
3618 // get neteditConfig filename
3619 const GNEFileDialog neteditConfigFileDialog(this, TL("netedit config file"),
3624 // continue depending of dialog
3625 if (neteditConfigFileDialog.getResult() == GNEDialog::Result::ACCEPT) {
3626 // set file in file bucket handler
3628 // mark netedit config as unsaved
3630 // continue saving netedit config
3631 return onCmdSaveNeteditConfig(sender, sel, ptr);
3632 } else {
3633 return 0;
3634 }
3635}
3636
3637
3638long
3639GNEApplicationWindow::onUpdSaveNeteditConfig(FXObject* sender, FXSelector, void*) {
3640 // check if enable or disable save netedit config button
3641 if (myNet == nullptr) {
3642 sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
3644 sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
3645 } else if (!myNet->getSavingStatus()->isNeteditConfigSaved()) {
3646 sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
3647 } else {
3648 sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
3649 }
3650 // check if enable/disable save individual files
3651 if (myNet) {
3655 } else {
3657 }
3658 }
3659 return 1;
3660}
3661
3662
3663long
3664GNEApplicationWindow::onCmdSaveSumoConfig(FXObject* sender, FXSelector sel, void* ptr) {
3665 // first check if netedit config is already saved
3667 return 1;
3668 }
3669 // obtain netedit option container
3670 auto& neteditOptions = OptionsCont::getOptions();
3671 // reset containers
3672 neteditOptions.resetWritable();
3674 // Check if configuration file was already set at start of netedit or with a previous save
3676 return onCmdSaveSumoConfigAs(sender, sel, ptr);
3677 } else {
3678 // save all elements giving automatic names based on patter in their file isn't defined
3679 if (onCmdSaveNetwork(sender, sel, ptr) != 1) {
3680 WRITE_MESSAGE(TL("Saving of SUMO configuration aborted"));
3681 return 0;
3682 }
3683 if (onCmdSaveAdditionalElements(sender, sel, ptr) != 1) {
3684 WRITE_MESSAGE(TL("Saving of SUMO configuration aborted"));
3685 return 0;
3686 }
3687 if (onCmdSaveDemandElements(sender, sel, ptr) != 1) {
3688 WRITE_MESSAGE(TL("Saving of SUMO configuration aborted"));
3689 return 0;
3690 }
3691 if (onCmdSaveDataElements(sender, sel, ptr) != 1) {
3692 WRITE_MESSAGE(TL("Saving of SUMO configuration aborted"));
3693 return 0;
3694 }
3695 if (onCmdSaveMeanDataElements(sender, sel, ptr) != 1) {
3696 WRITE_MESSAGE(TL("Saving of SUMO configuration aborted"));
3697 return 0;
3698 }
3699 // get SumoConfig file
3701 // confinguration
3702 std::ofstream out(StringUtils::transcodeToLocal(sumoConfigFile));
3703 if (out.good()) {
3704 // before saving sumo config, check if force enable option junction-taz
3706 mySumoOptions.set("junction-taz", "true");
3707 }
3708 // write SUMO config
3709 mySumoOptions.writeConfiguration(out, true, false, false, sumoConfigFile, true);
3710 // write info
3711 WRITE_MESSAGE(TLF("SUMO configuration saved in '%'.", sumoConfigFile));
3712 // After saving a config successfully, add it into recent configs
3713 myMenuBarFile.myRecentConfigs.appendFile(sumoConfigFile.c_str());
3714 // if we have a netedit cong defined, save it also
3716 // get netedit config file
3718 // configuration
3719 std::ofstream out(StringUtils::transcodeToLocal(neteditConfigFile));
3720 if (out.good()) {
3721 // write netedit config
3722 neteditOptions.writeConfiguration(out, true, false, false, myFileBucketHandler->getDefaultFolder(FileBucket::Type::NETEDIT_CONFIG), true);
3723 // write info
3724 WRITE_MESSAGE(TLF("Netedit configuration saved in '%'.", neteditConfigFile));
3725 // config saved
3727 // After saving a config successfully, add it into recent configs
3728 myMenuBarFile.myRecentConfigs.appendFile(neteditConfigFile.c_str());
3729 }
3730 }
3731 // save in plain XML (netconvert) if the option is enabled (usually used in netedit tests)
3732 if (neteditOptions.getBool("autosave-netconvert-file")) {
3733 onCmdSavePlainXML(sender, sel, ptr);
3734 }
3735 } else {
3736 WRITE_MESSAGE(TLF("Could not save SUMO configuration in '%'.", sumoConfigFile));
3737 }
3738 out.close();
3739 return 1;
3740 }
3741}
3742
3743
3744long
3745GNEApplicationWindow::onCmdSaveSumoConfigAs(FXObject* sender, FXSelector sel, void* ptr) {
3746 // get sumoConfig filename
3747 const GNEFileDialog sumoConfigFileDialog(this, TL("sumo config file"),
3752 // continue depending of dialog
3753 if (sumoConfigFileDialog.getResult() == GNEDialog::Result::ACCEPT) {
3754 // set sumo config
3756 // mark netedit config as unsaved
3758 // check instead saving sumo config, save netedit config (this will save also the sumoConfig)
3760 return onCmdSaveNeteditConfig(sender, sel, ptr);
3761 } else {
3762 return onCmdSaveSumoConfig(sender, sel, ptr);
3763 }
3764 } else {
3765 return 0;
3766 }
3767}
3768
3769
3770long
3771GNEApplicationWindow::onUpdSaveSumoConfig(FXObject* sender, FXSelector, void*) {
3772 if (myNet == nullptr) {
3773 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
3775 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
3776 } else if (!myNet->getSavingStatus()->isSumoConfigSaved()) {
3777 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
3778 } else {
3779 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
3780 }
3781}
3782
3783
3784long
3785GNEApplicationWindow::onCmdSaveTLSPrograms(FXObject* obj, FXSelector sel, void* ptr) {
3786 // Check if TLS Programs file was already set at start of netedit or with a previous save
3788 return onCmdSaveTLSProgramsAs(obj, sel, ptr);
3789 } else {
3790 // Start saving TLS Programs
3791 getApp()->beginWaitCursor();
3792 try {
3793 // compute before saving
3794 myNet->computeNetwork(this, true); // GNEChange_TLS does not triggere GNENet:requireRecompute
3796 // write info
3798 } catch (IOError& e) {
3799 // open error message box
3800 GNEErrorBasicDialog(this, TL("Saving TLS Programs failed"), e.what());
3801 }
3803 getApp()->endWaitCursor();
3804 // set focus again in viewNet
3805 myViewNet->setFocus();
3806 }
3807 return 1;
3808}
3809
3810
3811long
3812GNEApplicationWindow::onUpdSaveTLSPrograms(FXObject* sender, FXSelector, void*) {
3813 if (myNet == nullptr) {
3814 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
3815 } else {
3816 // check if there is at least one TLS
3817 for (const auto& junction : myNet->getAttributeCarriers()->getJunctions()) {
3818 if (junction.second->getNBNode()->getControllingTLS().size() > 0) {
3819 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
3820 }
3821 }
3822 // no TLS, then disable
3823 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
3824 }
3825}
3826
3827
3828long
3829GNEApplicationWindow::onCmdSaveEdgeTypes(FXObject* obj, FXSelector sel, void* ptr) {
3830 // Check if edgeType file was already set at start of netedit or with a previous save
3832 return onCmdSaveEdgeTypesAs(obj, sel, ptr);
3833 } else {
3834 // Start saving edgeTypes
3835 getApp()->beginWaitCursor();
3836 try {
3838 // save edge types
3839 myNet->saveEdgeTypes(edgeTypeFile);
3840 // write info
3841 WRITE_MESSAGE(TLF("EdgeType saved in '%'.", edgeTypeFile));
3842 } catch (IOError& e) {
3843 // open error message box
3844 GNEErrorBasicDialog(this, TL("Saving edgeTypes failed"), e.what());
3845 }
3847 getApp()->endWaitCursor();
3848 }
3849 return 1;
3850}
3851
3852
3853long
3854GNEApplicationWindow::onUpdSaveEdgeTypes(FXObject* sender, FXSelector, void*) {
3855 // check if net exist and there are edge types
3856 if (myNet && (myNet->getAttributeCarriers()->getEdgeTypes().size() > 0)) {
3857 sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
3858 } else {
3859 sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
3860 }
3861 return 1;
3862}
3863
3864
3865long
3866GNEApplicationWindow::onCmdSaveTLSProgramsAs(FXObject* sender, FXSelector sel, void* ptr) {
3867 // get TLS file
3868 const GNEFileDialog TLSfileDialog(this, TL("Traffic Light definitions file"),
3873 // continue depending of dialog
3874 if (TLSfileDialog.getResult() == GNEDialog::Result::ACCEPT) {
3875 // set tls type in bucket
3877 // enable save netedit config
3879 // set focus again in viewNet
3880 myViewNet->setFocus();
3881 // save TLS Programs
3882 return onCmdSaveTLSPrograms(sender, sel, ptr);
3883 } else {
3884 return 1;
3885 }
3886}
3887
3888
3889long
3890GNEApplicationWindow::onCmdSaveEdgeTypesAs(FXObject* sender, FXSelector sel, void* ptr) {
3891 // get network file file
3892 const GNEFileDialog edgeTypeFileDialog(this, TL("EdgeTypes file"),
3897 // continue depending of dialog
3898 if (edgeTypeFileDialog.getResult() == GNEDialog::Result::ACCEPT) {
3899 // set tls type in bucket
3901 // enable save netedit config
3903 // set focus again in viewNet
3904 myViewNet->setFocus();
3905 // save edgeTypes
3906 return onCmdSaveEdgeTypes(sender, sel, ptr);
3907 } else {
3908 return 1;
3909 }
3910}
3911
3912
3913long
3915 // get file
3916 const GNEFileDialog additionalFileDialog(this, TL("Additional elements file"),
3921 // continue depending of dialog
3922 if (additionalFileDialog.getResult() == GNEDialog::Result::ACCEPT) {
3923 // flag for save current saving status
3924 const auto previouslySaved = myNet->getSavingStatus()->isAdditionalsSaved();
3925 // get (or create) bucket for this new file
3926 auto bucket = myFileBucketHandler->getBucket(FileBucket::Type::ADDITIONAL, additionalFileDialog.getFilename(), true);
3927 // disable validation for additionals
3928 XMLSubSys::setValidation("never", "auto", "auto");
3929 // Create additional handler
3930 GNEGeneralHandler generalHandler(myNet, bucket, myAllowUndoRedoLoading ? myAllowUndoRedo : false);
3931 // begin undoList operation
3932 myUndoList->begin(Supermode::NETWORK, GUIIcon::SUPERMODENETWORK, TLF("load additionals from '%'", bucket->getFilename()));
3933 // Run parser
3934 if (!generalHandler.parse()) {
3935 // write error
3936 WRITE_ERROR(TLF("Loading of additional file '%' failed.", bucket->getFilename()));
3937 } else {
3938 // write info
3939 WRITE_MESSAGE(TLF("Loading of additional file '%' successfully.", bucket->getFilename()));
3940 // enable save if there is errors loading additionals
3941 if (previouslySaved && !generalHandler.isErrorCreatingElement()) {
3943 }
3944 }
3945 // end undoList operation
3946 myUndoList->end();
3947 // restore validation for additionals
3948 XMLSubSys::setValidation("auto", "auto", "auto");
3949 // check if clear undoList
3951 myUndoList->clear();
3952 }
3953 update();
3954 }
3955 return 1;
3956}
3957
3958
3959long
3961 // disable validation for additionals
3962 XMLSubSys::setValidation("never", "auto", "auto");
3963 // begin undoList operation
3964 myUndoList->begin(Supermode::DEMAND, GUIIcon::SUPERMODENETWORK, TL("reloading additionals"));
3965 // clear additionals
3967 // reload additional elements stored in options
3968 loadAdditionalElements("reloading");
3969 // end undoList operation
3970 myUndoList->end();
3971 // restore validation for additionals
3972 XMLSubSys::setValidation("auto", "auto", "auto");
3973 // check if clear undoList
3975 myUndoList->clear();
3976 }
3977 update();
3978 return 1;
3979}
3980
3981
3982long
3983GNEApplicationWindow::onUpdReloadAdditionalElements(FXObject* sender, FXSelector, void*) {
3984 if (myViewNet == nullptr) {
3985 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
3987 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
3988 } else {
3989 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
3990 }
3991}
3992
3993
3994long
3995GNEApplicationWindow::onCmdSaveAdditionalElements(FXObject* sender, FXSelector sel, void* ptr) {
3996 const auto savingFileHandler = myFileBucketHandler;
3997 // get option container
3998 auto& neteditOptions = OptionsCont::getOptions();
3999 // check if we're forcing to saving additionals
4001 neteditOptions.getBool("force-saving") &&
4003 WRITE_MESSAGE(TL("Force save additional elements"));
4004 } else if (myNet->getSavingStatus()->isAdditionalsSaved()) {
4005 // nothing to save
4006 return 1;
4007 }
4008 // check if we have to define a default filename
4010 savingFileHandler->setDefaultFilenameFile(FileBucket::Type::ADDITIONAL, myFileBucketHandler->getConfigFilePrefix(".add.xml"));
4011 }
4012 // check if we have to open save as dialog
4013 if (!savingFileHandler->isFilenameDefined(FileBucket::Type::ADDITIONAL)) {
4014 // choose file to save
4015 return onCmdSaveAdditionalElementsAs(sender, sel, ptr);
4016 } else {
4017 // always recompute before saving
4018 myNet->computeNetwork(this);
4019 try {
4020 // compute before saving (for detectors positions)
4021 myNet->computeNetwork(this);
4022 // save additionals
4023 const bool savingResult = myNet->saveAdditionals();
4024 // show info
4025 if (savingResult) {
4026 WRITE_MESSAGE(TL("Additionals saved."));
4027 return 1;
4028 } else {
4029 WRITE_MESSAGE(TL("Saving additional aborted."));
4030 return 0;
4031 }
4032 } catch (IOError& e) {
4033 // open error message box
4034 GNEErrorBasicDialog(this, TL("Saving additional elements failed"), e.what());
4035 }
4036 return 0;
4037 }
4038}
4039
4040
4041long
4042GNEApplicationWindow::onCmdSaveAdditionalElementsAs(FXObject* sender, FXSelector sel, void* ptr) {
4043 // get additional file
4044 const GNEFileDialog additionalFileDialog(this, TL("Additional elements as"),
4049 // continue depending of dialog
4050 if (additionalFileDialog.getResult() == GNEDialog::Result::ACCEPT) {
4051 // update default name
4053 // save additional
4054 return onCmdSaveAdditionalElements(sender, sel, ptr);
4055 } else {
4056 return 0;
4057 }
4058}
4059
4060
4061long
4062GNEApplicationWindow::onCmdSaveAdditionalElementsUnified(FXObject* sender, FXSelector sel, void* ptr) {
4063 // get additional file
4064 const GNEFileDialog additionalFileDialog(this, TL("Additional elements in unified file"),
4069 // continue depending of dialog
4070 if (additionalFileDialog.getResult() == GNEDialog::Result::ACCEPT) {
4071 // use the file as default file
4073 // begin undoList operation
4074 myUndoList->begin(Supermode::NETWORK, GUIIcon::SUPERMODENETWORK, TLF("saving of unified additional elements in '%'", additionalFileDialog.getFilename()));
4075 // iterate over all demand elementes and change file
4076 for (const auto& additionalElementTag : myNet->getAttributeCarriers()->getAdditionals()) {
4077 for (const auto& additionalElement : additionalElementTag.second) {
4078 additionalElement.second->setAttribute(GNE_ATTR_SAVEFILE, additionalFileDialog.getFilename(), myUndoList);
4079 }
4080 }
4081 // end undoList operation
4082 myUndoList->end();
4083 // save additionals
4084 return onCmdSaveAdditionalElements(sender, sel, ptr);
4085 } else {
4086 return 0;
4087 }
4088}
4089
4090
4091long
4093 // get juPedSim file
4094 const GNEFileDialog juPedSimfileDialog(this, TL("JuPedSim elements file"),
4099 // continue depending of dialog
4100 if (juPedSimfileDialog.getResult() == GNEDialog::Result::ACCEPT) {
4101 try {
4102 // save additionals
4103 const bool savingResult = myNet->saveJuPedSimElements(juPedSimfileDialog.getFilename());
4104 // set focus again in viewNet
4105 myViewNet->setFocus();
4106 // show info
4107 if (savingResult) {
4108 WRITE_MESSAGE(TL("JuPedSim elements saved."));
4109 return 1;
4110 } else {
4111 WRITE_MESSAGE(TL("Saving JuPedSim elements aborted."));
4112 return 0;
4113 }
4114 } catch (IOError& e) {
4115 // open error message box
4116 GNEErrorBasicDialog(this, TL("Saving JuPedSim elements failed"), e.what());
4117 }
4118 }
4119 return 0;
4120}
4121
4122
4123long
4125 // get file
4126 const GNEFileDialog routeFileDialog(this, TL("Route elements file"),
4131 // continue depending of dialog
4132 if (routeFileDialog.getResult() == GNEDialog::Result::ACCEPT) {
4133 // save previous demand element status saving
4134 const auto previouslySaved = myNet->getSavingStatus()->isDemandElementsSaved();
4135 // disable validation for additionals
4136 XMLSubSys::setValidation("never", "auto", "auto");
4137 // get (or create) bucket for this new file
4138 auto bucket = myFileBucketHandler->getBucket(FileBucket::Type::DEMAND, routeFileDialog.getFilename(), true);
4139 // Create generic handler
4141 // begin undoList operation
4142 myUndoList->begin(Supermode::DEMAND, GUIIcon::SUPERMODEDEMAND, TLF("loading demand elements from '%'", bucket->getFilename()));
4143 // Run parser for additionals
4144 if (!handler.parse()) {
4145 // write error
4146 WRITE_ERROR(TLF("Loading of route file '%' failed.", bucket->getFilename()));
4147 } else {
4148 // show info
4149 WRITE_MESSAGE(TLF("Loading of route file '%' successfully.", bucket->getFilename()));
4150 // enable demand elements if there is an error creating element
4151 if (previouslySaved && !handler.isErrorCreatingElement()) {
4153 }
4154 }
4155 // end undoList operation
4156 myUndoList->end();
4157 // restore validation
4158 XMLSubSys::setValidation("auto", "auto", "auto");
4159 // check if clear undoList
4161 myUndoList->clear();
4162 }
4163 update();
4164 }
4165 return 1;
4166}
4167
4168
4169long
4171 // disable validation for additionals
4172 XMLSubSys::setValidation("never", "auto", "auto");
4173 // begin undoList operation
4174 myUndoList->begin(Supermode::DEMAND, GUIIcon::SUPERMODEDEMAND, TL("reloading demand elements"));
4175 // clear demand elements
4177 // reload demand elements stored in options
4178 loadDemandElements("reloading");
4179 // end undoList operation and update view
4180 myUndoList->end();
4181 // restore validation for demand
4182 XMLSubSys::setValidation("auto", "auto", "auto");
4183 // check if clear undoList
4185 myUndoList->clear();
4186 }
4187 update();
4188 return 1;
4189}
4190
4191
4192long
4193GNEApplicationWindow::onUpdReloadDemandElements(FXObject* sender, FXSelector, void*) {
4194 if (myViewNet == nullptr) {
4195 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
4197 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
4198 } else {
4199 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
4200 }
4201}
4202
4203
4204long
4205GNEApplicationWindow::onCmdSaveDemandElements(FXObject* sender, FXSelector sel, void* ptr) {
4206 const auto savingFileHandler = myFileBucketHandler;
4207 // get option container
4208 auto& neteditOptions = OptionsCont::getOptions();
4209 // check if we're forcing to saving demand elements
4211 neteditOptions.getBool("force-saving") &&
4213 WRITE_MESSAGE(TL("Force save demand elements"));
4214 } else if (myNet->getSavingStatus()->isDemandElementsSaved()) {
4215 // nothing to save
4216 return 1;
4217 }
4218 // check if we have to define a default filename
4220 savingFileHandler->setDefaultFilenameFile(FileBucket::Type::DEMAND, myFileBucketHandler->getConfigFilePrefix(".rou.xml"));
4221 }
4222 // check if we have to open save as dialog
4223 if (!savingFileHandler->isFilenameDefined(FileBucket::Type::DEMAND)) {
4224 // choose file to save
4225 return onCmdSaveDemandElementsAs(sender, sel, ptr);
4226 } else {
4227 // always recompute before saving
4228 myNet->computeNetwork(this);
4229 try {
4230 // save demand elements
4231 const bool savingResult = myNet->saveDemandElements();
4232 // show info
4233 if (savingResult) {
4234 WRITE_MESSAGE(TL("Demand elements saved."));
4235 return 1;
4236 } else {
4237 WRITE_MESSAGE(TL("Saving demand elements aborted."));
4238 return 0;
4239 }
4240 } catch (IOError& e) {
4241 // open error message box
4242 GNEErrorBasicDialog(this, TL("Saving demand elements failed"), e.what());
4243 }
4244 }
4245 return 0;
4246}
4247
4248
4249long
4250GNEApplicationWindow::onCmdSaveDemandElementsAs(FXObject* sender, FXSelector sel, void* ptr) {
4251 // get route file
4252 const GNEFileDialog routeFileDialog(this, TL("Route elements"),
4257 // continue depending of dialog
4258 if (routeFileDialog.getResult() == GNEDialog::Result::ACCEPT) {
4259 // update default name
4261 // save demand elements
4262 return onCmdSaveDemandElements(sender, sel, ptr);
4263 } else {
4264 return 0;
4265 }
4266}
4267
4268
4269long
4270GNEApplicationWindow::onCmdSaveDemandElementsUnified(FXObject* sender, FXSelector sel, void* ptr) {
4271 // get route file
4272 const GNEFileDialog routeFileDialog(this, TL("Route elements file in unified file"),
4277 // continue depending of dialog
4278 if (routeFileDialog.getResult() == GNEDialog::Result::ACCEPT) {
4279 // use the file as default file
4281 // begin undoList operation
4282 myUndoList->begin(Supermode::DEMAND, GUIIcon::SUPERMODEDEMAND, TLF("saving of unified demand elements in '%'.", routeFileDialog.getFilename()));
4283 // iterate over all demand elementes and change file
4284 for (const auto& demandElementTag : myNet->getAttributeCarriers()->getDemandElements()) {
4285 for (const auto& demandElement : demandElementTag.second) {
4286 demandElement.second->setAttribute(GNE_ATTR_SAVEFILE, routeFileDialog.getFilename(), myUndoList);
4287 }
4288 }
4289 // end undoList operation
4290 myUndoList->end();
4291 // save demand elements
4292 return onCmdSaveDemandElements(sender, sel, ptr);
4293 } else {
4294 return 0;
4295 }
4296}
4297
4298
4299long
4300GNEApplicationWindow::onCmdOpenDataElements(FXObject*, FXSelector, void*) {
4301 // get file
4302 const GNEFileDialog dataFileDialog(this, TL("Data elements file"),
4307 // continue depending of dialog
4308 if (dataFileDialog.getResult() == GNEDialog::Result::ACCEPT) {
4309 // save previous demand element status saving
4310 const auto previouslySaved = myNet->getSavingStatus()->isDataElementsSaved();
4311 // get (or create) bucket for this new file
4312 auto bucket = myFileBucketHandler->getBucket(FileBucket::Type::DATA, dataFileDialog.getFilename(), true);
4313 // disable update data
4315 // disable validation for data elements
4316 XMLSubSys::setValidation("never", "auto", "auto");
4317 // Create data handler
4318 GNEDataHandler dataHandler(myNet, bucket, myAllowUndoRedoLoading ? myAllowUndoRedo : false);
4319 // begin undoList operation
4320 myUndoList->begin(Supermode::DATA, GUIIcon::SUPERMODEDATA, TLF("loading data elements from '%'.", bucket->getFilename()));
4321 // Run data parser
4322 if (!dataHandler.parse()) {
4323 // write error
4324 WRITE_ERROR(TLF("Loading of data file '%' failed.", bucket->getFilename()));
4325 } else {
4326 // show info
4327 WRITE_MESSAGE(TLF("Loading of data file '%' successfully.", bucket->getFilename()));
4328 // enable demand elements if there is an error creating element
4329 if (previouslySaved && !dataHandler.isErrorCreatingElement()) {
4331 }
4332 }
4333 // end undoList operation
4334 myUndoList->end();
4335 // enable update data
4337 // restore validation for data
4338 XMLSubSys::setValidation("auto", "auto", "auto");
4339 // check if clear undoList
4341 myUndoList->clear();
4342 }
4343 update();
4344 }
4345 return 1;
4346}
4347
4348
4349long
4351 // disable update data
4353 // disable validation for additionals
4354 XMLSubSys::setValidation("never", "auto", "auto");
4355 // begin undoList operation
4356 myUndoList->begin(Supermode::DATA, GUIIcon::SUPERMODEDATA, TL("reloading data elements"));
4357 // clear data elements
4359 // reload data elements stored in options
4360 loadDataElements("reloading");
4361 // restore validation for data
4362 XMLSubSys::setValidation("auto", "auto", "auto");
4363 // end undoList operation and update view
4364 myUndoList->end();
4365 // enable update data
4367 // check if clear undoList
4369 myUndoList->clear();
4370 }
4371 update();
4372 return 1;
4373}
4374
4375
4376long
4377GNEApplicationWindow::onUpdReloadDataElements(FXObject* sender, FXSelector, void*) {
4378 if (myViewNet == nullptr) {
4379 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
4381 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
4382 } else {
4383 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
4384 }
4385}
4386
4387
4388long
4389GNEApplicationWindow::onCmdSaveDataElements(FXObject* sender, FXSelector sel, void* ptr) {
4390 const auto savingFileHandler = myFileBucketHandler;
4391 // get option container
4392 auto& neteditOptions = OptionsCont::getOptions();
4393 // check if we're forcing to saving data elements
4395 neteditOptions.getBool("force-saving") &&
4397 WRITE_MESSAGE(TL("Force save data elements"));
4398 } else if (myNet->getSavingStatus()->isDataElementsSaved()) {
4399 // nothing to save
4400 return 1;
4401 }
4402 // check if we have to define a default filename
4404 savingFileHandler->setDefaultFilenameFile(FileBucket::Type::DATA, myFileBucketHandler->getConfigFilePrefix(".dat.xml"));
4405 }
4406 // check if we have to open save as dialog
4407 if (!savingFileHandler->isFilenameDefined(FileBucket::Type::DATA)) {
4408 return onCmdSaveDataElementsAs(sender, sel, ptr);
4409 } else {
4410 try {
4411 // save data elements
4412 const bool savingResult = myNet->saveDataElements();
4413 // show info
4414 if (savingResult) {
4415 WRITE_MESSAGE(TL("Data elements saved."));
4416 return 1;
4417 } else {
4418 WRITE_MESSAGE(TL("Saving demand elements aborted."));
4419 return 0;
4420 }
4421 } catch (IOError& e) {
4422 // open error message box
4423 GNEErrorBasicDialog(this, TL("Saving data elements failed"), e.what());
4424 }
4425 }
4426 return 0;
4427}
4428
4429
4430long
4431GNEApplicationWindow::onCmdSaveDataElementsAs(FXObject* sender, FXSelector sel, void* ptr) {
4432 // get data file
4433 const GNEFileDialog dataFileDialog(this, TL("Data elements file"),
4438 // continue depending of dialog
4439 if (dataFileDialog.getResult() == GNEDialog::Result::ACCEPT) {
4440 // update default name
4442 // save data elements
4443 return onCmdSaveDataElements(sender, sel, ptr);
4444 } else {
4445 return 0;
4446 }
4447}
4448
4449
4450long
4451GNEApplicationWindow::onCmdSaveDataElementsUnified(FXObject* sender, FXSelector sel, void* ptr) {
4452 // get data file
4453 const GNEFileDialog dataFileDialog(this, TL("Data elements file in unified file"),
4458 // continue depending of dialog
4459 if (dataFileDialog.getResult() == GNEDialog::Result::ACCEPT) {
4460 // use the file as default file
4462 // begin undoList operation
4463 myUndoList->begin(Supermode::DATA, GUIIcon::SUPERMODEDATA, TLF("saving of unified data elements in '%'", dataFileDialog.getFilename()));
4464 // iterate over all demand elementes and change file
4465 for (const auto& dataSet : myNet->getAttributeCarriers()->getDataSets()) {
4466 dataSet.second->setAttribute(GNE_ATTR_SAVEFILE, dataFileDialog.getFilename(), myUndoList);
4467 }
4468 // end undoList operation
4469 myUndoList->end();
4470 // save data elements
4471 return onCmdSaveDataElements(sender, sel, ptr);
4472 } else {
4473 return 0;
4474 }
4475}
4476
4477
4478long
4480 // get file
4481 const GNEFileDialog meanDataFileDialog(this, TL("MeanData elements file"),
4486 // continue depending of dialog
4487 if (meanDataFileDialog.getResult() == GNEDialog::Result::ACCEPT) {
4488 // save previous demand element status saving
4489 const auto previouslySaved = myNet->getSavingStatus()->isMeanDatasSaved();
4490 // get (or create) bucket for this new file
4491 auto bucket = myFileBucketHandler->getBucket(FileBucket::Type::MEANDATA, meanDataFileDialog.getFilename(), true);
4492 // disable validation for meanDatas
4493 XMLSubSys::setValidation("never", "auto", "auto");
4494 // Create meanData handler
4495 GNEGeneralHandler generalHandler(myNet, bucket, myAllowUndoRedoLoading ? myAllowUndoRedo : false);
4496 // begin undoList operation
4497 myUndoList->begin(Supermode::DATA, GUIIcon::SUPERMODEDATA, TLF("load meanDatas from '%'", bucket->getFilename()));
4498 // Run parser
4499 if (!generalHandler.parse()) {
4500 // write error
4501 WRITE_ERROR(TLF("Loading of meandata file '%' failed.", bucket->getFilename()));
4502 } else {
4503 // show info
4504 WRITE_MESSAGE(TLF("Loading of meandata file '%' successfully.", bucket->getFilename()));
4505 // enable demand elements if there is an error creating element
4506 if (previouslySaved && !generalHandler.isErrorCreatingElement()) {
4508 }
4509 }
4510 // end undoList operation
4511 myUndoList->end();
4512 // restore validation for meanDatas
4513 XMLSubSys::setValidation("auto", "auto", "auto");
4514 // check if clear undoList
4516 myUndoList->clear();
4517 }
4518 update();
4519 }
4520 return 1;
4521}
4522
4523
4524long
4526 // disable validation for meanDatas
4527 XMLSubSys::setValidation("never", "auto", "auto");
4528 // begin undoList operation
4530 // clear meanDatas
4532 // reload meanData elements stored in options
4533 loadMeanDataElements("reloading");
4534 // end undoList operation and update view
4535 myUndoList->end();
4536 // restore validation for meanDatas
4537 XMLSubSys::setValidation("auto", "auto", "auto");
4538 // check if clear undoList
4540 myUndoList->clear();
4541 }
4542 update();
4543 return 1;
4544}
4545
4546
4547long
4548GNEApplicationWindow::onUpdReloadMeanDataElements(FXObject* sender, FXSelector, void*) {
4549 if (myViewNet == nullptr) {
4550 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
4552 return sender->handle(this, FXSEL(SEL_COMMAND, ID_DISABLE), nullptr);
4553 } else {
4554 return sender->handle(this, FXSEL(SEL_COMMAND, ID_ENABLE), nullptr);
4555 }
4556}
4557
4558
4559long
4560GNEApplicationWindow::onCmdSaveMeanDataElements(FXObject* sender, FXSelector sel, void* ptr) {
4561 const auto savingFileHandler = myFileBucketHandler;
4562 // get option container
4563 auto& neteditOptions = OptionsCont::getOptions();
4564 // check if we're forcing to saving meandata elements
4566 neteditOptions.getBool("force-saving") &&
4568 WRITE_MESSAGE(TL("Force save meandata elements"));
4569 } else if (myNet->getSavingStatus()->isMeanDatasSaved()) {
4570 // nothing to save
4571 return 1;
4572 }
4573 // check if we have to define a default filename
4575 savingFileHandler->setDefaultFilenameFile(FileBucket::Type::MEANDATA, myFileBucketHandler->getConfigFilePrefix(".dat.add.xml"));
4576 }
4577 // check if we have to open save as dialog
4578 if (!savingFileHandler->isFilenameDefined(FileBucket::Type::MEANDATA)) {
4579 return onCmdSaveMeanDataElementsAs(sender, sel, ptr);
4580 } else {
4581 try {
4582 // compute before saving
4583 myNet->computeNetwork(this);
4584 // save demand elements
4585 const bool savingResult = myNet->saveMeanDatas();
4586 // show info
4587 if (savingResult) {
4588 WRITE_MESSAGE(TL("MeanDatas elements saved"));
4589 return 1;
4590 } else {
4591 WRITE_MESSAGE(TL("Saving MeanData elements aborted"));
4592 return 0;
4593 }
4594 } catch (IOError& e) {
4595 // open error message box
4596 GNEErrorBasicDialog(this, TL("Saving demand elements failed!"), e.what());
4597 }
4598 }
4599 return 0;
4600}
4601
4602
4603long
4604GNEApplicationWindow::onCmdSaveMeanDataElementsAs(FXObject* sender, FXSelector sel, void* ptr) {
4605 // get meanData file
4606 const GNEFileDialog meanDataFileDialog(this, TL("MeanData elements"),
4611 // continue depending of dialog
4612 if (meanDataFileDialog.getResult() == GNEDialog::Result::ACCEPT) {
4613 // update default name
4615 // save meanDatas
4616 return onCmdSaveMeanDataElements(sender, sel, ptr);
4617 } else {
4618 return 0;
4619 }
4620}
4621
4622
4623long
4624GNEApplicationWindow::onCmdSaveMeanDataElementsUnified(FXObject* sender, FXSelector sel, void* ptr) {
4625 // get meanData file
4626 const GNEFileDialog meanDataFileDialog(this, TL("MeanData elements file in unified file"),
4631 // continue depending of dialog
4632 if (meanDataFileDialog.getResult() == GNEDialog::Result::ACCEPT) {
4633 // use the file as default file
4635 // begin undoList operation
4636 myUndoList->begin(Supermode::DATA, GUIIcon::MODEMEANDATA, TLF("saving of unified mean data elements in '%'", meanDataFileDialog.getFilename()));
4637 // iterate over all demand elementes and change file
4638 for (const auto& meanDataTag : myNet->getAttributeCarriers()->getMeanDatas()) {
4639 for (const auto& meanData : meanDataTag.second) {
4640 meanData.second->setAttribute(GNE_ATTR_SAVEFILE, meanDataFileDialog.getFilename(), myUndoList);
4641 }
4642 }
4643 // end undoList operation
4644 myUndoList->end();
4645 // save meanDatas
4646 return onCmdSaveMeanDataElements(sender, sel, ptr);
4647 } else {
4648 return 0;
4649 }
4650}
4651
4652
4653bool
4654GNEApplicationWindow::askSaveElements(FXObject* sender, FXSelector sel, void* ptr) {
4655 if (myNet) {
4657 const auto saveNetwork = myNet->getSavingStatus()->askSaveNetwork(commonResult);
4658 const auto saveAdditionalElements = myNet->getSavingStatus()->askSaveAdditionalElements(commonResult);
4659 const auto saveDemandElements = myNet->getSavingStatus()->askSaveDemandElements(commonResult);
4660 const auto saveDataElements = myNet->getSavingStatus()->askSaveDataElements(commonResult);
4661 const auto saveMeanDataElements = myNet->getSavingStatus()->askSaveMeanDataElements(commonResult);
4662 // first check if abort saving
4663 if (commonResult == GNEDialog::Result::ABORT) {
4664 return false;
4665 }
4666 // save every type of file
4667 if ((saveNetwork == GNEDialog::Result::ACCEPT) &&
4668 (onCmdSaveNetwork(sender, sel, ptr) != 1)) {
4669 return false;
4670 }
4671 if ((saveAdditionalElements == GNEDialog::Result::ACCEPT) &&
4672 (onCmdSaveAdditionalElements(sender, sel, ptr) != 1)) {
4673 return false;
4674 }
4675 if ((saveDemandElements == GNEDialog::Result::ACCEPT) &&
4676 (onCmdSaveDemandElements(sender, sel, ptr) != 1)) {
4677 return false;
4678 }
4679 if ((saveDataElements == GNEDialog::Result::ACCEPT) &&
4680 (onCmdSaveDataElements(sender, sel, ptr) != 1)) {
4681 return false;
4682 }
4683 if ((saveMeanDataElements == GNEDialog::Result::ACCEPT) &&
4684 (onCmdSaveMeanDataElements(sender, sel, ptr) != 1)) {
4685 return false;
4686 }
4687 // restore focus in viewNet
4688 myViewNet->setFocus();
4689 // clear undo list
4690 clearUndoList();
4691 // all saved, then continue
4692 return true;
4693 } else {
4694 // nothing to do, then continue
4695 return true;
4696 }
4697}
4698
4699
4700void
4702 // check that view exists
4703 if (myViewNet) {
4705 }
4706 // update require recomputing
4708}
4709
4710
4711void
4713 // remove lock hotkeys
4715 // check supermode
4716 if (supermode == Supermode::NETWORK) {
4717 // menu commands
4721 // lock
4725 // processing
4730 } else if (supermode == Supermode::DEMAND) {
4731 // menu commands
4735 // lock
4739 // processing
4744 } else if (supermode == Supermode::DATA) {
4745 // menu commands
4749 // lock
4753 // processing
4758 } else {
4759 // menu commands
4764 // lock
4768 // processing
4772 }
4773 // continue depending of view
4774 if (myViewNet) {
4778 } else if (myViewNet->getEditModes().isJuPedSimView()) {
4781 }
4782 }
4783}
4784
4785
4786bool
4790
4791
4792void
4796
4797
4798void
4800 myUndoRedoListEnabled = reason;
4801}
4802
4803
4804const std::string&
4808
4809
4810void
4812 if (myViewNet) {
4813 // destroy Popup (to avoid crashes)
4815 }
4816 // clear undo list and return true to continue with closing/reload
4817 myUndoList->clear();
4818}
4819
4820
4825
4826
4831
4832
4837
4838
4843
4844
4849
4850
4855
4856
4861
4862
4863void
4865 // get netedit option container
4866 auto& neteditOptions = OptionsCont::getOptions();
4867 // get additional files (don't use reference because it's modified during loading)
4868 const StringVector additionalFiles = neteditOptions.getStringVector("additional-files");
4869 // check if we have additionals to load
4870 if (myNet && (additionalFiles.size() > 0)) {
4871 // disable validation for additionals
4872 XMLSubSys::setValidation("never", "auto", "auto");
4873 // begin undolist
4874 myUndoList->begin(Supermode::NETWORK, GUIIcon::SUPERMODENETWORK, TLF("% additional elements from '%'", operation, toString(additionalFiles)));
4875 // use this flag for mark all elements as saved after loading, if it was sucessfully
4876 bool setSaved = additionalFiles.size() == 1;
4877 // iterate over every additional file
4878 for (const auto& file : additionalFiles) {
4879 // check if ignore missing inputs
4880 if (FileHelpers::isReadable(file) || !neteditOptions.getBool("ignore-missing-inputs")) {
4881 WRITE_MESSAGE(TLF("% additionals from '%'.", operation, file));
4882 // get (or create) bucket for this new file
4884 // declare general handler
4885 GNEGeneralHandler generalHandler(myNet, bucket, myAllowUndoRedoLoading ? myAllowUndoRedo : false);
4886 // check if force overwritte
4887 if (operation == "reloading") {
4888 generalHandler.forceOverwriteElements();
4889 }
4890 // Run parser
4891 if (!generalHandler.parse()) {
4892 WRITE_ERROR(TLF("% of '%' failed.", operation, file));
4893 }
4894 setSaved &= !generalHandler.isErrorCreatingElement();
4895 }
4896 }
4897 // end undo list
4898 myUndoList->end();
4899 // disable validation for additionals
4900 XMLSubSys::setValidation("auto", "auto", "auto");
4901 if (setSaved) {
4903 }
4904 // check if clear undoList
4906 myUndoList->clear();
4907 }
4908 }
4909}
4910
4911
4912void
4913GNEApplicationWindow::loadDemandElements(const std::string operation) {
4914 // get netedit option container
4915 auto& neteditOptions = OptionsCont::getOptions();
4916 // get demand files (don't use reference because it's modified during loading)
4917 const StringVector demandFiles = neteditOptions.getStringVector("route-files");
4918 // check if we have demand files to load
4919 if (myNet && (demandFiles.size() > 0)) {
4920 // disable validation for additionals
4921 XMLSubSys::setValidation("never", "auto", "auto");
4922 // begin undolist
4923 myUndoList->begin(Supermode::DEMAND, GUIIcon::SUPERMODEDEMAND, TLF("% demand elements from '%'", operation, toString(demandFiles)));
4924 // use this flag for mark all elements as saved after loading, if it was sucessfully
4925 bool setSaved = demandFiles.size() == 1;
4926 // iterate over every demand file
4927 for (const auto& file : demandFiles) {
4928 // check if ignore missing inputs
4929 if (FileHelpers::isReadable(file) || !neteditOptions.getBool("ignore-missing-inputs")) {
4930 WRITE_MESSAGE(TLF("% demand elements from '%'.", operation, file));
4931 // get (or create) bucket for this new file
4932 auto bucket = myFileBucketHandler->getBucket(FileBucket::Type::DEMAND, file, true);
4933 // declare general handler
4934 GNEGeneralHandler generalHandler(myNet, bucket, myAllowUndoRedoLoading ? myAllowUndoRedo : false);
4935 // check if force overwritte
4936 if (operation == "reloading") {
4937 generalHandler.forceOverwriteElements();
4938 }
4939 // Run parser
4940 if (!generalHandler.parse()) {
4941 WRITE_ERROR(TLF("% of '%' failed.", operation, file));
4942 }
4943 setSaved &= !generalHandler.isErrorCreatingElement();
4944 }
4945 }
4946 // end undo list
4947 myUndoList->end();
4948 // disable validation for additionals
4949 XMLSubSys::setValidation("auto", "auto", "auto");
4950 if (setSaved) {
4952 }
4953 // check if clear undoList
4955 myUndoList->clear();
4956 }
4957 }
4958}
4959
4960
4961void
4962GNEApplicationWindow::loadDataElements(const std::string operation) {
4963 // get option container
4964 auto& neteditOptions = OptionsCont::getOptions();
4965 // get data files (don't use reference because it's modified during loading)
4966 const StringVector dataFiles = neteditOptions.getStringVector("data-files");
4967 if (myNet && (dataFiles.size() > 0)) {
4968 // disable validation for additionals
4969 XMLSubSys::setValidation("never", "auto", "auto");
4970 // begin undolist
4971 myUndoList->begin(Supermode::DEMAND, GUIIcon::SUPERMODEDEMAND, TLF("% data elements from '%'", operation, toString(dataFiles)));
4972 // use this flag for mark all elements as saved after loading, if it was sucessfully
4973 bool setSaved = dataFiles.size() == 1;
4974 // iterate over every data file
4975 for (const auto& file : dataFiles) {
4976 // check if ignore missing inputs
4977 if (FileHelpers::isReadable(file) || !neteditOptions.getBool("ignore-missing-inputs")) {
4978 WRITE_MESSAGE(TLF("% data elements from '%'.", operation, file));
4979 // get (or create) bucket for this new file
4980 auto bucket = myFileBucketHandler->getBucket(FileBucket::Type::DATA, file, true);
4981 // declare general handler
4982 GNEDataHandler generalHandler(myNet, bucket, myAllowUndoRedoLoading ? myAllowUndoRedo : false);
4983 // check if force overwritte
4984 if (operation == "reloading") {
4985 generalHandler.forceOverwriteElements();
4986 }
4987 // Run parser
4988 if (!generalHandler.parse()) {
4989 WRITE_ERROR(TLF("% of % failed.", operation, file));
4990 }
4991 setSaved &= !generalHandler.isErrorCreatingElement();
4992 }
4993 }
4994 // end undo list
4995 myUndoList->end();
4996 // disable validation for additionals
4997 XMLSubSys::setValidation("auto", "auto", "auto");
4998 if (setSaved) {
5000 }
5001 // check if clear undoList
5003 myUndoList->clear();
5004 }
5005 }
5006}
5007
5008
5009void
5011 // get option container
5012 auto& neteditOptions = OptionsCont::getOptions();
5013 // get meanData files (don't use reference because it's modified during loading)
5014 const StringVector meanDataFiles = neteditOptions.getStringVector("meandata-files");
5015 if (myNet && (meanDataFiles.size() > 0)) {
5016 // disable validation for additionals
5017 XMLSubSys::setValidation("never", "auto", "auto");
5018 // begin undolist
5019 myUndoList->begin(Supermode::DEMAND, GUIIcon::SUPERMODEDEMAND, TLF("% meanData elements from '%'", operation, toString(meanDataFiles)));
5020 // use this flag for mark all elements as saved after loading, if it was sucessfully
5021 bool setSaved = meanDataFiles.size() == 1;
5022 // iterate over every meanData file
5023 for (const auto& file : meanDataFiles) {
5024 // check if ignore missing inputs
5025 if (FileHelpers::isReadable(file) || !neteditOptions.getBool("ignore-missing-inputs")) {
5026 WRITE_MESSAGE(TLF("% meanData elements from '%'.", operation, file));
5027 // get (or create) bucket for this new file
5028 auto bucket = myFileBucketHandler->getBucket(FileBucket::Type::MEANDATA, file, true);
5029 // declare general handler
5030 GNEGeneralHandler generalHandler(myNet, bucket, myAllowUndoRedoLoading ? myAllowUndoRedo : false);
5031 // check if force overwritte
5032 if (operation == "reloading") {
5033 generalHandler.forceOverwriteElements();
5034 }
5035 // Run parser
5036 if (!generalHandler.parse()) {
5037 WRITE_ERROR(TLF("% of % failed.", operation, file));
5038 }
5039 setSaved &= !generalHandler.isErrorCreatingElement();
5040 }
5041 }
5042 // end undo list
5043 myUndoList->end();
5044 // disable validation for additionals
5045 XMLSubSys::setValidation("auto", "auto", "auto");
5046 if (setSaved) {
5048 }
5049 // check if clear undoList
5051 myUndoList->clear();
5052 }
5053 }
5054}
5055
5056
5057void
5058GNEApplicationWindow::loadTrafficLights(const std::string operation) {
5059 // get TLS file
5061 if (tlsFile.size() > 0) {
5062 // show info
5063 WRITE_MESSAGE(TLF("% TLS programs from '%'.", operation, tlsFile));
5064 myUndoList->begin(Supermode::NETWORK, GUIIcon::MODETLS, TLF("% TLS programs from '%'.", operation, tlsFile));
5065 myNet->computeNetwork(this);
5066 // parse TLS programs
5067 if (myNet->getViewParent()->getTLSEditorFrame()->parseTLSPrograms(tlsFile) == false) {
5068 // Abort undo/redo
5070 } else {
5071 // commit undo/redo operation
5072 myUndoList->end();
5073 update();
5074 }
5075 // requiere save network
5077 // if defined, require save netedit config
5080 }
5081 }
5082}
5083
5084
5085void
5086GNEApplicationWindow::loadEdgeTypes(const std::string operation) {
5087 // get edgeType file
5089 if (edgeTypeFile.size() > 0) {
5090 // declare type container
5091 NBTypeCont typeContainerAux;
5092 // declare type handler
5093 NIXMLTypesHandler handler(typeContainerAux);
5094 // load edge types
5095 NITypeLoader::load(handler, {edgeTypeFile}, toString(SUMO_TAG_TYPES));
5096 // now create GNETypes based on typeContainerAux
5097 WRITE_MESSAGE(TLF("% edge types from '%'.", operation, edgeTypeFile));
5098 myUndoList->begin(Supermode::NETWORK, GUIIcon::MODETLS, TLF("% edge types from '%'.", operation, edgeTypeFile));
5099 // iterate over typeContainerAux
5100 for (const auto& auxEdgeType : typeContainerAux) {
5101 // create new edge type
5102 GNEEdgeType* edgeType = new GNEEdgeType(myNet, auxEdgeType.first, auxEdgeType.second);
5103 // add lane types
5104 for (const auto& laneType : auxEdgeType.second->laneTypeDefinitions) {
5105 edgeType->addLaneType(new GNELaneType(edgeType, laneType));
5106 }
5107 // add it using undoList
5108 myViewNet->getUndoList()->add(new GNEChange_EdgeType(edgeType, true), true);
5109
5110 }
5111 // end undo list
5113 // refresh edge type selector
5115 // requiere save network
5117 // if defined, require save netedit config
5120 }
5121 }
5122}
5123
5124
5129
5130
5131bool
5133 if (myInternalTest == nullptr) {
5134 return true;
5135 } else if (obj == myInternalTest) {
5136 return true;
5137 } else {
5138 return false;
5139 }
5140}
5141
5142// ---------------------------------------------------------------------------
5143// GNEApplicationWindow - protected methods
5144// ---------------------------------------------------------------------------
5145#ifdef _MSC_VER
5146#pragma warning(push)
5147#pragma warning(disable: 4355) // mask warning about "this" in initializers
5148#endif
5150 myToolbarsGrip(this),
5151 myMenuBarFile(this),
5152 myFileMenuCommands(this),
5153 myModesMenuCommands(this),
5154 myEditMenuCommands(this),
5155 myLockMenuCommands(this),
5156 myProcessingMenuCommands(this),
5157 myLocateMenuCommands(this),
5158 myToolsMenuCommands(this),
5159 myWindowsMenuCommands(this),
5160 myHelpMenuCommands(this),
5161 mySupermodeCommands(this) {
5162}
5163#ifdef _MSC_VER
5164#pragma warning(pop)
5165#endif
5166
5167
5168long
5169GNEApplicationWindow::onKeyPress(FXObject* o, FXSelector sel, void* eventData) {
5170 const long handled = FXMainWindow::onKeyPress(o, sel, eventData);
5171 if (handled == 0 && myMDIClient->numChildren() > 0) {
5172 GNEViewParent* w = dynamic_cast<GNEViewParent*>(myMDIClient->getActiveChild());
5173 if (w != nullptr) {
5174 w->onKeyPress(nullptr, sel, eventData);
5175 }
5176 }
5177 return 0;
5178}
5179
5180
5181long
5182GNEApplicationWindow::onKeyRelease(FXObject* o, FXSelector sel, void* eventData) {
5183 const long handled = FXMainWindow::onKeyRelease(o, sel, eventData);
5184 if (handled == 0 && myMDIClient->numChildren() > 0) {
5185 GNEViewParent* w = dynamic_cast<GNEViewParent*>(myMDIClient->getActiveChild());
5186 if (w != nullptr) {
5187 w->onKeyRelease(nullptr, sel, eventData);
5188 }
5189 }
5190 return 0;
5191}
5192
5193
5194/****************************************************************************/
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
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