100 if (selected && (myViewNet->getViewParent()->getGNEAppWindows()->getLockMenuCommands().menuCheckLockSelectedElements->getCheck() == TRUE)) {
107 return myLockedElements.at(
GLO_WIRE).lock;
110 return myLockedElements.at(
GLO_ROUTE).lock;
122 return myLockedElements.at(
GLO_STOP).lock;
124 return myLockedElements.at(objectType).lock;
207 mySupermode(supermode) {
228 myInspectedACs.clear();
230 myFirstInspectedAC = AC;
231 myInspectedACs.insert(AC);
233 myFirstInspectedAC =
nullptr;
240 myInspectedACs.clear();
241 if (ACs.size() > 0) {
242 myFirstInspectedAC = ACs.front();
243 for (
const auto& AC : ACs) {
244 myInspectedACs.insert(AC);
247 myFirstInspectedAC =
nullptr;
254 auto it = myInspectedACs.find(AC);
255 if (it != myInspectedACs.end()) {
256 myInspectedACs.erase(it);
257 if (myInspectedACs.size() == 0) {
258 myInspectedACs.clear();
259 myFirstInspectedAC =
nullptr;
260 }
else if (myFirstInspectedAC == AC) {
261 myFirstInspectedAC = (*myInspectedACs.begin());
269 myFirstInspectedAC =
nullptr;
270 myInspectedACs.clear();
276 return myFirstInspectedAC;
280const std::unordered_set<GNEAttributeCarrier*>&
282 return myInspectedACs;
288 if (myInspectedACs.empty()) {
290 }
else if (myFirstInspectedAC == AC) {
293 return myInspectedACs.find(AC) != myInspectedACs.end();
300 if (myInspectedACs.empty()) {
302 }
else if (myFirstInspectedAC == AC) {
313 return myInspectedACs.size() > 0;
319 return myInspectedACs.size() == 1;
325 return myInspectedACs.size() > 1;
337 myMarkedACs.insert(AC);
343 if (myMarkedACs.size() > 0) {
344 auto it = myMarkedACs.find(AC);
345 if (it != myMarkedACs.end()) {
346 myMarkedACs.erase(it);
355 const auto copy = myMarkedACs;
356 for (
auto& AC : copy) {
362const std::unordered_set<GNEAttributeCarrier*>&
379 myViewObjects.clearElements();
394 if (myViewObjects.junctions.size() > 0) {
397 if (myViewObjects.edges.size() > 0) {
400 if (myViewObjects.lanes.size() > 0) {
403 if (myViewObjects.crossings.size() > 0) {
406 if (myViewObjects.connections.size() > 0) {
409 if (myViewObjects.walkingAreas.size() > 0) {
412 if (myViewObjects.lanes.size() > 0) {
415 if (myViewObjects.additionals.size() > 0) {
416 baseObjet->
addParentID(myViewObjects.additionals.front()->getTagProperty()->getTag(), myViewObjects.additionals.front()->getID());
418 if (myViewObjects.demandElements.size() > 0) {
419 baseObjet->
addParentID(myViewObjects.demandElements.front()->getTagProperty()->getTag(), myViewObjects.demandElements.front()->getID());
421 if (myViewObjects.genericDatas.size() > 0) {
422 baseObjet->
addParentID(myViewObjects.genericDatas.front()->getTagProperty()->getTag(), myViewObjects.genericDatas.front()->getID());
430 std::vector<const GUIGlObject*> glElements;
431 for (
const auto& glElement : myViewObjects.GUIGlObjects) {
432 if (glElement->getType() != exception) {
433 glElements.push_back(glElement);
436 myViewObjects.filterElements(glElements);
442 if (myViewNet->getEditModes().isCurrentSupermodeNetwork()) {
443 filterDemandElements(
true);
444 filterDataElements();
445 }
else if (myViewNet->getEditModes().isCurrentSupermodeDemand()) {
446 filterNetworkElements();
447 filterAdditionals(
true,
true);
448 filterDataElements();
449 }
else if (myViewNet->getEditModes().isCurrentSupermodeData()) {
450 filterNetworkElements();
451 filterDemandElements(
true);
459 std::vector<const GUIGlObject*> junctions;
460 for (
const auto& junction : myViewObjects.junctions) {
461 junctions.push_back(junction);
463 myViewObjects.filterElements(junctions);
470 std::vector<const GUIGlObject*> edges;
471 for (
const auto& edge : myViewObjects.edges) {
472 edges.push_back(edge);
474 myViewObjects.filterElements(edges);
481 std::vector<const GUIGlObject*> lanes;
482 for (
const auto& lane : myViewObjects.lanes) {
483 lanes.push_back(lane);
485 myViewObjects.filterElements(lanes);
492 std::vector<const GUIGlObject*> connections;
493 for (
const auto& connection : myViewObjects.connections) {
494 connections.push_back(connection);
496 myViewObjects.filterElements(connections);
503 std::vector<const GUIGlObject*> crossings;
504 for (
const auto& crossing : myViewObjects.crossings) {
505 crossings.push_back(crossing);
507 myViewObjects.filterElements(crossings);
514 std::vector<const GUIGlObject*> walkingAreas;
515 for (
const auto& walkingArea : myViewObjects.walkingAreas) {
516 walkingAreas.push_back(walkingArea);
518 myViewObjects.filterElements(walkingAreas);
525 std::vector<const GUIGlObject*> shapes;
526 for (
const auto& poly : myViewObjects.polys) {
527 shapes.push_back(poly);
529 for (
const auto&
POI : myViewObjects.POIs) {
530 shapes.push_back(
POI);
532 myViewObjects.filterElements(shapes);
539 std::vector<const GUIGlObject*> additionals;
540 for (
const auto& additional : myViewObjects.additionals) {
543 }
else if (!includeTAZs && (additional->getType() ==
GLO_TAZ)) {
546 additionals.push_back(additional);
549 myViewObjects.filterElements(additionals);
556 std::vector<const GUIGlObject*> networkElements;
557 for (
const auto& networkElement : myViewObjects.networkElements) {
558 networkElements.push_back(networkElement);
560 myViewObjects.filterElements(networkElements);
567 std::vector<const GUIGlObject*> demandElements;
568 for (
const auto& demandElement : myViewObjects.demandElements) {
569 if (!includeRoutes && (demandElement->getType() ==
GLO_ROUTE)) {
572 demandElements.push_back(demandElement);
575 myViewObjects.filterElements(demandElements);
582 std::vector<const GUIGlObject*> datadElements;
583 for (
const auto& datadElement : myViewObjects.edgeDatas) {
584 datadElements.push_back(datadElement);
586 for (
const auto& datadElement : myViewObjects.edgeRelDatas) {
587 datadElements.push_back(datadElement);
589 for (
const auto& datadElement : myViewObjects.TAZRelDatas) {
590 datadElements.push_back(datadElement);
592 myViewObjects.filterElements(datadElements);
599 std::vector<const GUIGlObject*> GUIGlObjects;
601 for (
const auto&
GUIGlObject : myViewObjects.GUIGlObjects) {
607 for (
const auto& ignoredType : ignoreFilter) {
608 auto it = GUIGlObjects.begin();
609 while (it != GUIGlObjects.end()) {
610 if ((*it)->getType() == ignoredType) {
611 it = GUIGlObjects.erase(it);
618 myViewObjects.filterElements(GUIGlObjects);
624 if (myViewObjects.GUIGlObjects.size() > 0) {
625 return myViewObjects.GUIGlObjects.front();
634 if (myViewObjects.attributeCarriers.size() > 0) {
635 return myViewObjects.attributeCarriers.front();
644 if (myViewObjects.networkElements.size() > 0) {
645 return myViewObjects.networkElements.front();
654 if (myViewObjects.additionals.size() > 0) {
655 return myViewObjects.additionals.front();
664 if (myViewObjects.demandElements.size() > 0) {
665 return myViewObjects.demandElements.front();
674 if (myViewObjects.genericDatas.size() > 0) {
675 return myViewObjects.genericDatas.front();
684 if (myViewObjects.junctions.size() > 0) {
685 return myViewObjects.junctions.front();
694 if (myViewObjects.edges.size() > 0) {
695 return myViewObjects.edges.front();
704 if (myViewObjects.lanes.size() > 0) {
705 return myViewObjects.lanes.front();
714 if (myViewObjects.lanes.size() > 0) {
715 for (
auto& lane : myViewObjects.lanes) {
716 if (!(lane->isAttributeCarrierSelected() || lane->getParentEdge()->isAttributeCarrierSelected()) ||
717 !myViewNet->getViewParent()->getGNEAppWindows()->getLockMenuCommands().menuCheckLockSelectedElements->getCheck()) {
729const std::vector<GNELane*>&
731 return myViewObjects.lanes;
737 if (myViewObjects.crossings.size() > 0) {
738 return myViewObjects.crossings.front();
747 if (myViewObjects.walkingAreas.size() > 0) {
748 return myViewObjects.walkingAreas.front();
757 if (myViewObjects.connections.size() > 0) {
758 return myViewObjects.connections.front();
767 if (myViewObjects.internalLanes.size() > 0) {
768 return myViewObjects.internalLanes.front();
777 if (myViewObjects.POIs.size() > 0) {
778 return myViewObjects.POIs.front();
787 if (myViewObjects.polys.size() > 0) {
788 return myViewObjects.polys.front();
797 if (myViewObjects.TAZs.size() > 0) {
798 return myViewObjects.TAZs.front();
807 if (myViewObjects.edgeDatas.size() > 0) {
808 return myViewObjects.edgeDatas.front();
817 if (myViewObjects.edgeRelDatas.size() > 0) {
818 return myViewObjects.edgeRelDatas.front();
827 if (myViewObjects.TAZRelDatas.size() > 0) {
828 return myViewObjects.TAZRelDatas.front();
835const std::vector<GUIGlObject*>&
837 return myViewObjects.GUIGlObjects;
841const std::vector<GNEAttributeCarrier*>&
843 return myViewObjects.attributeCarriers;
847const std::vector<GNEJunction*>&
849 return myViewObjects.junctions;
853const std::vector<GNEEdge*>&
855 return myViewObjects.edges;
859const std::vector<GNETAZ*>&
861 return myViewObjects.TAZs;
865const std::vector<GNEAdditional*>&
867 return myViewObjects.additionals;
871const std::vector<GNEDemandElement*>&
873 return myViewObjects.demandElements;
877const std::vector<const GNEJunction*>&
879 return myMergingJunctions;
888 GUIGlObjects.clear();
889 attributeCarriers.clear();
890 networkElements.clear();
892 demandElements.clear();
897 walkingAreas.clear();
899 internalLanes.clear();
903 genericDatas.clear();
905 edgeRelDatas.clear();
912 GUIGlObjects.reserve(size);
913 attributeCarriers.reserve(size);
914 networkElements.reserve(size);
915 additionals.reserve(size);
916 demandElements.reserve(size);
917 junctions.reserve(size);
920 crossings.reserve(size);
921 walkingAreas.reserve(size);
922 connections.reserve(size);
923 internalLanes.reserve(size);
927 genericDatas.reserve(size);
928 edgeDatas.reserve(size);
929 edgeRelDatas.reserve(size);
930 TAZRelDatas.reserve(size);
936 for (
const auto&
object : objects) {
938 auto itGlObjects = GUIGlObjects.begin();
939 while (itGlObjects != GUIGlObjects.end()) {
940 if (*itGlObjects ==
object) {
941 itGlObjects = GUIGlObjects.erase(itGlObjects);
947 auto itACs = attributeCarriers.begin();
948 while (itACs != attributeCarriers.end()) {
949 if ((*itACs)->getGUIGlObject() == object) {
950 itACs = attributeCarriers.erase(itACs);
956 auto itNetworkElements = networkElements.begin();
957 while (itNetworkElements != networkElements.end()) {
958 if ((*itNetworkElements)->getGUIGlObject() == object) {
959 itNetworkElements = networkElements.erase(itNetworkElements);
965 auto itAdditionals = additionals.begin();
966 while (itAdditionals != additionals.end()) {
967 if ((*itAdditionals)->getGUIGlObject() == object) {
968 itAdditionals = additionals.erase(itAdditionals);
974 auto itDemandElements = demandElements.begin();
975 while (itDemandElements != demandElements.end()) {
976 if ((*itDemandElements)->getGUIGlObject() == object) {
977 itDemandElements = demandElements.erase(itDemandElements);
983 auto itGenericDatas = genericDatas.begin();
984 while (itGenericDatas != genericDatas.end()) {
985 if ((*itGenericDatas)->getGUIGlObject() == object) {
986 itGenericDatas = genericDatas.erase(itGenericDatas);
992 auto itJunctions = junctions.begin();
993 while (itJunctions != junctions.end()) {
994 if ((*itJunctions)->getGUIGlObject() == object) {
995 itJunctions = junctions.erase(itJunctions);
1001 auto itEdges = edges.begin();
1002 while (itEdges != edges.end()) {
1003 if ((*itEdges)->getGUIGlObject() == object) {
1004 itEdges = edges.erase(itEdges);
1010 auto itLanes = lanes.begin();
1011 while (itLanes != lanes.end()) {
1012 if ((*itLanes)->getGUIGlObject() == object) {
1013 itLanes = lanes.erase(itLanes);
1019 auto itCrossings = crossings.begin();
1020 while (itCrossings != crossings.end()) {
1021 if ((*itCrossings)->getGUIGlObject() == object) {
1022 itCrossings = crossings.erase(itCrossings);
1028 auto itWalkingAreas = walkingAreas.begin();
1029 while (itWalkingAreas != walkingAreas.end()) {
1030 if ((*itWalkingAreas)->getGUIGlObject() == object) {
1031 itWalkingAreas = walkingAreas.erase(itWalkingAreas);
1037 auto itConnections = connections.begin();
1038 while (itConnections != connections.end()) {
1039 if ((*itConnections)->getGUIGlObject() == object) {
1040 itConnections = connections.erase(itConnections);
1046 auto itInternalLanes = internalLanes.begin();
1047 while (itInternalLanes != internalLanes.end()) {
1048 if ((*itInternalLanes)->getGUIGlObject() == object) {
1049 itInternalLanes = internalLanes.erase(itInternalLanes);
1055 auto itTAZs = TAZs.begin();
1056 while (itTAZs != TAZs.end()) {
1057 if ((*itTAZs)->getGUIGlObject() == object) {
1058 itTAZs = TAZs.erase(itTAZs);
1064 auto itPOIs = POIs.begin();
1065 while (itPOIs != POIs.end()) {
1066 if ((*itPOIs)->getGUIGlObject() == object) {
1067 itPOIs = POIs.erase(itPOIs);
1073 auto itPolys = polys.begin();
1074 while (itPolys != polys.end()) {
1075 if ((*itPolys)->getGUIGlObject() == object) {
1076 itPolys = polys.erase(itPolys);
1082 auto itEdgeDatas = edgeDatas.begin();
1083 while (itEdgeDatas != edgeDatas.end()) {
1084 if ((*itEdgeDatas)->getGUIGlObject() == object) {
1085 itEdgeDatas = edgeDatas.erase(itEdgeDatas);
1091 auto itEdgeRelDatas = edgeRelDatas.begin();
1092 while (itEdgeRelDatas != edgeRelDatas.end()) {
1093 if ((*itEdgeRelDatas)->getGUIGlObject() == object) {
1094 itEdgeRelDatas = edgeRelDatas.erase(itEdgeRelDatas);
1100 auto itTAZRelDatas = TAZRelDatas.begin();
1101 while (itTAZRelDatas != TAZRelDatas.end()) {
1102 if ((*itTAZRelDatas)->getGUIGlObject() == object) {
1103 itTAZRelDatas = TAZRelDatas.erase(itTAZRelDatas);
1115 switch (glObject->
getType()) {
1120 if (junction->isMarkedForDrawingFront()) {
1128 container.
junctions.push_back(junction);
1137 auto edge = myViewNet->getNet()->getAttributeCarriers()->retrieveEdge(glObject->
getMicrosimID());
1139 if (edge->isMarkedForDrawingFront()) {
1141 container.
edges.insert(container.
edges.begin(), edge);
1147 container.
edges.push_back(edge);
1156 auto lane = myViewNet->getNet()->getAttributeCarriers()->retrieveLane(glObject);
1158 if (lane->isMarkedForDrawingFront()) {
1160 container.
lanes.insert(container.
lanes.begin(), lane);
1166 container.
lanes.push_back(lane);
1175 auto crossing = myViewNet->getNet()->getAttributeCarriers()->retrieveCrossing(glObject);
1177 if (crossing->isMarkedForDrawingFront()) {
1185 container.
crossings.push_back(crossing);
1194 auto walkingArea = myViewNet->getNet()->getAttributeCarriers()->retrieveWalkingArea(glObject);
1196 if (walkingArea->isMarkedForDrawingFront()) {
1213 auto connection = myViewNet->getNet()->getAttributeCarriers()->retrieveConnection(glObject);
1215 if (connection->isMarkedForDrawingFront()) {
1232 auto internalLane = myViewNet->getNet()->getAttributeCarriers()->retrieveInternalLane(glObject);
1234 if (internalLane->isMarkedForDrawingFront()) {
1256 auto additionalElement = myViewNet->getNet()->getAttributeCarriers()->retrieveAdditional(glObject,
false);
1257 if (additionalElement) {
1259 if (additionalElement->isMarkedForDrawingFront()) {
1266 container.
additionals.push_back(additionalElement);
1279 auto POI =
dynamic_cast<GNEPOI*
>(myViewNet->getNet()->getAttributeCarriers()->retrieveAdditional(glObject));
1281 if (
POI->isMarkedForDrawingFront()) {
1283 container.
POIs.insert(container.
POIs.begin(),
POI);
1286 container.
POIs.push_back(
POI);
1290 auto poly =
dynamic_cast<GNEPoly*
>(myViewNet->getNet()->getAttributeCarriers()->retrieveAdditional(glObject));
1292 if (poly->isMarkedForDrawingFront()) {
1294 container.
polys.insert(container.
polys.begin(), poly);
1297 container.
polys.push_back(poly);
1308 auto TAZ =
dynamic_cast<GNETAZ*
>(myViewNet->getNet()->getAttributeCarriers()->retrieveAdditional(glObject));
1310 if (
TAZ->isMarkedForDrawingFront()) {
1312 container.
TAZs.insert(container.
TAZs.begin(),
TAZ);
1315 container.
TAZs.push_back(
TAZ);
1325 if (demandElement) {
1345 switch (glObject->
getType()) {
1348 auto edgeData =
dynamic_cast<GNEEdgeData*
>(myViewNet->getNet()->getAttributeCarriers()->retrieveGenericData(glObject));
1350 if (edgeData->isMarkedForDrawingFront()) {
1358 container.
edgeDatas.push_back(edgeData);
1367 auto edgeRelData =
dynamic_cast<GNEEdgeRelData*
>(myViewNet->getNet()->getAttributeCarriers()->retrieveGenericData(glObject));
1369 if (edgeRelData->isMarkedForDrawingFront()) {
1386 auto TAZRelData =
dynamic_cast<GNETAZRelData*
>(myViewNet->getNet()->getAttributeCarriers()->retrieveGenericData(glObject));
1388 if (TAZRelData->isMarkedForDrawingFront()) {
1412 for (
const auto& glObjectLayer : objectsContainer) {
1413 for (
const auto& glObject : glObjectLayer.second) {
1415 updateNetworkElements(myViewObjects, glObject.object);
1416 updateAdditionalElements(myViewObjects, glObject.object);
1417 updateShapeElements(myViewObjects, glObject.object);
1418 updateTAZElements(myViewObjects, glObject.object);
1419 updateDemandElements(myViewObjects, glObject.object);
1420 updateGenericDataElements(myViewObjects, glObject.object);
1427 myViewNet(nullptr) {
1435 myEventInfo(nullptr) {
1441 myEventInfo = (FXEvent*) eventData;
1448 return (myEventInfo->state & SHIFTMASK) != 0;
1458 return (myEventInfo->state & CONTROLMASK) != 0;
1468 return (myEventInfo->state & ALTMASK) != 0;
1478 return (myEventInfo->state & LEFTBUTTONMASK) != 0;
1488 return (myEventInfo->state & RIGHTBUTTONMASK) != 0;
1499 myViewNet(viewNet) {
1506 myRelativeClickedPosition = myViewNet->getPositionInformation();
1508 const GNENetworkElement* editedElement = myViewNet->myEditNetworkElementShapes.getEditedNetworkElement();
1510 if (myViewNet->myViewObjectsSelector.getJunctionFront() && (myViewNet->myViewObjectsSelector.getJunctionFront() == editedElement)) {
1512 GNEMoveOperation* moveOperation = myViewNet->myViewObjectsSelector.getJunctionFront()->getMoveElement()->getMoveOperation();
1514 if (moveOperation) {
1515 myMoveOperation = moveOperation;
1520 }
else if (myViewNet->myViewObjectsSelector.getLaneFront() && (myViewNet->myViewObjectsSelector.getLaneFront() == editedElement)) {
1522 GNEMoveOperation* moveOperation = myViewNet->myViewObjectsSelector.getLaneFront()->getMoveElement()->getMoveOperation();
1524 if (moveOperation) {
1525 myMoveOperation = moveOperation;
1530 }
else if (myViewNet->myViewObjectsSelector.getCrossingFront() && (myViewNet->myViewObjectsSelector.getCrossingFront() == editedElement)) {
1532 GNEMoveOperation* moveOperation = myViewNet->myViewObjectsSelector.getCrossingFront()->getMoveElement()->getMoveOperation();
1534 if (moveOperation) {
1535 myMoveOperation = moveOperation;
1540 }
else if (myViewNet->myViewObjectsSelector.getConnectionFront() && (myViewNet->myViewObjectsSelector.getConnectionFront() == editedElement)) {
1542 GNEMoveOperation* moveOperation = myViewNet->myViewObjectsSelector.getConnectionFront()->getMoveElement()->getMoveOperation();
1544 if (moveOperation) {
1545 myMoveOperation = moveOperation;
1550 }
else if (myViewNet->myViewObjectsSelector.getWalkingAreaFront() && (myViewNet->myViewObjectsSelector.getWalkingAreaFront() == editedElement)) {
1563 myRelativeClickedPosition = myViewNet->getPositionInformation();
1565 const GNEAttributeCarrier* markAC = myViewNet->myViewObjectsSelector.getAttributeCarrierFront();
1567 if (myViewNet->myViewObjectsSelector.getPolyFront() && (markAC == myViewNet->myViewObjectsSelector.getPolyFront())) {
1569 GNEMoveOperation* moveOperation = myViewNet->myViewObjectsSelector.getPolyFront()->getMoveElement()->getMoveOperation();
1571 if (moveOperation) {
1572 myMoveOperation = moveOperation;
1577 }
else if (myViewNet->myViewObjectsSelector.getPOIFront() && (markAC == myViewNet->myViewObjectsSelector.getPOIFront())) {
1579 GNEMoveOperation* moveOperation = myViewNet->myViewObjectsSelector.getPOIFront()->getMoveElement()->getMoveOperation();
1581 if (moveOperation) {
1582 myMoveOperation = moveOperation;
1587 }
else if (myViewNet->myViewObjectsSelector.getAdditionalFront() && (markAC == myViewNet->myViewObjectsSelector.getAdditionalFront()) &&
1588 myViewNet->myViewObjectsSelector.getAdditionalFront()->getMoveElement()) {
1590 GNEMoveOperation* moveOperation = myViewNet->myViewObjectsSelector.getAdditionalFront()->getMoveElement()->getMoveOperation();
1592 if (moveOperation) {
1593 myMoveOperation = moveOperation;
1598 }
else if (myViewNet->myViewObjectsSelector.getJunctionFront() && (markAC == myViewNet->myViewObjectsSelector.getJunctionFront())) {
1600 if (myViewNet->myViewObjectsSelector.getEdgeFront() && (myViewNet->myViewObjectsSelector.getEdgeFront()->clickedOverGeometryPoint(myRelativeClickedPosition))) {
1602 GNEMoveOperation* moveOperation = myViewNet->myViewObjectsSelector.getEdgeFront()->getMoveElement()->getMoveOperation();
1604 if (moveOperation) {
1605 myMoveOperation = moveOperation;
1612 GNEMoveOperation* moveOperation = myViewNet->myViewObjectsSelector.getJunctionFront()->getMoveElement()->getMoveOperation();
1614 if (moveOperation) {
1615 myMoveOperation = moveOperation;
1621 }
else if (myViewNet->myViewObjectsSelector.getEdgeFront() && (markAC == myViewNet->myViewObjectsSelector.getEdgeFront())) {
1623 if (myViewNet->myMouseButtonKeyPressed.shiftKeyPressed()) {
1625 myViewNet->myViewObjectsSelector.getEdgeFront()->editEndpoint(myViewNet->getPositionInformation(), myViewNet->myUndoList);
1630 GNEMoveOperation* moveOperation = myViewNet->myViewObjectsSelector.getEdgeFront()->getMoveElement()->getMoveOperation();
1632 if (moveOperation) {
1633 myMoveOperation = moveOperation;
1639 }
else if (myViewNet->myViewObjectsSelector.getLaneFront() && (markAC == myViewNet->myViewObjectsSelector.getLaneFront())) {
1641 GNEMoveOperation* moveOperation = myViewNet->myViewObjectsSelector.getLaneFront()->getMoveElement()->getMoveOperation();
1643 if (moveOperation) {
1644 myMoveOperation = moveOperation;
1659 myRelativeClickedPosition = myViewNet->getPositionInformation();
1661 const GNEAttributeCarrier* markAC = myViewNet->myViewObjectsSelector.getAttributeCarrierFront();
1663 if (myViewNet->myViewObjectsSelector.getDemandElementFront() && (markAC == myViewNet->myViewObjectsSelector.getDemandElementFront() &&
1664 myViewNet->myViewObjectsSelector.getDemandElementFront()->
getMoveElement())) {
1666 GNEMoveOperation* moveOperation = myViewNet->myViewObjectsSelector.getDemandElementFront()->getMoveElement()->getMoveOperation();
1668 if (moveOperation) {
1669 myMoveOperation = moveOperation;
1683 if (myMoveOperation) {
1687 if (mouseLeftButtonPressed) {
1694 delete myMoveOperation;
1695 myMoveOperation =
nullptr;
1703 if (myMoveOperation) {
1708 delete myMoveOperation;
1709 myMoveOperation =
nullptr;
1716 return myMoveOperation !=
nullptr;
1722 if (myMoveOperation) {
1734 Position moveOffset = (myViewNet->getPositionInformation() - myViewNet->myMoveSingleElement.myRelativeClickedPosition);
1736 if (myViewNet->myNetworkViewOptions.menuCheckMoveElevation->shown() && myViewNet->myNetworkViewOptions.menuCheckMoveElevation->amChecked() == TRUE) {
1751 myMovingSelectedEdge(false),
1759 myClickedPosition = myViewNet->getPositionInformation();
1761 if (myViewNet->myViewObjectsSelector.getJunctionFront()) {
1762 calculateJunctionSelection();
1763 }
else if (myViewNet->myViewObjectsSelector.getEdgeFront()) {
1764 calculateEdgeSelection(myViewNet->myViewObjectsSelector.getEdgeFront());
1766 myViewNet->updateViewNet();
1775 if (mouseLeftButtonPressed) {
1777 for (
const auto& moveOperation : myMoveOperations) {
1781 }
else if (myMoveOperations.size() > 0) {
1785 for (
const auto& moveOperation : myMoveOperations) {
1789 delete moveOperation;
1792 myViewNet->getUndoList()->end();
1794 myMoveOperations.clear();
1806 for (
const auto& moveOperation : myMoveOperations) {
1809 delete moveOperation;
1812 myViewNet->getUndoList()->end();
1814 myMoveOperations.clear();
1820 return (myMoveOperations.size() > 0);
1826 return myMovingSelectedEdge;
1832 myMovingSelectedEdge =
false;
1838 return myEdgeOffset;
1844 return myMoveOperations.size() > 0;
1852 Position moveOffset = (myViewNet->getPositionInformation() - myClickedPosition);
1854 if (myViewNet->myNetworkViewOptions.menuCheckMoveElevation->shown() && myViewNet->myNetworkViewOptions.menuCheckMoveElevation->amChecked() == TRUE) {
1869 const auto selectedJunctions = myViewNet->getNet()->getAttributeCarriers()->getSelectedJunctions();
1871 for (
const auto& junction : selectedJunctions) {
1872 moveOperation = junction->getMoveElement()->getMoveOperation();
1873 if (moveOperation) {
1874 myMoveOperations.push_back(moveOperation);
1878 const auto selectedEdges = myViewNet->getNet()->getAttributeCarriers()->getSelectedEdges();
1880 for (
const auto& edge : selectedEdges) {
1881 moveOperation = edge->getMoveElement()->getMoveOperation();
1882 if (moveOperation) {
1883 myMoveOperations.push_back(moveOperation);
1892 const auto selectedJunctions = myViewNet->getNet()->getAttributeCarriers()->getSelectedJunctions();
1894 for (
const auto& junction : selectedJunctions) {
1895 GNEMoveOperation* moveOperation = junction->getMoveElement()->getMoveOperation();
1896 if (moveOperation) {
1897 myMoveOperations.push_back(moveOperation);
1901 myMovingSelectedEdge =
true;
1908 myEdgeOffset = shape.length2D() - shape.nearest_offset_to_point2D(myViewNet->getPositionInformation());
1911 const auto selectedEdges = myViewNet->getNet()->getAttributeCarriers()->getSelectedEdges();
1913 for (
const auto& edge : selectedEdges) {
1914 GNEMoveOperation* moveOperation = edge->getMoveElement()->getMoveOperation();
1916 if (moveOperation) {
1917 myMoveOperations.push_back(moveOperation);
1927 myViewNet(viewNet) {
1948 myViewNet(viewNet) {
1969 selectingUsingRectangle(false),
1970 startDrawing(false),
1971 myViewNet(viewNet) {
1977 selectingUsingRectangle =
true;
1978 selectionCorner1 = myViewNet->getPositionInformation();
1979 selectionCorner2 = selectionCorner1;
1986 startDrawing =
true;
1988 selectionCorner2 = myViewNet->getPositionInformation();
1990 myViewNet->setStatusBarText(
TL(
"Selection width:") +
toString(fabs(selectionCorner1.x() - selectionCorner2.x()))
1991 +
TL(
" height:") +
toString(fabs(selectionCorner1.y() - selectionCorner2.y()))
1992 +
TL(
" diagonal:") +
toString(selectionCorner1.distanceTo2D(selectionCorner2)));
1999 selectingUsingRectangle =
false;
2000 startDrawing =
false;
2002 myViewNet->setStatusBarText(
"");
2009 if ((abs(selectionCorner1.x() - selectionCorner2.x()) > 0.01) &&
2010 (abs(selectionCorner1.y() - selectionCorner2.y()) > 0.01) &&
2011 myViewNet->myMouseButtonKeyPressed.shiftKeyPressed()) {
2014 rectangleBoundary.
add(selectionCorner1);
2015 rectangleBoundary.
add(selectionCorner2);
2017 processBoundarySelection(rectangleBoundary);
2022std::vector<GNEEdge*>
2025 if ((abs(selectionCorner1.x() - selectionCorner2.x()) > 0.01) &&
2026 (abs(selectionCorner1.y() - selectionCorner2.y()) > 0.01) &&
2027 myViewNet->myMouseButtonKeyPressed.shiftKeyPressed()) {
2030 rectangleBoundary.
add(selectionCorner1);
2031 rectangleBoundary.
add(selectionCorner2);
2033 myViewNet->updateObjectsInShape(rectangleBoundary.
getShape(
false));
2035 return myViewNet->getViewObjectsSelector().getEdges();
2044 if (selectingUsingRectangle) {
2049 glPolygonMode(GL_FRONT_AND_BACK, GL_LINE);
2051 glVertex2d(selectionCorner1.x(), selectionCorner1.y());
2052 glVertex2d(selectionCorner1.x(), selectionCorner2.y());
2053 glVertex2d(selectionCorner2.x(), selectionCorner2.y());
2054 glVertex2d(selectionCorner2.x(), selectionCorner1.y());
2063 const bool selEdges = myViewNet->myNetworkViewOptions.selectEdges();
2065 myViewNet->updateObjectsInShape(boundary.
getShape(
false));
2067 std::vector<GNEAttributeCarrier*> ACsFiltered;
2068 ACsFiltered.reserve(myViewNet->getViewObjectsSelector().getAttributeCarriers().size());
2069 for (
const auto& AC : myViewNet->getViewObjectsSelector().getAttributeCarriers()) {
2071 if (!AC->getGUIGlObject()->isGLObjectLocked()) {
2072 const auto tagProperty = AC->getTagProperty();
2073 if (tagProperty->isNetworkElement() || tagProperty->isAdditionalElement()) {
2075 if (((tagProperty->getTag() ==
SUMO_TAG_EDGE) && !selEdges) ||
2079 ACsFiltered.push_back(AC);
2081 }
else if (tagProperty->isDemandElement()) {
2082 ACsFiltered.push_back(AC);
2083 }
else if (tagProperty->isGenericData()) {
2084 ACsFiltered.push_back(AC);
2089 std::vector<GNEAttributeCarrier*> ACToSelect;
2090 std::vector<GNEAttributeCarrier*> ACToUnselect;
2092 ACToSelect.reserve(ACsFiltered.size());
2093 ACToUnselect.reserve(ACsFiltered.size());
2095 const auto modificationMode = myViewNet->myViewParent->getSelectorFrame()->getModificationModeModul()->getModificationMode();
2098 const auto selectedAC = myViewNet->getNet()->getAttributeCarriers()->getSelectedAttributeCarriers(
false);
2100 for (
const auto& AC : selectedAC) {
2101 ACToUnselect.push_back(AC);
2105 for (
const auto& AC : ACsFiltered) {
2106 switch (myViewNet->myViewParent->getSelectorFrame()->getModificationModeModul()->getModificationMode()) {
2108 ACToUnselect.push_back(AC);
2111 if (std::find(ACToUnselect.begin(), ACToUnselect.end(), AC) != ACToUnselect.end()) {
2112 ACToSelect.push_back(AC);
2116 ACToSelect.push_back(AC);
2122 std::vector<GNEEdge*> edgesToSelect;
2124 for (
const auto& AC : ACToSelect) {
2126 edgesToSelect.push_back(
dynamic_cast<GNEEdge*
>(AC));
2130 for (
const auto& edge : edgesToSelect) {
2132 ACToSelect.push_back(edge->getFromJunction());
2133 for (
const auto& connection : edge->getFromJunction()->getGNEConnections()) {
2134 ACToSelect.push_back(connection);
2136 for (
const auto& crossing : edge->getFromJunction()->getGNECrossings()) {
2137 ACToSelect.push_back(crossing);
2140 ACToSelect.push_back(edge->getToJunction());
2141 for (
const auto& connection : edge->getToJunction()->getGNEConnections()) {
2142 ACToSelect.push_back(connection);
2144 for (
const auto& crossing : edge->getToJunction()->getGNECrossings()) {
2145 ACToSelect.push_back(crossing);
2150 if ((ACToSelect.size() + ACToUnselect.size()) > 0) {
2153 for (
const auto& AC : ACToUnselect) {
2156 for (
const auto& AC : ACToSelect) {
2157 if (AC->getTagProperty()->isSelectable()) {
2161 myViewNet->myUndoList->end();
2163 myViewNet->makeNonCurrent();
2171 myViewNet(viewNet) {
2181 if ((windowSize.size() == 2) && GNEAttributeCarrier::canParse<int>(windowSize[0]) && GNEAttributeCarrier::canParse<int>(windowSize[1])) {
2182 myTestingWidth = GNEAttributeCarrier::parse<int>(windowSize[0]);
2183 myTestingHeight = GNEAttributeCarrier::parse<int>(windowSize[1]);
2196 if (myTestingWidth > 0) {
2197 mainWindow->resize(myTestingWidth, myTestingHeight);
2201 const double size = myViewNet->p2m(32);
2202 Position center = myViewNet->screenPos2NetPos(8, 8);
2207 glPolygonMode(GL_FRONT_AND_BACK, GL_FILL);
2210 glVertex2d(0, -size);
2211 glVertex2d(size, -size);
2212 glVertex2d(size, 0);
2219 glScaled(0.7, 0.7, 0);
2220 glPolygonMode(GL_FRONT_AND_BACK, GL_FILL);
2223 glVertex2d(0, -size);
2224 glVertex2d(size, -size);
2225 glVertex2d(size, 0);
2232 glScaled(0.4, 0.4, 0);
2233 glPolygonMode(GL_FRONT_AND_BACK, GL_FILL);
2236 glVertex2d(0, -size);
2237 glVertex2d(size, -size);
2238 glVertex2d(size, 0);
2249 myViewNet(viewNet) {
2254 delete mySaveIndividualFilesPopup;
2261 auto gripSaveElements = myViewNet->getViewParent()->getGNEAppWindows()->getToolbarsGrip().saveElements;
2263 auto tooltipMenu = myViewNet->myViewParent->getGNEAppWindows()->getStaticTooltipMenu();
2268 mySaveNeteditConfig->create();
2273 mySaveSumoConfig->create();
2278 mySaveNetwork->create();
2280 mySaveIndividualFilesPopup =
new FXPopup(gripSaveElements, POPUP_VERTICAL);
2281 mySaveIndividualFilesPopup->create();
2284 std::string(
"\t") +
TL(
"Save individual files") + std::string(
"\t") +
TL(
"Save individual files."),
2286 mySaveIndividualFiles->create();
2288 mySaveAdditionalElements =
new MFXButtonTooltip(mySaveIndividualFilesPopup, tooltipMenu,
2291 mySaveAdditionalElements->create();
2293 mySaveDemandElements =
new MFXButtonTooltip(mySaveIndividualFilesPopup, tooltipMenu,
2296 mySaveDemandElements->create();
2298 mySaveDataElements =
new MFXButtonTooltip(mySaveIndividualFilesPopup, tooltipMenu,
2301 mySaveDataElements->create();
2303 mySaveMeanDataElements =
new MFXButtonTooltip(mySaveIndividualFilesPopup, tooltipMenu,
2306 mySaveMeanDataElements->create();
2308 gripSaveElements->recalc();
2310 gripSaveElements->show();
2317 mySaveIndividualFiles->enable();
2319 mySaveIndividualFiles->disable();
2328 myViewNet(viewNet) {
2335 mySwitchButton =
new MFXButtonTooltip(myViewNet->getViewParent()->getGNEAppWindows()->getToolbarsGrip().timeSwitch,
2336 myViewNet->myViewParent->getGNEAppWindows()->getStaticTooltipMenu(),
2337 gHumanReadableTime ?
"H" :
"S" + std::string(
"\t") +
TL(
"Switch between seconds and HH:MM:SS") + std::string(
"\t") +
TL(
"Switch between seconds and HH:MM:SS"),
nullptr,
2339 mySwitchButton->create();
2358 mySwitchButton->setText(
"H");
2360 mySwitchButton->setText(
"S");
2373 myViewNet(viewNet) {
2376 if (neteditOptions.getBool(
"new")) {
2378 neteditOptions.resetWritable();
2379 neteditOptions.set(
"new",
"false");
2385 delete myNeteditViewsPopup;
2392 auto gripSupermodes = myViewNet->getViewParent()->getGNEAppWindows()->getToolbarsGrip().superModes;
2394 auto toolTipMenu = myViewNet->myViewParent->getGNEAppWindows()->getStaticTooltipMenu();
2397 TL(
"Network") + std::string(
"\t") +
TL(
"Edit network elements") + std::string(
"\t") +
TL(
"Set mode for editing network elements. (F2)"),
2399 networkButton->create();
2402 TL(
"Demand") + std::string(
"\t") +
TL(
"Edit traffic demand elements") + std::string(
"\t") +
TL(
"Set mode for editing traffic demand. (F3)"),
2404 demandButton->create();
2407 TL(
"Data") + std::string(
"\t") +
TL(
"Edit data elements") + std::string(
"\t") +
TL(
"Set mode for editing data demand. (F4)"),
2409 dataButton->create();
2411 myNeteditViewsPopup =
new FXPopup(gripSupermodes, POPUP_VERTICAL);
2412 myNeteditViewsPopup->create();
2415 (std::string(
"\t") +
TL(
"Change netedit view") + std::string(
"\t") +
TL(
"Change netedit view.")).c_str(),
2417 myNeteditViewsButton->create();
2419 myDefaultViewButton =
new MFXButtonTooltip(myNeteditViewsPopup, toolTipMenu,
2420 (std::string(
"Default\t") +
TL(
"Set default view") + std::string(
"\t") +
TL(
"Set default view.")).c_str(),
2422 myDefaultViewButton->create();
2424 myJuPedSimViewButton =
new MFXButtonTooltip(myNeteditViewsPopup, toolTipMenu,
2425 (std::string(
"JuPedSim\t") +
TL(
"Set JuPedSim view") + std::string(
"\t") +
TL(
"Set JuPedSim view.")).c_str(),
2427 myJuPedSimViewButton->create();
2428 myNeteditViewsPopup->recalc();
2430 gripSupermodes->setWidth(353);
2432 gripSupermodes->show();
2438 if (!force && (supermode == currentSupermode)) {
2439 myViewNet->setStatusBarText(
TL(
"Mode already selected"));
2440 if (myViewNet->myCurrentFrame !=
nullptr) {
2441 myViewNet->myCurrentFrame->focusUpperElement();
2444 myViewNet->setStatusBarText(
"");
2446 myViewNet->abortOperation(
false);
2448 currentSupermode = supermode;
2452 networkButton->setChecked(
true);
2453 demandButton->setChecked(
false);
2454 dataButton->setChecked(
false);
2456 myViewNet->myNetworkCheckableButtons.showNetworkCheckableButtons();
2458 myViewNet->myDemandCheckableButtons.hideDemandCheckableButtons();
2460 myViewNet->myDataCheckableButtons.hideDataCheckableButtons();
2462 setNetworkEditMode(networkEditMode,
true);
2465 networkButton->setChecked(
false);
2466 demandButton->setChecked(
true);
2467 dataButton->setChecked(
false);
2469 myViewNet->myNetworkCheckableButtons.hideNetworkCheckableButtons();
2471 myViewNet->myDemandCheckableButtons.showDemandCheckableButtons();
2473 myViewNet->myDataCheckableButtons.hideDataCheckableButtons();
2475 setDemandEditMode(demandEditMode,
true);
2477 myViewNet->myNet->computeNetwork(myViewNet->myViewParent->getGNEAppWindows());
2479 if (!myViewNet->myNet->getDemandPathManager()->getPathCalculator()->isPathCalculatorUpdated()) {
2481 myViewNet->myNet->getDemandPathManager()->getPathCalculator()->updatePathCalculator();
2483 myViewNet->myNet->computeDemandElements(myViewNet->myViewParent->getGNEAppWindows());
2487 networkButton->setChecked(
false);
2488 demandButton->setChecked(
false);
2489 dataButton->setChecked(
true);
2491 myViewNet->myNetworkCheckableButtons.hideNetworkCheckableButtons();
2493 myViewNet->myDemandCheckableButtons.hideDemandCheckableButtons();
2495 myViewNet->myDataCheckableButtons.showDataCheckableButtons();
2497 setDataEditMode(dataEditMode,
true);
2499 if (myViewNet->getViewParent()->getGNEAppWindows()->getProcessingMenuCommands().menuCheckRecomputeDataMode->getCheck() == TRUE) {
2501 myViewNet->myNet->computeNetwork(myViewNet->myViewParent->getGNEAppWindows());
2504 for (
const auto&
TAZ : myViewNet->getNet()->getAttributeCarriers()->getAdditionals().at(
SUMO_TAG_TAZ)) {
2505 TAZ.second->resetAdditionalContour();
2509 networkButton->update();
2510 demandButton->update();
2511 dataButton->update();
2513 myViewNet->myViewParent->getGNEAppWindows()->updateSuperModeMenuCommands(currentSupermode);
2520 if ((mode == networkEditMode) && !force) {
2521 myViewNet->setStatusBarText(
TL(
"Network mode already selected"));
2522 if (myViewNet->myCurrentFrame !=
nullptr) {
2523 myViewNet->myCurrentFrame->focusUpperElement();
2526 myViewNet->setStatusBarText(
TL(
"Save modifications in TLS before change mode"));
2527 myViewNet->myCurrentFrame->focusUpperElement();
2529 myViewNet->setStatusBarText(
"");
2530 myViewNet->abortOperation(
false);
2532 myViewNet->myEditNetworkElementShapes.stopEditCustomShape();
2534 networkEditMode = mode;
2555 myViewNet->myNet->computeNetwork(myViewNet->myViewParent->getGNEAppWindows());
2561 myViewNet->updateCursor();
2563 myViewNet->updateNetworkModeSpecificControls();
2570 if ((mode == demandEditMode) && !force) {
2571 myViewNet->setStatusBarText(
TL(
"Demand mode already selected"));
2572 if (myViewNet->myCurrentFrame !=
nullptr) {
2573 myViewNet->myCurrentFrame->focusUpperElement();
2576 myViewNet->setStatusBarText(
"");
2577 myViewNet->abortOperation(
false);
2579 myViewNet->myEditNetworkElementShapes.stopEditCustomShape();
2581 demandEditMode = mode;
2596 myViewNet->updateCursor();
2598 myViewNet->updateDemandModeSpecificControls();
2605 if ((mode == dataEditMode) && !force) {
2606 myViewNet->setStatusBarText(
TL(
"Data mode already selected"));
2607 if (myViewNet->myCurrentFrame !=
nullptr) {
2608 myViewNet->myCurrentFrame->focusUpperElement();
2611 myViewNet->setStatusBarText(
"");
2612 myViewNet->abortOperation(
false);
2614 myViewNet->myEditNetworkElementShapes.stopEditCustomShape();
2616 dataEditMode = mode;
2629 for (
const auto& dataSet : myViewNet->getNet()->getAttributeCarriers()->getDataSets()) {
2630 dataSet.second->updateAttributeColors();
2633 myViewNet->updateCursor();
2635 myViewNet->updateDataModeSpecificControls();
2661 auto gripSupermodes = myViewNet->getViewParent()->getGNEAppWindows()->getToolbarsGrip().superModes;
2663 auto& fileMenuCommands = myViewNet->getViewParent()->getGNEAppWindows()->getFileMenuCommands();
2667 gripSupermodes->setWidth(353);
2669 fileMenuCommands.setDefaultView();
2672 gripSupermodes->setWidth(250);
2674 fileMenuCommands.setJuPedSimView();
2677 myViewNet->viewUpdated();
2697 myViewNet(viewNet) {
2704 auto gripModes = myViewNet->myViewParent->getGNEAppWindows()->getToolbarsGrip().modes;
2706 auto toolTipMenu = myViewNet->myViewParent->getGNEAppWindows()->getStaticTooltipMenu();
2709 (std::string(
"\t") +
TL(
"Show grid") + std::string(
"\t") +
TL(
"Show grid and restrict movement to the grid - define grid size in visualization options. (Ctrl+G)")),
2712 menuCheckToggleGrid->setChecked(
false);
2713 menuCheckToggleGrid->create();
2715 menuCheckToggleDrawJunctionShape =
new MFXCheckableButton(
false, gripModes, toolTipMenu,
2716 (std::string(
"\t") +
TL(
"Hide junction shape") + std::string(
"\t") +
TL(
"Toggle hiding junction shape. (Ctrl+J)")),
2719 menuCheckToggleDrawJunctionShape->setChecked(
false);
2720 menuCheckToggleDrawJunctionShape->create();
2723 (std::string(
"\t") +
TL(
"Draw vehicles spread in lane or depart position") + std::string(
"\t") +
TL(
"Draw vehicles spread in lane or in depart position.")),
2726 menuCheckDrawSpreadVehicles->setChecked(
false);
2727 menuCheckDrawSpreadVehicles->create();
2730 (std::string(
"\t") +
TL(
"Show demand elements") + std::string(
"\t") +
TL(
"Toggle show demand elements.")),
2733 menuCheckShowDemandElements->setChecked(
false);
2734 menuCheckShowDemandElements->create();
2737 (std::string(
"\t") +
TL(
"Clicks target lanes") + std::string(
"\t") +
TL(
"Toggle whether clicking should inspect/select/delete lanes instead of edges.")),
2740 menuCheckSelectEdges->create();
2743 (std::string(
"\t") +
TL(
"Show connections over junctions") + std::string(
"\t") +
TL(
"Toggle show connections over junctions.")),
2746 menuCheckShowConnections->setChecked(myViewNet->getVisualisationSettings().showLane2Lane);
2747 menuCheckShowConnections->create();
2750 (std::string(
"\t") +
TL(
"Hide connections") + std::string(
"\t") +
TL(
"Toggle hide connections.")),
2753 menuCheckHideConnections->setChecked(
false);
2754 menuCheckHideConnections->create();
2756 menuCheckShowAdditionalSubElements =
new MFXCheckableButton(
false, gripModes, toolTipMenu,
2757 (std::string(
"\t") +
TL(
"Show additional sub-elements") + std::string(
"\t") +
TL(
"Toggle show additional sub-elements.")),
2760 menuCheckShowAdditionalSubElements->setChecked(
false);
2761 menuCheckShowAdditionalSubElements->create();
2764 (std::string(
"\t") +
TL(
"Show TAZ elements") + std::string(
"\t") +
TL(
"Toggle show TAZ elements.")),
2767 menuCheckShowTAZElements->setChecked(
false);
2768 menuCheckShowTAZElements->create();
2771 (std::string(
"\t") +
TL(
"Automatic select junctions") + std::string(
"\t") +
TL(
"Toggle whether selecting multiple edges should automatically select their junctions.")),
2774 menuCheckExtendSelection->setChecked(
true);
2775 menuCheckExtendSelection->create();
2778 (std::string(
"\t") +
TL(
"Apply state to all phases") + std::string(
"\t") +
TL(
"Toggle whether clicking should apply state changes to all phases of the current TLS plan.")),
2781 menuCheckChangeAllPhases->setChecked(
false);
2782 menuCheckChangeAllPhases->create();
2785 (std::string(
"\t") +
TL(
"Automatic merging junction") + std::string(
"\t") +
TL(
"Toggle ask for confirmation before merging junction.")),
2788 menuCheckMergeAutomatically->create();
2791 (std::string(
"\t") +
TL(
"Edge chain mode") + std::string(
"\t") +
TL(
"Create consecutive edges with a single click (hit ESC to cancel chain).")),
2794 menuCheckChainEdges->setChecked(
false);
2795 menuCheckChainEdges->create();
2798 (std::string(
"\t") +
TL(
"Edge opposite direction") + std::string(
"\t") +
TL(
"Automatically create an edge in the opposite direction.")),
2801 menuCheckAutoOppositeEdge->setChecked(
false);
2802 menuCheckAutoOppositeEdge->create();
2805 (std::string(
"\t") +
TL(
"Move elevation") + std::string(
"\t") +
TL(
"Apply mouse movement to elevation instead of x,y position.")),
2808 menuCheckMoveElevation->setChecked(
false);
2809 menuCheckMoveElevation->create();
2812 (std::string(
"\t") +
TL(
"Show bubbles") + std::string(
"\t") +
TL(
"Toggle show bubbles over junctions shapes.")),
2815 menuCheckShowJunctionBubble->setChecked(
false);
2816 menuCheckShowJunctionBubble->create();
2819 gripModes->recalc();
2825 menuCheckToggleGrid->hide();
2826 menuCheckToggleDrawJunctionShape->hide();
2827 menuCheckDrawSpreadVehicles->hide();
2828 menuCheckShowDemandElements->hide();
2829 menuCheckSelectEdges->hide();
2830 menuCheckShowConnections->hide();
2831 menuCheckHideConnections->hide();
2832 menuCheckShowAdditionalSubElements->hide();
2833 menuCheckShowTAZElements->hide();
2834 menuCheckExtendSelection->hide();
2835 menuCheckChangeAllPhases->hide();
2836 menuCheckMergeAutomatically->hide();
2837 menuCheckShowJunctionBubble->hide();
2838 menuCheckMoveElevation->hide();
2839 menuCheckChainEdges->hide();
2840 menuCheckAutoOppositeEdge->hide();
2847 if (menuCheckToggleGrid->shown()) {
2848 commands.push_back(menuCheckToggleGrid);
2850 if (menuCheckToggleDrawJunctionShape->shown()) {
2851 commands.push_back(menuCheckToggleDrawJunctionShape);
2853 if (menuCheckDrawSpreadVehicles->shown()) {
2854 commands.push_back(menuCheckDrawSpreadVehicles);
2856 if (menuCheckShowDemandElements->shown()) {
2857 commands.push_back(menuCheckShowDemandElements);
2859 if (menuCheckSelectEdges->shown()) {
2860 commands.push_back(menuCheckSelectEdges);
2862 if (menuCheckShowConnections->shown()) {
2863 commands.push_back(menuCheckShowConnections);
2865 if (menuCheckHideConnections->shown()) {
2866 commands.push_back(menuCheckHideConnections);
2868 if (menuCheckShowAdditionalSubElements->shown()) {
2869 commands.push_back(menuCheckShowAdditionalSubElements);
2871 if (menuCheckShowTAZElements->shown()) {
2872 commands.push_back(menuCheckShowTAZElements);
2874 if (menuCheckExtendSelection->shown()) {
2875 commands.push_back(menuCheckExtendSelection);
2877 if (menuCheckChangeAllPhases->shown()) {
2878 commands.push_back(menuCheckChangeAllPhases);
2880 if (menuCheckMergeAutomatically->shown()) {
2881 commands.push_back(menuCheckMergeAutomatically);
2883 if (menuCheckChainEdges->shown()) {
2884 commands.push_back(menuCheckChainEdges);
2886 if (menuCheckAutoOppositeEdge->shown()) {
2887 commands.push_back(menuCheckAutoOppositeEdge);
2889 if (menuCheckMoveElevation->shown()) {
2890 commands.push_back(menuCheckMoveElevation);
2892 if (menuCheckShowJunctionBubble->shown()) {
2893 commands.push_back(menuCheckShowJunctionBubble);
2900 return (menuCheckDrawSpreadVehicles->amChecked() == TRUE);
2906 if (menuCheckShowDemandElements->shown()) {
2907 return (menuCheckShowDemandElements->amChecked() == TRUE);
2917 if (menuCheckSelectEdges->shown()) {
2918 return (menuCheckSelectEdges->amChecked() != TRUE);
2928 if (myViewNet->myEditModes.isCurrentSupermodeData()) {
2932 return (menuCheckHideConnections->amChecked() == FALSE);
2935 }
else if (myViewNet->myEditModes.isCurrentSupermodeNetwork() && menuCheckShowConnections->shown() ==
false) {
2938 return (myViewNet->getVisualisationSettings().showLane2Lane);
2945 if (!myViewNet->myEditModes.isCurrentSupermodeNetwork()) {
2947 }
else if (menuCheckShowAdditionalSubElements->shown() ==
false) {
2950 return menuCheckShowAdditionalSubElements->amChecked();
2957 if (!myViewNet->myEditModes.isCurrentSupermodeNetwork()) {
2959 }
else if (menuCheckShowTAZElements->shown() ==
false) {
2962 return menuCheckShowTAZElements->amChecked();
2969 if (menuCheckMoveElevation->shown()) {
2970 return (menuCheckMoveElevation->amChecked() == TRUE);
2981 myViewNet(viewNet) {
2988 auto gripModes = myViewNet->getViewParent()->getGNEAppWindows()->getToolbarsGrip().modes;
2990 auto tooltipMenu = myViewNet->myViewParent->getGNEAppWindows()->getStaticTooltipMenu();
2993 (std::string(
"\t") +
TL(
"Show grid") + std::string(
"\t") +
TL(
"Show grid and restrict movement to the grid - define grid size in visualization options. (Ctrl+G)")),
2996 menuCheckToggleGrid->setChecked(
false);
2997 menuCheckToggleGrid->create();
2999 menuCheckToggleDrawJunctionShape =
new MFXCheckableButton(
false, gripModes, tooltipMenu,
3000 (std::string(
"\t") +
TL(
"Hide junction shape") + std::string(
"\t") +
TL(
"Toggle hiding junction shape. (Ctrl+J)")),
3003 menuCheckToggleDrawJunctionShape->setChecked(
false);
3004 menuCheckToggleDrawJunctionShape->create();
3007 (std::string(
"\t") +
TL(
"Draw vehicles spread/depart position") + std::string(
"\t") +
TL(
"Draw vehicles spread in lane or in depart position.")),
3010 menuCheckDrawSpreadVehicles->setChecked(
false);
3011 menuCheckDrawSpreadVehicles->create();
3014 (std::string(
"\t") +
TL(
"Show shapes") + std::string(
"\t") +
TL(
"Toggle show shapes (Polygons and POIs).")),
3017 menuCheckHideShapes->setChecked(
false);
3018 menuCheckHideShapes->create();
3021 (std::string(
"\t") +
TL(
"Show all trips") + std::string(
"\t") +
TL(
"Toggle show all trips (requires updated demand - F5).")),
3024 menuCheckShowAllTrips->setChecked(
false);
3025 menuCheckShowAllTrips->create();
3028 (std::string(
"\t") +
TL(
"Show all person plans") + std::string(
"\t") +
TL(
"Toggle show all person plans.")),
3031 menuCheckShowAllPersonPlans->setChecked(
false);
3032 menuCheckShowAllPersonPlans->create();
3035 (std::string(
"\t") +
TL(
"Lock selected person") + std::string(
"\t") +
TL(
"Toggle lock selected person.")),
3038 menuCheckLockPerson->setChecked(
false);
3039 menuCheckLockPerson->create();
3041 menuCheckShowAllContainerPlans =
new MFXCheckableButton(
false, gripModes, tooltipMenu,
3042 (std::string(
"\t") +
TL(
"Show all containers plans") + std::string(
"\t") +
TL(
"Toggle show all container plans.")),
3045 menuCheckShowAllContainerPlans->setChecked(
false);
3046 menuCheckShowAllContainerPlans->create();
3049 (std::string(
"\t") +
TL(
"Lock selected container") + std::string(
"\t") +
TL(
"Toggle lock selected container.")),
3052 menuCheckLockContainer->setChecked(
false);
3053 menuCheckLockContainer->create();
3055 menuCheckHideNonInspectedDemandElements =
new MFXCheckableButton(
false, gripModes, tooltipMenu,
3056 (std::string(
"\t") +
TL(
"Show non-inspected demand elements") + std::string(
"\t") +
TL(
"Toggle show non-inspected demand elements.")),
3059 menuCheckHideNonInspectedDemandElements->setChecked(
false);
3060 menuCheckHideNonInspectedDemandElements->create();
3062 menuCheckShowOverlappedRoutes =
new MFXCheckableButton(
false, gripModes, tooltipMenu,
3063 (std::string(
"\t") +
TL(
"Show number of overlapped routes") + std::string(
"\t") +
TL(
"Toggle show number of overlapped routes.")),
3066 menuCheckShowOverlappedRoutes->setChecked(
false);
3067 menuCheckShowOverlappedRoutes->create();
3070 gripModes->recalc();
3076 menuCheckToggleGrid->hide();
3077 menuCheckToggleDrawJunctionShape->hide();
3078 menuCheckDrawSpreadVehicles->hide();
3079 menuCheckHideShapes->hide();
3080 menuCheckShowAllTrips->hide();
3081 menuCheckShowAllPersonPlans->hide();
3082 menuCheckLockPerson->hide();
3083 menuCheckShowAllContainerPlans->hide();
3084 menuCheckLockContainer->hide();
3085 menuCheckHideNonInspectedDemandElements->hide();
3086 menuCheckShowOverlappedRoutes->hide();
3093 if (menuCheckToggleGrid->shown()) {
3094 commands.push_back(menuCheckToggleGrid);
3096 if (menuCheckToggleDrawJunctionShape->shown()) {
3097 commands.push_back(menuCheckToggleDrawJunctionShape);
3099 if (menuCheckDrawSpreadVehicles->shown()) {
3100 commands.push_back(menuCheckDrawSpreadVehicles);
3102 if (menuCheckHideShapes->shown()) {
3103 commands.push_back(menuCheckHideShapes);
3105 if (menuCheckShowAllTrips->shown()) {
3106 commands.push_back(menuCheckShowAllTrips);
3108 if (menuCheckShowAllPersonPlans->shown() && menuCheckShowAllPersonPlans->isEnabled()) {
3109 commands.push_back(menuCheckShowAllPersonPlans);
3111 if (menuCheckLockPerson->shown() && menuCheckLockPerson->isEnabled()) {
3112 commands.push_back(menuCheckLockPerson);
3114 if (menuCheckShowAllContainerPlans->shown() && menuCheckShowAllContainerPlans->isEnabled()) {
3115 commands.push_back(menuCheckShowAllContainerPlans);
3117 if (menuCheckLockContainer->shown() && menuCheckLockContainer->isEnabled()) {
3118 commands.push_back(menuCheckLockContainer);
3120 if (menuCheckHideNonInspectedDemandElements->shown()) {
3121 commands.push_back(menuCheckHideNonInspectedDemandElements);
3123 if (menuCheckShowOverlappedRoutes->shown()) {
3124 commands.push_back(menuCheckShowOverlappedRoutes);
3131 return (menuCheckDrawSpreadVehicles->amChecked() == TRUE);
3137 if (menuCheckHideNonInspectedDemandElements->shown()) {
3138 const auto& inspectedElements = myViewNet->getInspectedElements();
3140 if ((menuCheckHideNonInspectedDemandElements->amChecked() == FALSE) || (inspectedElements.getFirstAC() ==
nullptr)) {
3143 }
else if (inspectedElements.getFirstAC() && inspectedElements.getFirstAC()->getTagProperty()->isDemandElement()) {
3144 if (inspectedElements.isACInspected(demandElement)) {
3150 if (inspectedElements.isACInspected(demandElementChild)) {
3156 if (inspectedElements.isACInspected(demandElementParent)) {
3176 if (menuCheckHideShapes->shown()) {
3177 return (menuCheckHideShapes->amChecked() == FALSE);
3186 return (menuCheckShowAllTrips->amChecked() == TRUE);
3192 if (menuCheckShowAllPersonPlans->isEnabled()) {
3193 return (menuCheckShowAllPersonPlans->amChecked() == TRUE);
3202 myLockedPerson = person;
3208 myLockedPerson =
nullptr;
3214 return myLockedPerson;
3220 if (menuCheckShowAllContainerPlans->isEnabled()) {
3221 return (menuCheckShowAllContainerPlans->amChecked() == TRUE);
3230 myLockedContainer = container;
3236 myLockedContainer =
nullptr;
3242 if (menuCheckShowOverlappedRoutes->isEnabled()) {
3243 return (menuCheckShowOverlappedRoutes->amChecked() == TRUE);
3252 return myLockedContainer;
3260 myViewNet(viewNet) {
3267 auto gripModes = myViewNet->getViewParent()->getGNEAppWindows()->getToolbarsGrip().modes;
3269 auto tooltipMenu = myViewNet->myViewParent->getGNEAppWindows()->getStaticTooltipMenu();
3271 menuCheckToggleDrawJunctionShape =
new MFXCheckableButton(
false, gripModes, tooltipMenu,
3272 (std::string(
"\t") +
TL(
"Hide junction shape") + std::string(
"\t") +
TL(
"Toggle hiding junction shape. (Ctrl+J)")),
3275 menuCheckToggleDrawJunctionShape->setChecked(
false);
3276 menuCheckToggleDrawJunctionShape->create();
3279 (std::string(
"\t") +
TL(
"Show additionals") + std::string(
"\t") +
TL(
"Toggle show additionals.")),
3282 menuCheckShowAdditionals->create();
3285 (std::string(
"\t") +
TL(
"Show shapes") + std::string(
"\t") +
TL(
"Toggle show shapes (Polygons and POIs).")),
3288 menuCheckShowShapes->create();
3291 (std::string(
"\t") +
TL(
"Show demand elements") + std::string(
"\t") +
TL(
"Toggle show demand elements.")),
3294 menuCheckShowDemandElements->create();
3297 (std::string(
"\t") +
TL(
"Draw TAZREL drawing mode") + std::string(
"\t") +
TL(
"Toggle draw TAZREL drawing mode.")),
3300 menuCheckToggleTAZRelDrawing->create();
3303 (std::string(
"\t") +
TL(
"Toggle draw TAZ fill") + std::string(
"\t") +
TL(
"Toggle draw TAZ fill")),
3306 menuCheckToggleTAZDrawFill->create();
3308 menuCheckToggleTAZRelOnlyFrom =
new MFXCheckableButton(
false, gripModes, tooltipMenu,
3309 (std::string(
"\t") +
TL(
"Toggle draw TAZRel only from") + std::string(
"\t") +
TL(
"Toggle draw TAZRel only from")),
3312 menuCheckToggleTAZRelOnlyFrom->create();
3315 (std::string(
"\t") +
TL(
"Toggle draw TAZRel only to") + std::string(
"\t") +
TL(
"Toggle draw TAZRel only to")),
3318 menuCheckToggleTAZRelOnlyTo->create();
3321 gripModes->recalc();
3327 menuCheckToggleDrawJunctionShape->hide();
3328 menuCheckShowAdditionals->hide();
3329 menuCheckShowShapes->hide();
3330 menuCheckShowDemandElements->hide();
3331 menuCheckToggleTAZRelDrawing->hide();
3332 menuCheckToggleTAZDrawFill->hide();
3333 menuCheckToggleTAZRelOnlyFrom->hide();
3334 menuCheckToggleTAZRelOnlyTo->hide();
3341 if (menuCheckToggleDrawJunctionShape->shown()) {
3342 commands.push_back(menuCheckToggleDrawJunctionShape);
3344 if (menuCheckShowAdditionals->shown()) {
3345 commands.push_back(menuCheckShowAdditionals);
3347 if (menuCheckShowShapes->shown()) {
3348 commands.push_back(menuCheckShowShapes);
3350 if (menuCheckShowDemandElements->shown()) {
3351 commands.push_back(menuCheckShowDemandElements);
3353 if (menuCheckToggleTAZRelDrawing->shown()) {
3354 commands.push_back(menuCheckToggleTAZRelDrawing);
3356 if (menuCheckToggleTAZDrawFill->shown()) {
3357 commands.push_back(menuCheckToggleTAZDrawFill);
3359 if (menuCheckToggleTAZRelOnlyFrom->shown()) {
3360 commands.push_back(menuCheckToggleTAZRelOnlyFrom);
3362 if (menuCheckToggleTAZRelOnlyTo->shown()) {
3363 commands.push_back(menuCheckToggleTAZRelOnlyTo);
3370 if (menuCheckShowAdditionals->shown()) {
3371 return (menuCheckShowAdditionals->amChecked() == TRUE);
3380 if (menuCheckShowShapes->shown()) {
3381 return (menuCheckShowShapes->amChecked() == TRUE);
3390 if (menuCheckShowDemandElements->shown()) {
3391 return (menuCheckShowDemandElements->amChecked() == TRUE);
3400 return (menuCheckToggleTAZRelDrawing->amChecked() != TRUE);
3406 if (menuCheckToggleTAZDrawFill->shown()) {
3407 return (menuCheckToggleTAZDrawFill->amChecked() != TRUE);
3416 if (menuCheckToggleTAZRelOnlyFrom->shown()) {
3417 return (menuCheckToggleTAZRelOnlyFrom->amChecked() != TRUE);
3426 if (menuCheckToggleTAZRelOnlyTo->shown()) {
3427 return (menuCheckToggleTAZRelOnlyTo->amChecked() != TRUE);
3438 myViewNet(viewNet) {
3444 const auto staticTooltip = myViewNet->myViewParent->getGNEAppWindows()->getStaticTooltipMenu();
3446 FXLabel* genericDataLabel =
new FXLabel(myViewNet->myViewParent->getGNEAppWindows()->getToolbarsGrip().intervalBar,
3448 genericDataLabel->create();
3450 myGenericDataTypesComboBox =
new MFXComboBoxIcon(myViewNet->myViewParent->getGNEAppWindows()->getToolbarsGrip().intervalBar,
3453 myGenericDataTypesComboBox->create();
3455 myGenericDataTypesComboBox->appendIconItem(
"<all>");
3460 FXLabel* dataSetLabel =
new FXLabel(myViewNet->myViewParent->getGNEAppWindows()->getToolbarsGrip().intervalBar,
3462 dataSetLabel->create();
3464 myDataSetsComboBox =
new MFXComboBoxIcon(myViewNet->myViewParent->getGNEAppWindows()->getToolbarsGrip().intervalBar,
3467 myDataSetsComboBox->create();
3469 myIntervalCheckBox =
new FXCheckButton(myViewNet->myViewParent->getGNEAppWindows()->getToolbarsGrip().intervalBar,
3471 myIntervalCheckBox->create();
3473 myBeginTextField =
new FXTextField(myViewNet->myViewParent->getGNEAppWindows()->getToolbarsGrip().intervalBar,
3475 myBeginTextField->create();
3477 myEndTextField =
new FXTextField(myViewNet->myViewParent->getGNEAppWindows()->getToolbarsGrip().intervalBar,
3479 myEndTextField->create();
3481 FXLabel* parameterLabel =
new FXLabel(myViewNet->myViewParent->getGNEAppWindows()->getToolbarsGrip().intervalBar,
3483 parameterLabel->create();
3485 myParametersComboBox =
new MFXComboBoxIcon(myViewNet->myViewParent->getGNEAppWindows()->getToolbarsGrip().intervalBar,
3488 myParametersComboBox->create();
3490 myViewNet->myViewParent->getGNEAppWindows()->getToolbarsGrip().intervalBar->recalc();
3497 updateIntervalBar();
3499 myViewNet->myViewParent->getGNEAppWindows()->getToolbarsGrip().intervalBar->show();
3506 myViewNet->myViewParent->getGNEAppWindows()->getToolbarsGrip().intervalBar->hide();
3513 if (myUpdateInterval && myViewNet->getNet()) {
3520 myParameters.clear();
3522 for (
const auto& dataSet : myViewNet->getNet()->getAttributeCarriers()->getDataSets()) {
3524 myDataSets.push_back(dataSet.second->getID());
3526 for (
const auto& interval : dataSet.second->getDataIntervalChildren()) {
3529 begin = interval.first;
3532 end = interval.first;
3535 for (
const auto& genericData : interval.second->getGenericDataChildren()) {
3537 for (
const auto& parameter : genericData->getParametersMap()) {
3538 myParameters.insert(parameter.first);
3544 const std::string previousDataSet = myDataSetsComboBox->getText().text();
3546 const std::string previousBegin = (myIntervalCheckBox->getCheck() == TRUE) ? myBeginTextField->getText().text() :
"";
3547 const std::string previousEnd = (myIntervalCheckBox->getCheck() == TRUE) ? myEndTextField->getText().text() :
"";
3549 const std::string previousParameter = myParametersComboBox->getText().text();
3551 myDataSetsComboBox->clearItems();
3552 myParametersComboBox->clearItems();
3554 myDataSetsComboBox->appendIconItem(
"<all>");
3555 myParametersComboBox->appendIconItem(
"<all>");
3557 for (
const auto& dataSet : myDataSets) {
3558 myDataSetsComboBox->appendIconItem(dataSet.c_str());
3561 myBeginTextField->setText(
toString(begin).c_str());
3562 myEndTextField->setText(
toString(end).c_str());
3564 for (
const auto& parameter : myParameters) {
3565 myParametersComboBox->appendIconItem(parameter.c_str());
3568 myDataSetsComboBox->setCurrentItem(0, FALSE);
3569 for (
int i = 0; i < myDataSetsComboBox->getNumItems(); i++) {
3570 if (myDataSetsComboBox->getItemText(i) == previousDataSet) {
3571 myDataSetsComboBox->setCurrentItem(i);
3575 if (myIntervalCheckBox->getCheck() == TRUE) {
3576 myBeginTextField->setText(previousBegin.c_str());
3577 myEndTextField->setText(previousEnd.c_str());
3580 myParametersComboBox->setCurrentItem(0, FALSE);
3581 for (
int i = 0; i < myParametersComboBox->getNumItems(); i++) {
3582 if (myParametersComboBox->getItemText(i) == previousParameter) {
3583 myParametersComboBox->setCurrentItem(i);
3590 enableIntervalBar();
3592 disableIntervalBar();
3595 myUpdateInterval =
false;
3602 myUpdateInterval =
true;
3608 if (myGenericDataTypesComboBox->isEnabled() && (myGenericDataTypesComboBox->getTextColor() ==
GUIDesignTextColorBlack)) {
3623 if (!myDataSetsComboBox->isEnabled() ||
3624 (myDataSetsComboBox->getCurrentItem() == 0) ||
3635 if (!myIntervalCheckBox->isEnabled() || (myIntervalCheckBox->getCheck() == FALSE)) {
3638 return GNEAttributeCarrier::parse<double>(myBeginTextField->getText().text());
3645 if (!myIntervalCheckBox->isEnabled() || (myIntervalCheckBox->getCheck() == FALSE)) {
3648 return GNEAttributeCarrier::parse<double>(myEndTextField->getText().text());
3655 if (!myParametersComboBox->isEnabled() ||
3656 (myParametersComboBox->getCurrentItem() == 0) ||
3660 return myParametersComboBox->getText().text();
3667 if ((myGenericDataTypesComboBox->getText() ==
"<all>") ||
3676 myViewNet->updateViewNet();
3683 if (std::find(myDataSets.begin(), myDataSets.end(), myDataSetsComboBox->getText().text()) != myDataSets.end()) {
3689 myViewNet->updateViewNet();
3696 if (myIntervalCheckBox->isEnabled() && (myIntervalCheckBox->getCheck() == TRUE)) {
3697 myBeginTextField->enable();
3698 myEndTextField->enable();
3700 myBeginTextField->disable();
3701 myEndTextField->disable();
3704 myViewNet->updateViewNet();
3710 if (myBeginTextField->getText().empty()) {
3711 myBeginTextField->setText(
toString(myViewNet->getNet()->getDataSetIntervalMinimumBegin()).c_str());
3713 }
else if (GNEAttributeCarrier::canParse<double>(myBeginTextField->getText().text())) {
3719 myViewNet->updateViewNet();
3725 if (myEndTextField->getText().empty()) {
3726 myEndTextField->setText(
toString(myViewNet->getNet()->getDataSetIntervalMaximumEnd()).c_str());
3728 }
else if (GNEAttributeCarrier::canParse<double>(myEndTextField->getText().text())) {
3734 myViewNet->updateViewNet();
3741 if (myParameters.count(myParametersComboBox->getText().text()) > 0) {
3747 myViewNet->updateViewNet();
3755 myGenericDataTypesComboBox->enable();
3756 myDataSetsComboBox->enable();
3757 myIntervalCheckBox->enable();
3758 if (myIntervalCheckBox->getCheck() == TRUE) {
3759 myBeginTextField->enable();
3760 myEndTextField->enable();
3762 myBeginTextField->disable();
3763 myEndTextField->disable();
3765 myParametersComboBox->enable();
3772 myGenericDataTypesComboBox->disable();
3773 myDataSetsComboBox->disable();
3774 myIntervalCheckBox->disable();
3775 myBeginTextField->disable();
3776 myEndTextField->disable();
3777 myParametersComboBox->disable();
3785 myViewNet(viewNet) {
3792 auto gripModes = myViewNet->getViewParent()->getGNEAppWindows()->getToolbarsGrip().modes;
3794 auto tooltipMenu = myViewNet->myViewParent->getGNEAppWindows()->getStaticTooltipMenu();
3797 std::string(
"\t") +
TL(
"Inspect mode") + std::string(
"\t") +
TL(
"Mode to inspect elements and change their attributes. (I)"),
3799 inspectButton->create();
3802 std::string(
"\t") +
TL(
"Delete mode") + std::string(
"\t") +
TL(
"Mode for deleting elements. (D)"),
3804 deleteButton->create();
3807 std::string(
"\t") +
TL(
"Select mode") + std::string(
"\t") +
TL(
"Mode for selecting elements. (S)"),
3809 selectButton->create();
3811 gripModes->recalc();
3817 inspectButton->show();
3818 deleteButton->show();
3819 selectButton->show();
3825 inspectButton->hide();
3826 deleteButton->hide();
3827 selectButton->hide();
3833 inspectButton->setChecked(
false);
3834 deleteButton->setChecked(
false);
3835 selectButton->setChecked(
false);
3841 inspectButton->update();
3842 deleteButton->update();
3843 selectButton->update();
3851 myViewNet(viewNet) {
3858 auto gripModes = myViewNet->getViewParent()->getGNEAppWindows()->getToolbarsGrip().modes;
3860 auto tooltipMenu = myViewNet->myViewParent->getGNEAppWindows()->getStaticTooltipMenu();
3863 std::string(
"\t") +
TL(
"Move mode") + std::string(
"\t") +
TL(
"Mode for moving elements. (M)"),
3865 moveNetworkElementsButton->create();
3868 std::string(
"\t") +
TL(
"Edge mode") + std::string(
"\t") +
TL(
"Mode for creating junctions and edges. (E)"),
3870 createEdgeButton->create();
3873 std::string(
"\t") +
TL(
"Traffic light mode") + std::string(
"\t") +
TL(
"Mode for editing traffic lights over junctions. (T)"),
3875 trafficLightButton->create();
3878 std::string(
"\t") +
TL(
"Connection mode") + std::string(
"\t") +
TL(
"Mode for edit connections between lanes. (C)"),
3880 connectionButton->create();
3883 std::string(
"\t") +
TL(
"Prohibition mode") + std::string(
"\t") +
TL(
"Mode for editing connection prohibitions. (H)"),
3885 prohibitionButton->create();
3888 std::string(
"\t") +
TL(
"Crossing mode") + std::string(
"\t") +
TL(
"Mode for creating crossings between edges. (R)"),
3890 crossingButton->create();
3893 std::string(
"\t") +
TL(
"Additional mode") + std::string(
"\t") +
TL(
"Mode for creating additional elements. (A)"),
3895 additionalButton->create();
3898 std::string(
"\t") +
TL(
"Wire mode") + std::string(
"\t") +
TL(
"Mode for editing overhead wires. (W)"),
3900 wireButton->create();
3903 std::string(
"\t") +
TL(
"TAZ mode") + std::string(
"\t") +
TL(
"Mode for creating Traffic Assignment Zones. (Z)"),
3905 TAZButton->create();
3908 std::string(
"\t") +
TL(
"Polygon mode") + std::string(
"\t") +
TL(
"Mode for creating polygons and POIs. (P)"),
3910 shapeButton->create();
3913 std::string(
"\t") +
TL(
"Decal mode") + std::string(
"\t") +
TL(
"Mode for editing decals. (U)"),
3915 decalButton->create();
3917 gripModes->recalc();
3924 if (myViewNet->getEditModes().isJuPedSimView()) {
3925 moveNetworkElementsButton->show();
3926 createEdgeButton->show();
3927 connectionButton->hide();
3928 trafficLightButton->hide();
3929 additionalButton->show();
3930 crossingButton->show();
3932 shapeButton->show();
3933 prohibitionButton->hide();
3935 decalButton->hide();
3937 moveNetworkElementsButton->show();
3938 createEdgeButton->show();
3939 connectionButton->show();
3940 trafficLightButton->show();
3941 additionalButton->show();
3942 crossingButton->show();
3944 shapeButton->show();
3945 prohibitionButton->show();
3947 decalButton->show();
3954 moveNetworkElementsButton->hide();
3955 createEdgeButton->hide();
3956 connectionButton->hide();
3957 trafficLightButton->hide();
3958 additionalButton->hide();
3959 crossingButton->hide();
3961 shapeButton->hide();
3962 prohibitionButton->hide();
3964 decalButton->hide();
3970 moveNetworkElementsButton->setChecked(
false);
3971 createEdgeButton->setChecked(
false);
3972 connectionButton->setChecked(
false);
3973 trafficLightButton->setChecked(
false);
3974 additionalButton->setChecked(
false);
3975 crossingButton->setChecked(
false);
3976 TAZButton->setChecked(
false);
3977 shapeButton->setChecked(
false);
3978 prohibitionButton->setChecked(
false);
3979 wireButton->setChecked(
false);
3980 decalButton->setChecked(
false);
3986 moveNetworkElementsButton->update();
3987 createEdgeButton->update();
3988 connectionButton->update();
3989 trafficLightButton->update();
3990 additionalButton->update();
3991 crossingButton->update();
3992 TAZButton->update();
3993 shapeButton->update();
3994 prohibitionButton->update();
3995 wireButton->update();
3996 decalButton->update();
4004 myViewNet(viewNet) {
4011 auto gripModes = myViewNet->getViewParent()->getGNEAppWindows()->getToolbarsGrip().modes;
4013 auto tooltipMenu = myViewNet->myViewParent->getGNEAppWindows()->getStaticTooltipMenu();
4016 std::string(
"\t") +
TL(
"Move mode") + std::string(
"\t") +
TL(
"Mode for moving elements. (M)"),
4018 moveDemandElementsButton->create();
4021 std::string(
"\t") +
TL(
"Route mode") + std::string(
"\t") +
TL(
"Mode for creating routes. (R)"),
4023 routeButton->create();
4026 std::string(
"\t") +
TL(
"Route distribution mode") + std::string(
"\t") +
TL(
"Mode for creating and editing rout distributions. (W)"),
4028 routeDistributionButton->create();
4031 std::string(
"\t") +
TL(
"Vehicle mode") + std::string(
"\t") +
TL(
"Mode for creating vehicles. (V)"),
4033 vehicleButton->create();
4036 std::string(
"\t") +
TL(
"Type mode") + std::string(
"\t") +
TL(
"Mode for creating types (of vehicles, persons and containers). (T)"),
4038 typeButton->create();
4041 std::string(
"\t") +
TL(
"Type distribution mode") + std::string(
"\t") +
TL(
"Mode for creating and editing type distribution. (U)"),
4043 typeDistributionButton->create();
4046 std::string(
"\t") +
TL(
"Stop mode") + std::string(
"\t") +
TL(
"Mode for creating stops. (A)"),
4048 stopButton->create();
4051 std::string(
"\t") +
TL(
"Person mode") + std::string(
"\t") +
TL(
"Mode for creating persons. (P)"),
4053 personButton->create();
4056 std::string(
"\t") +
TL(
"Person plan mode") + std::string(
"\t") +
TL(
"Mode for creating person plans. (L)"),
4058 personPlanButton->create();
4061 std::string(
"\t") +
TL(
"Container mode") + std::string(
"\t") +
TL(
"Mode for creating containers. (C)"),
4063 containerButton->create();
4066 std::string(
"\t") +
TL(
"Container plan mode") + std::string(
"\t") +
TL(
"Mode for creating container plans. (H)"),
4068 containerPlanButton->create();
4070 gripModes->recalc();
4076 if (myViewNet->getEditModes().isJuPedSimView()) {
4077 moveDemandElementsButton->hide();
4078 routeButton->show();
4079 routeDistributionButton->show();
4080 vehicleButton->hide();
4082 typeDistributionButton->show();
4084 personButton->show();
4085 personPlanButton->show();
4086 containerButton->hide();
4087 containerPlanButton->hide();
4089 moveDemandElementsButton->show();
4090 routeButton->show();
4091 routeDistributionButton->show();
4092 vehicleButton->show();
4094 typeDistributionButton->show();
4096 personButton->show();
4097 personPlanButton->show();
4098 containerButton->show();
4099 containerPlanButton->show();
4106 moveDemandElementsButton->hide();
4107 routeButton->hide();
4108 routeDistributionButton->hide();
4109 vehicleButton->hide();
4111 typeDistributionButton->hide();
4113 personButton->hide();
4114 personPlanButton->hide();
4115 containerButton->hide();
4116 containerPlanButton->hide();
4122 moveDemandElementsButton->setChecked(
false);
4123 routeButton->setChecked(
false);
4124 routeDistributionButton->setChecked(
false);
4125 vehicleButton->setChecked(
false);
4126 typeButton->setChecked(
false);
4127 typeDistributionButton->setChecked(
false);
4128 stopButton->setChecked(
false);
4129 personButton->setChecked(
false);
4130 personPlanButton->setChecked(
false);
4131 containerButton->setChecked(
false);
4132 containerPlanButton->setChecked(
false);
4138 moveDemandElementsButton->update();
4139 routeButton->update();
4140 routeDistributionButton->update();
4141 vehicleButton->update();
4142 typeButton->update();
4143 typeDistributionButton->update();
4144 stopButton->update();
4145 personButton->update();
4146 personPlanButton->update();
4147 containerButton->update();
4148 containerPlanButton->update();
4156 myViewNet(viewNet) {
4163 auto gripModes = myViewNet->getViewParent()->getGNEAppWindows()->getToolbarsGrip().modes;
4165 auto tooltipMenu = myViewNet->myViewParent->getGNEAppWindows()->getStaticTooltipMenu();
4168 std::string(
"\t") +
TL(
"Edge data mode") + std::string(
"\t") +
TL(
"Mode for creating edge datas. (E)"),
4170 edgeDataButton->create();
4173 std::string(
"\t") +
TL(
"Edge relation data mode") + std::string(
"\t") +
TL(
"Mode for creating edge relation datas. (R)"),
4175 edgeRelDataButton->create();
4178 std::string(
"\t") +
TL(
"TAZ relation data mode") + std::string(
"\t") +
TL(
"Mode for creating TAZ relation datas. (Z)"),
4180 TAZRelDataButton->create();
4183 std::string(
"\t") +
TL(
"MeanData mode") + std::string(
"\t") +
TL(
"Mode for MeanData elements. (M)"),
4185 meanDataButton->create();
4187 gripModes->recalc();
4193 edgeDataButton->show();
4194 edgeRelDataButton->show();
4195 TAZRelDataButton->show();
4196 meanDataButton->show();
4202 edgeDataButton->hide();
4203 edgeRelDataButton->hide();
4204 TAZRelDataButton->hide();
4205 meanDataButton->hide();
4211 edgeDataButton->setChecked(
false);
4212 edgeRelDataButton->setChecked(
false);
4213 TAZRelDataButton->setChecked(
false);
4214 meanDataButton->setChecked(
false);
4220 edgeDataButton->update();
4221 edgeRelDataButton->update();
4222 TAZRelDataButton->update();
4223 meanDataButton->update();
4238 if (element && (myEditedNetworkElement ==
nullptr)) {
4240 myPreviousNetworkEditMode = myViewNet->myEditModes.networkEditMode;
4244 myEditedNetworkElement = element;
4248 myViewNet->updateViewNet();
4256 if (myEditedNetworkElement !=
nullptr) {
4258 myEditedNetworkElement->setShapeEdited(
false);
4260 myEditedNetworkElement =
nullptr;
4262 if (myViewNet->myEditModes.networkEditMode != myPreviousNetworkEditMode) {
4263 myViewNet->myEditModes.setNetworkEditMode(myPreviousNetworkEditMode);
4272 if (myEditedNetworkElement !=
nullptr) {
4274 stopEditCustomShape();
4281 return myEditedNetworkElement;
4291 const double size,
const double offsetx,
const double offsety) {
4293 if (checkDrawing(d, AC, type, exaggeration)) {
4299 glTranslated(offsetx, offsety, 0);
4301 glRotated(180, 0, 0, 1);
4325 if (exaggeration == 0) {
4329 if (viewNet->getEditModes().isCurrentSupermodeNetwork() &&
4351const std::vector<RGBColor>&
4376 }
else if (value >= max) {
4380 const double procent = ((value - min) * 100) / (max - min);
4384 }
else if (procent >= 100) {
4394std::vector<GUIGlObject*>
4396 std::vector<GUIGlObject*> filteredGLObjects;
4397 if (GLObjects.size() > 0) {
4398 const auto firstLayer = GLObjects.front()->getType();
4399 for (
const auto& GLObject : GLObjects) {
4401 (GLO_RIDE <= GLObject->getType()) && (GLObject->getType() <=
GLO_TRANSHIP)) {
4402 filteredGLObjects.push_back(GLObject);
4404 (GLO_STOP <= GLObject->getType()) && (GLObject->getType() <=
GLO_STOP_PLAN)) {
4405 filteredGLObjects.push_back(GLObject);
4407 (GLO_VEHICLE <= GLObject->getType()) && (GLObject->getType() <=
GLO_ROUTEFLOW)) {
4408 filteredGLObjects.push_back(GLObject);
4410 (GLO_PERSON <= GLObject->getType()) && (GLObject->getType() <=
GLO_PERSONFLOW)) {
4411 filteredGLObjects.push_back(GLObject);
4413 (GLO_CONTAINER <= GLObject->getType()) && (GLObject->getType() <=
GLO_CONTAINERFLOW)) {
4414 filteredGLObjects.push_back(GLObject);
4415 }
else if (GLObject->getType() == firstLayer) {
4416 filteredGLObjects.push_back(GLObject);
4420 return filteredGLObjects;
DataEditMode
enum for data edit modes
@ 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..)
NetworkEditMode
@brie enum for network edit modes
@ NETWORK_DELETE
mode for deleting network elements
@ NETWORK_MOVE
mode for moving network elements
@ NETWORK_WIRE
Mode for editing wires.
@ NETWORK_CREATE_EDGE
mode for creating new edges
@ NETWORK_TLS
mode for editing tls
@ NETWORK_SELECT
mode for selecting network elements
@ NETWORK_INSPECT
mode for inspecting network elements
@ NETWORK_PROHIBITION
Mode for editing connection prohibitions.
@ NETWORK_NONE
empty Network mode
@ NETWORK_CONNECT
mode for connecting lanes
DemandEditMode
@brie enum for demand edit modes
@ 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
@ MID_GNE_NETWORKVIEWOPTIONS_AUTOOPPOSITEEDGES
automatically create opposite edge
@ MID_HOTKEY_CTRL_SHIFT_B_SAVEDATAELEMENTS
save Data Elements
@ MID_HOTKEY_F3_SUPERMODE_DEMAND
select demand supermode in netedit
@ MID_GNE_DEMANDVIEWOPTIONS_SHOWALLPERSONPLANS
show all person plans
@ MID_GNE_DATAVIEWOPTIONS_TAZRELDRAWING
toggle TAZRel drawing
@ MID_HOTKEY_U_MODE_DECAL_TYPEDISTRIBUTION
hotkey for mode decal AND type distribution
@ MID_GNE_NETWORKVIEWOPTIONS_DRAWSPREADVEHICLES
Draw vehicles in begin position or spread in lane.
@ MID_GNE_NETWORKVIEWOPTIONS_MOVEELEVATION
move elevation instead of x,y
@ MID_GNE_NETWORKVIEWOPTIONS_HIDECONNECTIONS
hide connections
@ MID_GNE_NETWORKVIEWOPTIONS_SHOWCONNECTIONS
show connections
@ MID_GNE_INTERVALBAR_BEGIN
begin changed in InterbalBar
@ MID_GNE_DATAVIEWOPTIONS_TAZRELONLYTO
toggle draw TAZRel only to
@ MID_GNE_DATAVIEWOPTIONS_TOGGLEDRAWJUNCTIONSHAPE
toggle draw junction shape
@ MID_GNE_NETWORKVIEWOPTIONS_SHOWTAZELEMENTS
show TAZ elements
@ MID_GNE_DEMANDVIEWOPTIONS_LOCKPERSON
lock person
@ MID_HOTKEY_Z_MODE_TAZ_TAZREL
hotkey for mode editing TAZ and TAZRel
@ MID_GNE_DEMANDVIEWOPTIONS_TOGGLEDRAWJUNCTIONSHAPE
toggle draw junction shape
@ MID_HOTKEY_A_MODE_STARTSIMULATION_ADDITIONALS_STOPS
hotkey for start simulation in SUMO and set editing mode additionals AND stops in netedit
@ MID_GNE_TOGGLE_TIMEFORMAT
switch time format
@ MID_GNE_DEMANDVIEWOPTIONS_SHOWGRID
show grid
@ MID_HOTKEY_CTRL_SHIFT_D_SAVEDEMANDELEMENTS
Save Demand Elements.
@ MID_HOTKEY_CTRL_S_STOPSIMULATION_SAVENETWORK
Stop the simulation in SUMO and save network in netedit.
@ MID_HOTKEY_D_MODE_SINGLESIMULATIONSTEP_DELETE
hotkey for perform a single simulation step in SUMO and set delete mode in netedit
@ MID_GNE_NETWORKVIEWOPTIONS_CHAINEDGES
create edges in chain mode
@ MID_GNE_DATAVIEWOPTIONS_SHOWDEMANDELEMENTS
show demand elements
@ MID_HOTKEY_C_MODE_CONNECT_CONTAINER
hotkey for mode connecting lanes AND container
@ MID_HOTKEY_H_MODE_PROHIBITION_CONTAINERPLAN
hotkey for mode prohibition AND container plan
@ MID_HOTKEY_W_MODE_WIRE_ROUTEDISTRIBUTION
hotkey for mode editing overhead wires AND route distributions
@ MID_HOTKEY_T_MODE_TLS_TYPE
hotkey for mode editing TLS AND Vehicle Types
@ MID_GNE_DEMANDVIEWOPTIONS_HIDESHAPES
hide shapes
@ MID_GNE_DATAVIEWOPTIONS_SHOWADDITIONALS
show additionals
@ MID_GNE_NETWORKVIEWOPTIONS_SHOWBUBBLES
show junctions as bubbles
@ MID_GNE_INTERVALBAR_END
end changed in InterbalBar
@ MID_GNE_NETWORKVIEWOPTIONS_EXTENDSELECTION
extend selection
@ MID_HOTKEY_S_MODE_STOPSIMULATION_SELECT
hotkey for stop simulation in SUMO and set select mode in netedit
@ MID_GNE_NETWORKVIEWOPTIONS_SHOWSUBADDITIONALS
show sub-additionals
@ MID_GNE_DEMANDVIEWOPTIONS_SHOWALLCONTAINERPLANS
show all container plans
@ MID_GNE_VIEW_DEFAULT
set default view
@ MID_HOTKEY_F4_SUPERMODE_DATA
select data supermode in netedit
@ MID_GNE_VIEW_JUPEDSIM
set juPedSim view
@ MID_GNE_INTERVALBAR_PARAMETER
parameter changed in InterbalBar
@ MID_HOTKEY_R_MODE_CROSSING_ROUTE_EDGERELDATA
hotkey for mode editing crossing, routes and edge rel datas
@ MID_GNE_DATAVIEWOPTIONS_TAZDRAWFILL
toggle draw TAZ fill
@ MID_HOTKEY_L_MODE_PERSONPLAN
hotkey for mode person plan
@ MID_HOTKEY_V_MODE_VEHICLE
hotkey for mode create vehicles
@ MID_HOTKEY_I_MODE_INSPECT
hotkey for mode inspecting object attributes
@ MID_GNE_NETWORKVIEWOPTIONS_SHOWDEMANDELEMENTS
show demand elements
@ MID_HOTKEY_CTRL_SHIFT_E_SAVENETEDITCONFIG
save netedit Config
@ MID_GNE_DEMANDVIEWOPTIONS_HIDENONINSPECTED
hide non-inspected demand element
@ MID_GNE_INTERVALBAR_GENERICDATATYPE
generic data selected
@ MID_GNE_NETWORKVIEWOPTIONS_MERGEAUTOMATICALLY
don't ask before merging junctions
@ MID_HOTKEY_CTRL_SHIFT_M_SAVEMEANDATAELEMENTS
save Mean Datas
@ MID_GNE_NETWORKVIEWOPTIONS_CHANGEALLPHASES
change all phases
@ MID_GNE_DATAVIEWOPTIONS_SHOWSHAPES
show shapes
@ MID_HOTKEY_E_MODE_EDGE_EDGEDATA
hotkey for mode adding edges AND edgeDatas
@ MID_GNE_DATAVIEWOPTIONS_TAZRELONLYFROM
toggle draw TAZRel only from
@ MID_GNE_NETWORKVIEWOPTIONS_TOGGLEDRAWJUNCTIONSHAPE
toggle draw junction shape
@ MID_GNE_DEMANDVIEWOPTIONS_DRAWSPREADVEHICLES
Draw vehicles in begin position or spread in lane.
@ MID_GNE_DEMANDVIEWOPTIONS_SHOWOVERLAPPEDROUTES
show overlapped routes
@ MID_HOTKEY_CTRL_SHIFT_S_SAVESUMOCONFIG
save SUMOConfig (SUMO AND netedit)
@ MID_GNE_INTERVALBAR_DATASET
data set selected
@ MID_HOTKEY_M_MODE_MOVE_MEANDATA
hotkey for mode moving element AND mean data
@ MID_HOTKEY_F2_SUPERMODE_NETWORK
select network supermode in netedit
@ MID_GNE_DEMANDVIEWOPTIONS_LOCKCONTAINER
lock container
@ MID_GNE_NETWORKVIEWOPTIONS_SELECTEDGES
select edges
@ MID_GNE_DEMANDVIEWOPTIONS_SHOWTRIPS
show all trips
@ MID_GNE_NETWORKVIEWOPTIONS_TOGGLEGRID
show grid
@ MID_GNE_INTERVALBAR_LIMITED
enable/disable show data elements by interval
@ MID_HOTKEY_P_MODE_POLYGON_PERSON
hotkey for mode creating polygons
@ MID_HOTKEY_CTRL_SHIFT_A_SAVEADDITIONALELEMENTS
Save Additional Elements.
#define GUIDesignTextColorRed
red color (for invalid text)
#define GUIDesignButtonPopup
checkable button placed in popup (for example, locate buttons)
#define GUIDesignButtonToolbar
little button with icon placed in navigation toolbar
#define GUIDesignButtonLeft
button extended over over Frame with thick and raise frame
#define GUIDesignComboBoxFixed(customWidth)
comboBox with thick frame, fixed width
#define GUIDesignTextFieldNCol
Num of column of text field.
#define GUIDesignTLSTableCheckableButtonIcon
checkable button only with icon used in TLSTable
#define GUIDesignComboBoxVisibleItemsFixed
combo box size fixed
#define GUIDesignTextColorBlack
black color (for correct text)
#define GUIDesignTextFieldFixedRestricted(width, type)
text field with fixed width
#define GUIDesignMFXCheckableButtonSquare
#define GUIDesignButtonToolbarLocator
little checkable button with icon placed in navigation toolbar used specify for Locator
#define GUIDesignMFXCheckableButtonSupermode
checkable button with icon placed in navigation toolbar for supermodes
#define GUIDesignCheckButtonAttribute
checkButton without thick extended over the frame used for attributes
#define GUIDesignLabelThickedFixed(width)
label thicked, icon before text, text centered and custom width
@ GLO_EDGERELDATA
edge relation data
@ GLO_TAZRELDATA
TAZ relation data.
@ GLO_WALKINGAREA
a walkingArea
@ GLO_JPS_WALKABLEAREA
walkable area
@ GLO_ROUTE_EMBEDDED
a route
@ GLO_TESTELEMENT
test element (used in netedit)
@ GLO_TRANSHIP
a container tranship
@ GLO_STOPPING_PLACE_LAST
reserved GLO type for packing all StoppingPlace elements
@ GLO_STOP_PLAN
a stop plan stop
@ GLO_ROUTEFLOW
a routeFlow
@ GLO_WIRE
reserved GLO type for packing all wire elements
@ GLO_TAZ
Traffic Assignment Zones (TAZs)
@ GLO_CONTAINER
a container
@ GLO_JPS_OBSTACLE
obstacles
@ GLO_CONNECTION
a connection
@ GLO_ADDITIONALELEMENT
reserved GLO type for packing all additionals elements
@ GLO_PERSONTRIP
a person trip
@ GLO_STOPPING_PLACE
reserved GLO type for packing all StoppingPlace elements
@ GLO_TRANSPORT
a container transport
@ GLO_POI
poi (over view, geo and lane)
@ GLO_RECTANGLESELECTION
rectangle selection shape (used in netedit)
@ GLO_CONTAINERFLOW
a person flow
@ GLO_PERSONFLOW
a person flow
@ GLO_TRACTIONSUBSTATION
a segment of an overhead line
@ GLO_LOCKICON
Lock icon (used in netedit)
GUIViewObjectsHandler gViewObjectsHandler
@ DATAMODE_CHECKBOX_SHOWADDITIONALS
@ NETWORKMODE_CHECKBOX_BUBBLES
@ DATAMODE_CHECKBOX_TAZRELONLYFROM
@ SAVE_ADDITIONALELEMENTS
@ DEMANDMODE_CHECKBOX_HIDENONINSPECTEDDEMANDELEMENTS
@ NETWORKMODE_CHECKBOX_HIDECONNECTIONS
@ DEMANDMODE_CHECKBOX_SHOWTRIPS
@ COMMONMODE_CHECKBOX_TOGGLEDRAWJUNCTIONSHAPE
@ DATAMODE_CHECKBOX_SHOWSHAPES
@ NETWORKMODE_CHECKBOX_SELECTEDGES
@ COMMONMODE_CHECKBOX_SHOWDEMANDELEMENTS
@ DEMANDMODE_CHECKBOX_LOCKPERSON
@ NETWORKMODE_CHECKBOX_MERGEAUTOMATICALLY
@ NETWORKMODE_CHECKBOX_APPLYTOALLPHASES
@ DATAMODE_CHECKBOX_TAZRELONLYTO
@ NETWORKMODE_CHECKBOX_AUTOSELECTJUNCTIONS
@ DATAMODE_CHECKBOX_TAZRELDRAWING
@ NETWORKMODE_CHECKBOX_SHOWCONNECTIONS
@ DEMANDMODE_CHECKBOX_SHOWPERSONPLANS
@ DEMANDMODE_CHECKBOX_HIDESHAPES
@ DATAMODE_CHECKBOX_TAZDRAWFILL
@ NETWORKMODE_CHECKBOX_ELEVATION
@ COMMONMODE_CHECKBOX_SPREADVEHICLE
@ DEMANDMODE_CHECKBOX_LOCKCONTAINER
@ NETWORKMODE_CHECKBOX_SHOWSUBADDITIONALS
@ NETWORKMODE_CHECKBOX_SHOWTAZELEMENTS
@ NETWORKMODE_CHECKBOX_CHAIN
@ DEMANDMODE_CHECKBOX_SHOWOVERLAPPEDROUTES
@ COMMONMODE_CHECKBOX_TOGGLEGRID
@ DEMANDMODE_CHECKBOX_SHOWCONTAINERPLANS
@ NETWORKMODE_CHECKBOX_TWOWAY
#define WRITE_ERRORF(...)
SumoXMLTag
Numbers representing SUMO-XML - element names.
@ SUMO_TAG_EDGEREL
a relation between two edges
@ SUMO_TAG_TAZ
a traffic assignment zone
@ SUMO_TAG_NOTHING
invalid tag, must be the last one
@ SUMO_TAG_CONNECTION
connectioon between two lanes
@ SUMO_TAG_WALKINGAREA
walking area for pedestrians
@ SUMO_TAG_JUNCTION
begin/end of the description of a junction
@ SUMO_TAG_CROSSING
crossing between edges for pedestrians
@ SUMO_TAG_LANE
begin/end of the description of a single lane
@ SUMO_TAG_TAZREL
a relation between two TAZs
@ SUMO_TAG_EDGE
begin/end of the description of an edge
@ GNE_ATTR_SELECTED
element is selected
const double INVALID_DOUBLE
invalid double
std::string toString(const T &t, std::streamsize accuracy=gPrecision)
A class that stores a 2D geometrical boundary.
void add(double x, double y, double z=0)
Makes the boundary include the given coordinate.
PositionVector getShape(const bool closeShape) const
get position vector (shape) based on this boundary
void addParentID(const SumoXMLTag tag, const std::string &ID)
add parent (string) attribute into current SumoBaseObject node
static void setColor(const RGBColor &c)
Sets the gl-color to this value.
static void popMatrix()
pop matrix
static void pushMatrix()
push matrix
bool isAttributeCarrierSelected() const
check if attribute carrier is selected
bool isMarkedForDrawingFront() const
check if this AC is marked for drawing front
virtual GNEMoveElement * getMoveElement() const =0
get GNEMoveElement associated with this AttributeCarrier
const GNETagProperties * getTagProperty() const
get tagProperty associated with this Attribute Carrier
void unmarkForDrawingFront()
unmark for drawing front
GNENet * getNet() const
get pointer to net
An Element which don't belong to GNENet but has influence in the simulation.
bool isConvexAngle() const
check if edge makes a convex angle [0 - 180) degrees
NBEdge * getNBEdge() const
returns the internal NBEdge
An Element which don't belong to GNENet but has influence in the simulation.
const GNEHierarchicalContainerParents< GNEDemandElement * > & getParentDemandElements() const
get parent demand elements
const GNEHierarchicalContainerChildren< GNEDemandElement * > & getChildDemandElements() const
return child demand elements
static void commitMove(const GNEViewNet *viewNet, GNEMoveOperation *moveOperation, const GNEMoveOffset &offset, GNEUndoList *undoList)
commit move element for the given offset
static void moveElement(const GNEViewNet *viewNet, GNEMoveOperation *moveOperation, const GNEMoveOffset &offset)
move element the for given offset (note: offset can be X-Y-0, 0-0-Z or X-Y-Z)
GNEJunction * retrieveJunction(const std::string &id, bool hardFail=true) const
get junction by id
GNEDataSet * retrieveDataSet(const std::string &id, bool hardFail=true) const
Returns the named data set.
GNEDemandElement * retrieveDemandElement(SumoXMLTag type, const std::string &id, bool hardFail=true) const
Returns the named demand element.
GNENetHelper::AttributeCarriers * getAttributeCarriers() const
get all attribute carriers used in this net
GNEViewNet * getViewNet() const
get view net
void setShapeEdited(const bool value)
set shape edited
An Element which don't belong to GNENet but has influence in the simulation.
bool isNetworkElement() const
network elements
bool isDataElement() const
return true if tag correspond to a data element
bool isDemandElement() const
return true if tag correspond to a demand element
bool isAdditionalElement() const
return true if tag correspond to an additional element (note: this include TAZ, shapes and wires)
bool isInspectingElements() const
check if we're inspecting at least one element
void inspectAC(GNEAttributeCarrier *AC)
void inspectACs(const std::vector< GNEAttributeCarrier * > &ACs)
inspect multiple ACs
bool isACInspected(GNEAttributeCarrier *AC) const
const std::unordered_set< GNEAttributeCarrier * > & getACs() const
get hash table with all inspected ACs
GNEAttributeCarrier * getFirstAC() const
void uninspectAC(GNEAttributeCarrier *AC)
uninspect AC
bool isInspectingSingleElement() const
check if we're inspecting exactly one element
bool isInspectingMultipleElements() const
check if we're inspecting more than one elements
void clearInspectedElements()
clear inspected AC
InspectedElements()
constructor
void setDataSet()
set dataSet
void setParameter()
set parameter
std::string getParameter() const
get parameter
void hideIntervalBar()
hide all options menu checks
void setGenericDataType()
set generic data type
double getBegin() const
get begin
void showIntervalBar()
show interval option bar
void disableIntervalBar()
disable interval bar
void updateIntervalBar()
update interval bar
void buildIntervalBarElements()
build interval bar elements
GNEDataSet * getDataSet() const
get dataSet
IntervalBar(GNEViewNet *viewNet)
default constructor
void enableIntervalBar()
enable interval bar
void setInterval()
update limit by interval
double getEnd() const
get end
SumoXMLTag getGenericDataType() const
get generic data type
~OperationLocked()
destructor
Supermode getSupermode() const
get supermode
OperationLocked()
constructor
void updateLockMenuBar()
update lock inspect menuBar
bool isObjectLocked(GUIGlObjectType objectType, const bool selected) const
check if given GLObject is locked for inspect, select, delete and move
LockManager(GNEViewNet *viewNet)
constructor
std::map< GUIGlObjectType, OperationLocked > myLockedElements
map with locked elements
void updateFlags()
update flags
GNEViewNet * myViewNet
pointer to viewNet
void unmarkAC(GNEAttributeCarrier *AC)
unmark AC for drawing front
MarkFrontElements()
constructor
void markAC(GNEAttributeCarrier *AC)
mark AC as drawing front
void unmarkAll()
unmark all ACs
const std::unordered_set< GNEAttributeCarrier * > & getACs() const
get hash table with all fronted ACs
std::vector< GNEConnection * > connections
vector with the connections
std::vector< GNEGenericData * > genericDatas
vector with the generic datas
std::vector< GNEPOI * > POIs
vector with the POIs
std::vector< GNEInternalLane * > internalLanes
vector with the internal lanes
std::vector< GUIGlObject * > GUIGlObjects
vector with the GUIGlObjects
std::vector< GNELane * > lanes
vector with the lanes
std::vector< GNETAZRelData * > TAZRelDatas
vector with the TAZ relation datas
void reserve(int size)
reseve memory for all elements
std::vector< GNECrossing * > crossings
vector with the crossings
std::vector< GNEPoly * > polys
vector with the polys
std::vector< GNETAZ * > TAZs
vector with the TAZ elements
std::vector< GNEAdditional * > additionals
vector with the additional elements
std::vector< GNEAttributeCarrier * > attributeCarriers
vector with the attribute carriers
void clearElements()
clear elements
std::vector< GNENetworkElement * > networkElements
vector with the network elements
std::vector< GNEEdgeData * > edgeDatas
vector with the edge datas
std::vector< GNEEdgeRelData * > edgeRelDatas
vector with the edge relation datas
std::vector< GNEEdge * > edges
vector with the edges
void filterElements(const std::vector< const GUIGlObject * > &objects)
filter elements
std::vector< GNEJunction * > junctions
vector with the junctions
std::vector< GNEWalkingArea * > walkingAreas
vector with the walkingAreas
std::vector< GNEDemandElement * > demandElements
vector with the demand elements
ViewObjectsContainer()
constructor
GNEEdgeRelData * getEdgeRelDataElementFront() const
get edge rel data element or a pointer to nullptr
void updateObjects()
update objects (using gViewObjectsHandler)
void filterConnections()
filter (remove) connections
void filterAllExcept(GUIGlObjectType exception)
filter all elements except the given GLO type
GNEEdgeData * getEdgeDataElementFront() const
get edge data element or a pointer to nullptr
const std::vector< const GNEJunction * > & getMergingJunctions() const
get merging junctions
void updateShapeElements(ViewObjectsContainer &container, const GUIGlObject *glObject)
update shape elements
void updateMergingJunctions()
update merging junctions
GNEConnection * getConnectionFront() const
get front connection or a pointer to nullptr
const std::vector< GNEAttributeCarrier * > & getAttributeCarriers() const
get vector with ACs
void filterEdges()
filter (remove) edges
GNEPoly * getPolyFront() const
get front Poly or a pointer to nullptr
void updateDemandElements(ViewObjectsContainer &container, const GUIGlObject *glObject)
update demand elements
void filterLockedElements(const std::vector< GUIGlObjectType > ignoreFilter={})
filter locked elements (except the ignoreFilter)
void filterCrossings()
filter (remove) crossings
GNEPOI * getPOIFront() const
get front POI or a pointer to nullptr
GNEInternalLane * getInternalLaneFront() const
get front internal lane or a pointer to nullptr
void filterNetworkElements()
filter (remove) network elements
void processGUIGlObjects(const GUIViewObjectsHandler::GLObjectsSortedContainer &objectsContainer)
process GL objects
const std::vector< GNETAZ * > & getTAZs() const
get vector with TAZs
GNEWalkingArea * getWalkingAreaFront() const
get front walkingArea or a pointer to nullptr
void filterBySuperMode()
filter by supermode
GNEEdge * getEdgeFront() const
get front edge or a pointer to nullptr
GNEAttributeCarrier * getAttributeCarrierFront() const
get front attribute carrier or a pointer to nullptr
void updateAdditionalElements(ViewObjectsContainer &container, const GUIGlObject *glObject)
update additional elements
void updateGenericDataElements(ViewObjectsContainer &container, const GUIGlObject *glObject)
update generic data elements
void filterDemandElements(const bool includeRoutes)
filter (remove) demand elements
void updateTAZElements(ViewObjectsContainer &container, const GUIGlObject *glObject)
update TAZ elements
const std::vector< GNEDemandElement * > & getDemandElements() const
get vector with Demand Elements
void filterWalkingAreas()
filter (remove) walkingAreas
GNETAZ * getTAZFront() const
get front TAZ or a pointer to nullptr
void filterAdditionals(const bool includeStoppigPlaces, const bool includeTAZs)
filter (remove) additionals
GNELane * getLaneFront() const
get front lane or a pointer to nullptr
void updateNetworkElements(ViewObjectsContainer &container, const GUIGlObject *glObject)
update network elements
GNEGenericData * getGenericDataElementFront() const
get generic data element or a pointer to nullptr
void fillSumoBaseObject(CommonXMLStructure::SumoBaseObject *baseObjet) const
fill the given SUMO base object with the current single objects
GNEAdditional * getAdditionalFront() const
get front additional element or a pointer to nullptr
GNELane * getLaneFrontNonLocked() const
get front lane or a pointer to nullptr checking if is locked
const GUIGlObject * getGUIGlObjectFront() const
get front GUIGLObject or a pointer to nullptr
GNENetworkElement * getNetworkElementFront() const
get front network element or a pointer to nullptr
const std::vector< GNEEdge * > & getEdges() const
get vector with edges
GNECrossing * getCrossingFront() const
get front crossing or a pointer to nullptr
ViewObjectsSelector()
default constructor
GNEJunction * getJunctionFront() const
get front junction or a pointer to nullptr
void filterLanes()
filter (remove) lanes
void filterJunctions()
filter (remove) junctions
GNETAZRelData * getTAZRelDataElementFront() const
get TAZ rel data element or a pointer to nullptr
const std::vector< GUIGlObject * > & getGLObjects() const
get vector with GL objects
void filterShapes()
filter (remove) polys and POIs
const std::vector< GNEJunction * > & getJunctions() const
get vector with junctions
GNEDemandElement * getDemandElementFront() const
get front demand element or a pointer to nullptr
void filterDataElements()
filter (remove) datga elements
const std::vector< GNELane * > & getLanes() const
get lanes
const std::vector< GNEAdditional * > & getAdditionals() const
get vector with additionals
const std::string & getMicrosimID() const
Returns the id of the object as known to microsim.
GUIGlObjectType getType() const
Returns the type of the object as coded in GUIGlObjectType.
virtual bool isGLObjectLocked() const
check if element is locked (Currently used only in netedit)
static FXIcon * getIcon(const GUIIcon which)
returns a icon previously defined in the enum GUIIcon
static GUIGlID getTexture(GUITexture which)
returns a texture previously defined in the enum GUITexture
static void drawTexturedBox(int which, double size)
Draws a named texture as a box with the given size.
int getNumberOfSelectedObjects() const
get number of selected objects
std::map< double, ObjectContainerLayer > GLObjectsSortedContainer
typedef for pack elements sorted by layer
const GLObjectsSortedContainer & getSelectedObjects() const
get all elements under cursor sorted by layer
const std::vector< const GNEJunction * > & getMergingJunctions() const
const PositionVector & getGeometry() const
Returns the geometry of the edge.
bool set(const std::string &name, const std::string &value, const bool append=false)
Sets the given value for the named option.
const StringVector & getStringVector(const std::string &name) const
Returns the list of string-value of the named option (only for Option_StringVector)
void resetWritable()
Resets all options to be writeable.
static OptionsCont & getOptions()
Retrieves the options.
C++ TraCI client API implementation.
A point in 2D or 3D with translation and scaling methods.
double x() const
Returns the x-position.
double y() const
Returns the y-position.
double nearest_offset_to_point2D(const Position &p, bool perpendicular=true) const
return the nearest offest to point 2D
static const RGBColor BLUE
static const RGBColor YELLOW
static const RGBColor MAGENTA
#define UNUSED_PARAMETER(x)
struct for processing menu commands
MFXMenuCheckIcon * menuCheckLockConnections
menu check to lock connections
MFXMenuCheckIcon * menuCheckLockPersons
menu check to lock persons
MFXMenuCheckIcon * menuCheckLockVehicles
menu check to lock vehicles
MFXMenuCheckIcon * menuCheckLockCrossings
menu check to lock crossings
MFXMenuCheckIcon * menuCheckLockRoutes
MFXMenuCheckIcon * menuCheckLockTAZs
menu check to lock TAZs
MFXMenuCheckIcon * menuCheckLockEdgeTAZRels
menu check to lock edgeTAZRels
MFXMenuCheckIcon * menuCheckLockJunctions
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 * menuCheckLockEdgeDatas
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
MFXMenuCheckIcon * menuCheckLockWalks
menu check to lock walks
MFXMenuCheckIcon * menuCheckLockJpsObstacles
menu check to lock jps obstacles
MFXMenuCheckIcon * menuCheckLockTranships
menu check to lock tranships
MFXMenuCheckIcon * menuCheckLockTransports
menu check to lock transports
DataViewOptions(GNEViewNet *viewNet)
default constructor
bool TAZRelOnlyTo() const
check if toggle TAZRel only to checkbox is enabled
void hideDataViewOptionsMenuChecks()
hide all options menu checks
bool showAdditionals() const
check if additionals has to be drawn
bool showDemandElements() const
check if show demand elements checkbox is enabled
bool TAZRelOnlyFrom() const
check if toggle TAZRel only from checkbox is enabled
bool TAZDrawFill() const
check if toggle TAZ draw fill checkbox is enabled
void buildDataViewOptionsMenuChecks()
build menu checks
void getVisibleDataMenuCommands(std::vector< MFXCheckableButton * > &commands) const
get visible demand menu commands
bool showShapes() const
check if shapes has to be drawn
bool TAZRelDrawing() const
check if toggle TAZRel drawing checkbox is enabled
void lockPerson(const GNEDemandElement *person)
lock person
bool showAllPersonPlans() const
check all person plans has to be show
void lockContainer(const GNEDemandElement *container)
lock container
void buildDemandViewOptionsMenuChecks()
build menu checks
const GNEDemandElement * getLockedPerson() const
get locked person
const GNEDemandElement * getLockedContainer() const
get locked container
bool showShapes() const
check if shapes has to be drawn
void hideDemandViewOptionsMenuChecks()
hide all options menu checks
bool showAllContainerPlans() const
check all container plans has to be show
void unlockContainer()
unlock container
void unlockPerson()
unlock person
bool drawSpreadVehicles() const
check if vehicles must be drawn spread
bool showNonInspectedDemandElements(const GNEDemandElement *demandElement) const
check if non inspected element has to be hidden
DemandViewOptions(GNEViewNet *viewNet)
default constructor
bool showOverlappedRoutes() const
show overlapped routes
void getVisibleDemandMenuCommands(std::vector< MFXCheckableButton * > &commands) const
get visible demand menu commands
bool showAllTrips() const
check if trips has to be drawn
void buildSuperModeButtons()
build checkable buttons
bool isDefaultView() const
check if default view is enabled
NetworkEditMode networkEditMode
the current Network edit mode
bool isCurrentSupermodeDemand() const
@check if current supermode is Demand
void setDemandEditMode(DemandEditMode demandMode, const bool force=false)
set Demand edit mode
bool isCurrentSupermodeData() const
@check if current supermode is Data
void setView(FXSelector sel)
set view
bool isCurrentSupermodeNetwork() const
@check if current supermode is Network
bool isJuPedSimView() const
check if default view is enabled
void setSupermode(Supermode supermode, const bool force)
set supermode
void setNetworkEditMode(NetworkEditMode networkMode, const bool force=false)
set Network edit mode
EditModes(GNEViewNet *viewNet)
constructor
void setDataEditMode(DataEditMode dataMode, const bool force=false)
set Data edit mode
GNENetworkElement * getEditedNetworkElement() const
pointer to edited network element
void stopEditCustomShape()
edit edit shape
EditNetworkElementShapes(GNEViewNet *viewNet)
default constructor
void startEditCustomShape(GNENetworkElement *element)
start edit custom shape
void commitShapeEdited()
save edited shape
static bool checkDrawing(const GUIVisualizationSettings::Detail d, const GNEAttributeCarrier *AC, GUIGlObjectType type, const double exaggeration)
check if icon can be drawn
static void drawLockIcon(const GUIVisualizationSettings::Detail d, const GNEAttributeCarrier *AC, GUIGlObjectType type, const Position position, const double exaggeration, const double size=0.5, const double offsetx=0, const double offsety=0)
draw lock icon
void moveSelection(const bool mouseLeftButtonPressed)
move selection
void calculateEdgeSelection(const GNEEdge *clickedEdge)
calculate edge selection
const GNEMoveOffset calculateMoveOffset() const
calculate move offset
bool isCurrentlyMovingMultipleElements() const
check if there are moving elements
void finishMoveSelection()
finish moving selection
double getEdgeOffset() const
edge offset
bool isMovingSelection() const
check if currently there is element being moved
void beginMoveSelection()
begin move selection
void resetMovingSelectedEdge()
reset flag for moving edge
void calculateJunctionSelection()
calculate junction selection
MoveMultipleElementModul(GNEViewNet *viewNet)
constructor
bool isMovingSelectedEdge() const
flag for moving edge
const GNEMoveOffset calculateMoveOffset() const
calculate offset
MoveSingleElementModul(GNEViewNet *viewNet)
constructor
bool beginMoveSingleElementDemandMode()
begin move single element in Demand mode
void moveSingleElement(const bool mouseLeftButtonPressed)
move single element in Network AND Demand mode
GNEMoveElement * getMovedElement() const
get moved element
bool isCurrentlyMovingSingleElement() const
check if there are moving elements
bool beginMoveSingleElementNetworkMode()
begin move single element in Network mode
bool beginMoveNetworkElementShape()
begin move network elementshape
void finishMoveSingleElement()
finish moving single elements in Network AND Demand mode
bool showConnections() const
check if select show connections checkbox is enabled
bool drawSpreadVehicles() const
check if vehicles must be drawn spread
bool editingElevation() const
check if we're editing elevation
void getVisibleNetworkMenuCommands(std::vector< MFXCheckableButton * > &commands) const
get visible network menu commands
bool showDemandElements() const
check if show demand elements checkbox is enabled
bool showSubAdditionals() const
check if show sub-additionals
bool selectEdges() const
check if select edges checkbox is enabled
bool showTAZElements() const
check if show TAZ Elements
NetworkViewOptions(GNEViewNet *viewNet)
default constructor
void hideNetworkViewOptionsMenuChecks()
hide all options menu checks
void buildNetworkViewOptionsMenuChecks()
build menu checks
~SaveElements()
destructor
SaveElements(GNEViewNet *viewNet)
default constructor
void setSaveIndividualFiles(bool value)
enable or disable save individual files
void buildSaveElementsButtons()
build save buttons
void finishRectangleSelection()
finish rectangle selection
void drawRectangleSelection(const RGBColor &color) const
draw rectangle selection
void beginRectangleSelection()
begin rectangle selection
void moveRectangleSelection()
move rectangle selection
void processBoundarySelection(const Boundary &boundary)
Process boundary Selection.
void processRectangleSelection()
process rectangle Selection
std::vector< GNEEdge * > processEdgeRectangleSelection()
process rectangle Selection (only limited to Edges)
SelectingArea(GNEViewNet *viewNet)
default constructor
void drawTestingElements(GUIMainWindow *mainWindow)
draw testing element
TestingMode(GNEViewNet *viewNet)
default constructor
void initTestingMode()
init testing mode
void buildVehicleOptionsMenuChecks()
build menu checks
VehicleOptions(GNEViewNet *viewNet)
constructor
void hideVehicleOptionsMenuChecks()
hide all options menu checks
VehicleTypeOptions(GNEViewNet *viewNet)
constructor
void buildVehicleTypeOptionsMenuChecks()
build menu checks
void hideVehicleTypeOptionsMenuChecks()
hide all options menu checks
static std::vector< RGBColor > myRainbowScaledColors
scale (rainbow) colors
static const RGBColor & getRainbowScaledColor(const double min, const double max, const double value)
get rainbow scaled color
static std::vector< GUIGlObject * > filterElementsByLayer(const std::vector< GUIGlObject * > &GLObjects)
filter elements based on the layer
static const std::vector< RGBColor > & getRainbowScaledColors()
get scaled rainbow colors