Eclipse SUMO - Simulation of Urban MObility
Loading...
Searching...
No Matches
GNEContainer.cpp
Go to the documentation of this file.
1/****************************************************************************/
2// Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo
3// Copyright (C) 2001-2024 German Aerospace Center (DLR) and others.
4// This program and the accompanying materials are made available under the
5// terms of the Eclipse Public License 2.0 which is available at
6// https://www.eclipse.org/legal/epl-2.0/
7// This Source Code may also be made available under the following Secondary
8// Licenses when the conditions for such availability set forth in the Eclipse
9// Public License 2.0 are satisfied: GNU General Public License, version 2
10// or later which is available at
11// https://www.gnu.org/licenses/old-licenses/gpl-2.0-standalone.html
12// SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-or-later
13/****************************************************************************/
18// Representation of containers in netedit
19/****************************************************************************/
21#include <netedit/GNENet.h>
22#include <netedit/GNEUndoList.h>
23#include <netedit/GNEViewNet.h>
29
30#include "GNEContainer.h"
31#include "GNERouteHandler.h"
32
33// ===========================================================================
34// FOX callback mapping
35// ===========================================================================
36
40
44
45// Object implementation
46FXIMPLEMENT(GNEContainer::GNEContainerPopupMenu, GUIGLObjectPopupMenu, containerPopupMenuMap, ARRAYNUMBER(containerPopupMenuMap))
47FXIMPLEMENT(GNEContainer::GNESelectedContainersPopupMenu, GUIGLObjectPopupMenu, selectedContainersPopupMenuMap, ARRAYNUMBER(selectedContainersPopupMenuMap))
48
49// ===========================================================================
50// GNEContainer::GNEContainerPopupMenu
51// ===========================================================================
52
54 GUIGLObjectPopupMenu(app, parent, *container),
55 myContainer(container),
56 myTransformToContainer(nullptr),
57 myTransformToContainerFlow(nullptr) {
58 // build header
59 myContainer->buildPopupHeader(this, app);
60 // build menu command for center button and copy cursor position to clipboard
61 myContainer->buildCenterPopupEntry(this);
62 myContainer->buildPositionCopyEntry(this, app);
63 // build menu commands for names
64 GUIDesigns::buildFXMenuCommand(this, ("Copy " + myContainer->getTagStr() + " name to clipboard").c_str(), nullptr, this, MID_COPY_NAME);
65 GUIDesigns::buildFXMenuCommand(this, ("Copy " + myContainer->getTagStr() + " typed name to clipboard").c_str(), nullptr, this, MID_COPY_TYPED_NAME);
66 new FXMenuSeparator(this);
67 // build selection and show parameters menu
68 myContainer->getNet()->getViewNet()->buildSelectionACPopupEntry(this, myContainer);
69 myContainer->buildShowParamsPopupEntry(this);
70 // add transform functions only in demand mode
71 if (myContainer->getNet()->getViewNet()->getEditModes().isCurrentSupermodeDemand()) {
72 // create menu pane for transform operations
73 FXMenuPane* transformOperation = new FXMenuPane(this);
74 this->insertMenuPaneChild(transformOperation);
75 new FXMenuCascade(this, "transform to", nullptr, transformOperation);
76 // Create menu comands for all transformations
77 myTransformToContainer = GUIDesigns::buildFXMenuCommand(transformOperation, "Container", GUIIconSubSys::getIcon(GUIIcon::CONTAINER), this, MID_GNE_CONTAINER_TRANSFORM);
78 myTransformToContainerFlow = GUIDesigns::buildFXMenuCommand(transformOperation, "ContainerFlow", GUIIconSubSys::getIcon(GUIIcon::CONTAINERFLOW), this, MID_GNE_CONTAINER_TRANSFORM);
79 // check what menu command has to be disabled
80 if (myContainer->getTagProperty().getTag() == SUMO_TAG_CONTAINER) {
81 myTransformToContainer->disable();
82 } else if (myContainer->getTagProperty().getTag() == SUMO_TAG_CONTAINERFLOW) {
83 myTransformToContainerFlow->disable();
84 }
85 }
86}
87
88
90
91
92long
93GNEContainer::GNEContainerPopupMenu::onCmdTransform(FXObject* obj, FXSelector, void*) {
94 if (obj == myTransformToContainer) {
96 } else if (obj == myTransformToContainerFlow) {
98 }
99 return 1;
100}
101
102
103// ===========================================================================
104// GNEContainer::GNESelectedContainersPopupMenu
105// ===========================================================================
106
107GNEContainer::GNESelectedContainersPopupMenu::GNESelectedContainersPopupMenu(GNEContainer* container, const std::vector<GNEContainer*>& selectedContainer, GUIMainWindow& app, GUISUMOAbstractView& parent) :
108 GUIGLObjectPopupMenu(app, parent, *container),
109 myContainerTag(container->getTagProperty().getTag()),
110 mySelectedContainers(selectedContainer),
111 myTransformToContainer(nullptr),
112 myTransformToContainerFlow(nullptr) {
113 // build header
114 container->buildPopupHeader(this, app);
115 // build menu command for center button and copy cursor position to clipboard
116 container->buildCenterPopupEntry(this);
117 container->buildPositionCopyEntry(this, app);
118 // build menu commands for names
119 GUIDesigns::buildFXMenuCommand(this, ("Copy " + container->getTagStr() + " name to clipboard").c_str(), nullptr, this, MID_COPY_NAME);
120 GUIDesigns::buildFXMenuCommand(this, ("Copy " + container->getTagStr() + " typed name to clipboard").c_str(), nullptr, this, MID_COPY_TYPED_NAME);
121 new FXMenuSeparator(this);
122 // build selection and show parameters menu
123 container->getNet()->getViewNet()->buildSelectionACPopupEntry(this, container);
124 container->buildShowParamsPopupEntry(this);
125 // add transform functions only in demand mode
126 if (container->getNet()->getViewNet()->getEditModes().isCurrentSupermodeDemand()) {
127 // create menu pane for transform operations
128 FXMenuPane* transformOperation = new FXMenuPane(this);
129 this->insertMenuPaneChild(transformOperation);
130 new FXMenuCascade(this, "transform to", nullptr, transformOperation);
131 // Create menu comands for all transformations
134 }
135}
136
137
139
140
141long
143 // iterate over all selected containers
144 for (const auto& container : mySelectedContainers) {
145 if ((obj == myTransformToContainer) &&
146 (container->getTagProperty().getTag() == myContainerTag)) {
148 } else if ((obj == myTransformToContainerFlow) &&
149 (container->getTagProperty().getTag() == myContainerTag)) {
151 }
152 }
153 return 1;
154}
155
156// ===========================================================================
157// member method definitions
158// ===========================================================================
159
162 GNEPathElement::Options::DEMAND_ELEMENT, {}, {}, {}, {}, {}, {}),
164 // reset default values
166 // set end and container per hours as default flow values
169}
170
171
173 GNEDemandElement(containerparameters.id, net, (tag == SUMO_TAG_CONTAINERFLOW) ? GLO_CONTAINERFLOW : GLO_CONTAINER, tag,
175 GNEPathElement::Options::DEMAND_ELEMENT, {}, {}, {}, {}, {pType}, {}),
176GNEDemandElementFlow(this, containerparameters) {
177 // set manually vtypeID (needed for saving)
178 vtypeid = pType->getID();
179}
180
181
183
184
187 const auto firstContainerPlan = getChildDemandElements().front();
188 // check first container plan
189 if (firstContainerPlan->getTagProperty().isPlanStopContainer()) {
190 return nullptr;
191 } else if (firstContainerPlan->getParentEdges().size() > 0) {
192 // get lane
193 const GNELane* lane = firstContainerPlan->getParentEdges().front()->getLaneByAllowedVClass(getVClass());
194 // declare departPos
195 double posOverLane = 0;
196 if (canParse<double>(getDepartPos())) {
197 posOverLane = parse<double>(getDepartPos());
198 }
199 // return move operation
200 return new GNEMoveOperation(this, lane, posOverLane, false);
201 } else {
202 return nullptr;
203 }
204}
205
206
207void
209 // attribute VType musn't be written if is DEFAULT_PEDTYPE_ID
211 // unset VType parameter
212 parametersSet &= ~VEHPARS_VTYPE_SET;
213 // write container attributes (VType will not be written)
215 // set VType parameter again
217 } else {
218 // write container attributes, including VType
220 }
221 // write flow attributes
222 writeFlowAttributes(this, device);
223 // write parameters
224 writeParams(device);
225 // write child demand elements associated to this container (Rides, Walks...)
226 for (const auto& containerPlan : getChildDemandElements()) {
227 containerPlan->writeDemandElement(device);
228 }
229 // close container tag
230 device.closeTag();
231}
232
233
236 if (getChildDemandElements().size() == 0) {
237 return Problem::NO_PLANS;
238 } else {
239 return Problem::OK;
240 }
241}
242
243
244std::string
246 if (getChildDemandElements().size() == 0) {
247 return "Container needs at least one plan";
248 } else {
249 return "";
250 }
251}
252
253
254void
256 // nothing to fix
257}
258
259
262 return getParentDemandElements().front()->getVClass();
263}
264
265
266const RGBColor&
268 return color;
269}
270
271
272void
274 // only update geometry of childrens
275 for (const auto& demandElement : getChildDemandElements()) {
276 demandElement->updateGeometry();
277 }
278}
279
280
285
286
289 // return a GNEContainerPopupMenu
290 return new GNEContainerPopupMenu(this, app, parent);
291}
292
293
294std::string
296 return getParentDemandElements().front()->getID();
297}
298
299
300double
304
305
308 Boundary containerBoundary;
309 if (getChildDemandElements().size() > 0) {
310 if (getChildDemandElements().front()->getTagProperty().isPlanStopContainer()) {
311 // use boundary of stop center
312 return getChildDemandElements().front()->getCenteringBoundary();
313 } else {
314 containerBoundary.add(getPositionInView());
315 }
316 } else {
317 containerBoundary = Boundary(-0.1, -0.1, 0.1, 0.1);
318 }
319 containerBoundary.grow(20);
320 return containerBoundary;
321}
322
323
324void
325GNEContainer::splitEdgeGeometry(const double /*splitPosition*/, const GNENetworkElement* /*originalElement*/, const GNENetworkElement* /*newElement*/, GNEUndoList* /*undoList*/) {
326 // geometry of this element cannot be splitted
327}
328
329
330void
332 bool drawContainer = true;
333 // check if container can be drawn
335 drawContainer = false;
337 drawContainer = false;
339 drawContainer = false;
340 } else if (getChildDemandElements().empty()) {
341 drawContainer = false;
342 }
343 // continue if container can be drawn
344 if (drawContainer) {
345 // obtain exaggeration (and add the special containerExaggeration)
346 const double exaggeration = getExaggeration(s) + 10;
347 // get detail level
348 const auto d = s.getDetailLevel(exaggeration);
349 // obtain position
350 const Position containerPosition = getAttributePosition(SUMO_ATTR_DEPARTPOS);
351 if (containerPosition == Position::INVALID) {
352 return;
353 }
354 // draw geometry only if we'rent in drawForObjectUnderCursor mode
356 // obtain img file
357 const std::string file = getTypeParent()->getAttribute(SUMO_ATTR_IMGFILE);
358 // push draw matrix
360 // Start with the drawing of the area traslating matrix to origin
362 // translate and rotate
363 glTranslated(containerPosition.x(), containerPosition.y(), 0);
364 glRotated(90, 0, 0, 1);
365 // set container color
367 // set scale
368 glScaled(exaggeration, exaggeration, 1);
369 // draw container depending of detail level
370 switch (s.containerQuality) {
371 case 0:
372 case 1:
373 case 2:
375 break;
376 case 3:
377 default:
379 break;
380 }
381 // pop matrix
383 // draw line between junctions if container plan isn't valid
384 for (const auto& containerPlan : getChildDemandElements()) {
385 if (containerPlan->getTagProperty().isPlanContainer() && (containerPlan->getParentJunctions().size() > 0) && !myNet->getDemandPathManager()->isPathValid(containerPlan)) {
386 drawJunctionLine(containerPlan);
387 }
388 }
389 // draw stack label
390 if (myStackedLabelNumber > 0) {
391 drawStackLabel(myStackedLabelNumber, "container", Position(containerPosition.x() - 2.5, containerPosition.y() - 0.8), -90, 1.3, 5, getExaggeration(s));
393 // declare counter for stacked containers over stops
394 int stackedCounter = 0;
395 // get stoppingPlace
396 const auto stoppingPlace = getChildDemandElements().front()->getParentAdditionals().front();
397 // get stacked containers
398 for (const auto& stopContainer : stoppingPlace->getChildDemandElements()) {
399 if (stopContainer->getTagProperty().getTag() == GNE_TAG_STOPCONTAINER_CONTAINERSTOP) {
400 // get container parent
401 const auto containerParent = stopContainer->getParentDemandElements().front();
402 // check if the stop if the first container plan parent
403 if (stopContainer->getPreviousChildDemandElement(containerParent) == nullptr) {
404 stackedCounter++;
405 }
406 }
407 }
408 // if we have more than two stacked elements, draw label
409 if (stackedCounter > 1) {
410 drawStackLabel(stackedCounter, "container", Position(containerPosition.x() - 2.5, containerPosition.y() - 0.8), -90, 1.3, 5, getExaggeration(s));
411 }
412 }
413 // draw flow label
414 if (myTagProperty.isFlow()) {
415 drawFlowLabel(Position(containerPosition.x() - 1, containerPosition.y() - 4.25), -90, 1.8, 2, getExaggeration(s));
416 }
417 // draw name
418 drawName(containerPosition, s.scale, s.containerName, s.angle);
419 // draw lock icon
421 // draw dotted contour
423 }
424 // calculate contour
425 myContainerContour.calculateContourRectangleShape(s, d, this, containerPosition, 0.5, 0.18, getType(), -5.5, 0, 0, exaggeration);
426 }
427}
428
429
430void
432 // compute all container plan children (because aren't computed in "computeDemandElements()")
433 for (const auto& demandElement : getChildDemandElements()) {
434 demandElement->computePathElement();
435 }
436}
437
438
439void
440GNEContainer::drawLanePartialGL(const GUIVisualizationSettings& /*s*/, const GNESegment* /*segment*/, const double /*offsetFront*/) const {
441 // Stops don't use drawJunctionPartialGL
442}
443
444
445void
446GNEContainer::drawJunctionPartialGL(const GUIVisualizationSettings& /*s*/, const GNESegment* /*segment*/, const double /*offsetFront*/) const {
447 // Stops don't use drawJunctionPartialGL
448}
449
450
451GNELane*
453 // use path lane of first container plan
454 return getChildDemandElements().front()->getFirstPathLane();
455}
456
457
458GNELane*
460 // use path lane of first container plan
461 return getChildDemandElements().front()->getLastPathLane();
462}
463
464
465std::string
467 // declare string error
468 std::string error;
469 switch (key) {
470 case SUMO_ATTR_ID:
471 return getMicrosimID();
472 case SUMO_ATTR_TYPE:
473 return getTypeParent()->getID();
474 case SUMO_ATTR_COLOR:
476 return toString(color);
477 } else {
479 }
482 return getDepartPos();
483 } else {
485 }
486 // Other
490 return getParametersStr();
491 default:
492 return getFlowAttribute(key);
493 }
494}
495
496
497double
499 switch (key) {
502 return departPos;
503 } else {
504 return 0;
505 }
506 default:
507 return getFlowAttributeDouble(key);
508 }
509}
510
511
514 switch (key) {
515 case SUMO_ATTR_DEPARTPOS: {
516 // first check number of child demand elements
517 if (getChildDemandElements().empty()) {
518 return Position();
519 }
520 // get container plan
521 const GNEDemandElement* containerPlan = getChildDemandElements().front();
522 // first check if first container plan is a stop
523 if (containerPlan->getTagProperty().isPlanStopContainer()) {
524 // stop center
525 return containerPlan->getPositionInView();
526 } else if (containerPlan->getTagProperty().planFromTAZ()) {
527 // TAZ
528 if (containerPlan->getParentAdditionals().front()->getAttribute(SUMO_ATTR_CENTER).empty()) {
529 return containerPlan->getParentAdditionals().front()->getAttributePosition(GNE_ATTR_TAZ_CENTROID);
530 } else {
531 return containerPlan->getParentAdditionals().front()->getAttributePosition(SUMO_ATTR_CENTER);
532 }
533 } else if (containerPlan->getTagProperty().planFromJunction()) {
534 // juncrtion
535 return containerPlan->getParentJunctions().front()->getPositionInView();
536 } else {
538 }
539 }
540 default:
541 throw InvalidArgument(getTagStr() + " doesn't have a Position attribute of type '" + toString(key) + "'");
542 }
543}
544
545
546void
547GNEContainer::setAttribute(SumoXMLAttr key, const std::string& value, GNEUndoList* undoList) {
548 switch (key) {
549 case SUMO_ATTR_ID:
550 case SUMO_ATTR_TYPE:
551 case SUMO_ATTR_COLOR:
553 // Other
556 GNEChange_Attribute::changeAttribute(this, key, value, undoList);
557 break;
558 default:
559 setFlowAttribute(this, key, value, undoList);
560 break;
561 }
562}
563
564
565bool
566GNEContainer::isValid(SumoXMLAttr key, const std::string& value) {
567 // declare string error
568 std::string error;
569 switch (key) {
570 case SUMO_ATTR_ID:
572 case SUMO_ATTR_TYPE:
573 return (myNet->getAttributeCarriers()->retrieveDemandElements(NamespaceIDs::types, value, false) != nullptr);
574 case SUMO_ATTR_COLOR:
575 return canParse<RGBColor>(value);
576 case SUMO_ATTR_DEPARTPOS: {
577 double dummyDepartPos;
578 DepartPosDefinition dummyDepartPosProcedure;
579 parseDepartPos(value, myTagProperty.getTagStr(), id, dummyDepartPos, dummyDepartPosProcedure, error);
580 // if error is empty, given value is valid
581 return error.empty();
582 }
583 // Other
585 return canParse<bool>(value);
588 default:
589 return isValidFlowAttribute(this, key, value);
590 }
591}
592
593
594void
596 enableFlowAttribute(this, key, undoList);
597}
598
599
600void
602 disableFlowAttribute(this, key, undoList);
603}
604
605
606bool
610
611
612std::string
614 return getTagStr();
615}
616
617
618std::string
620 const auto& inspectedElements = myNet->getViewNet()->getInspectedElements();
621 // special case for Trips and flow
623 // check if we're inspecting an Edge
624 if (inspectedElements.getFirstAC() && (inspectedElements.getFirstAC()->getTagProperty().getTag() == SUMO_TAG_EDGE)) {
625 // check if edge correspond to a "from", "to" or "via" edge
626 if (inspectedElements.isACInspected(getParentEdges().front())) {
627 return getTagStr() + ": " + getAttribute(SUMO_ATTR_ID) + " (from)";
628 } else if (inspectedElements.isACInspected(getParentEdges().front())) {
629 return getTagStr() + ": " + getAttribute(SUMO_ATTR_ID) + " (to)";
630 } else {
631 // iterate over via
632 for (const auto& viaEdgeID : via) {
633 if (viaEdgeID == inspectedElements.getFirstAC()->getID()) {
634 return getTagStr() + ": " + getAttribute(SUMO_ATTR_ID) + " (via)";
635 }
636 }
637 }
638 }
639 }
640 return getTagStr() + ": " + getAttribute(SUMO_ATTR_ID);
641}
642
643
648
649// ===========================================================================
650// protected
651// ===========================================================================
652
655 // change color
656 if (drawUsingSelectColor()) {
658 } else {
659 return getColorByScheme(s.containerColorer, this);
660 }
661}
662
663
664void
666 // obtain width and length
667 const double length = getTypeParent()->getAttributeDouble(SUMO_ATTR_LENGTH);
668 const double width = getTypeParent()->getAttributeDouble(SUMO_ATTR_WIDTH);
669 // draw pedestrian shape
670 glScaled(length * 0.2, width * 0.2, 1);
671 glBegin(GL_QUADS);
672 glVertex2d(0, 0.5);
673 glVertex2d(0, -0.5);
674 glVertex2d(-1, -0.5);
675 glVertex2d(-1, 0.5);
676 glEnd();
677 GLHelper::setColor(GLHelper::getColor().changedBrightness(-30));
678 glTranslated(0, 0, .045);
679 glBegin(GL_QUADS);
680 glVertex2d(-0.1, 0.4);
681 glVertex2d(-0.1, -0.4);
682 glVertex2d(-0.9, -0.4);
683 glVertex2d(-0.9, 0.4);
684 glEnd();
685}
686
687
688void
690 const std::string& file = getTypeParent()->getAttribute(SUMO_ATTR_IMGFILE);
691 // obtain width and length
692 const double length = getTypeParent()->getAttributeDouble(SUMO_ATTR_LENGTH);
693 const double width = getTypeParent()->getAttributeDouble(SUMO_ATTR_WIDTH);
694 if (file != "") {
695 // @todo invent an option for controlling whether images should be rotated or not
696 //if (getVehicleType().getGuiShape() == SVS_CONTAINER) {
697 // glRotated(RAD2DEG(getAngle() + M_PI / 2.), 0, 0, 1);
698 //}
699 int textureID = GUITexturesHelper::getTextureID(file);
700 if (textureID > 0) {
701 const double exaggeration = s.containerSize.getExaggeration(s, this);
702 const double halfLength = length / 2.0 * exaggeration;
703 const double halfWidth = width / 2.0 * exaggeration;
704 GUITexturesHelper::drawTexturedBox(textureID, -halfWidth, -halfLength, halfWidth, halfLength);
705 }
706 } else {
707 // fallback if no image is defined
709 }
710}
711
712// ===========================================================================
713// private
714// ===========================================================================
715
717 containerPlan(_containerPlan),
718 edge(nullptr),
719 arrivalPos(-1) {
720}
721
722
724 containerPlan(nullptr),
725 edge(nullptr),
726 arrivalPos(-1) {
727}
728
729
730void
731GNEContainer::setAttribute(SumoXMLAttr key, const std::string& value) {
732 // declare string error
733 std::string error;
734 switch (key) {
735 case SUMO_ATTR_ID:
736 // update microsimID
737 setDemandElementID(value);
738 // update id
739 id = value;
740 break;
741 case SUMO_ATTR_TYPE:
742 if (getID().size() > 0) {
744 // set manually vtypeID (needed for saving)
745 vtypeid = value;
746 }
747 break;
748 case SUMO_ATTR_COLOR:
749 if (!value.empty() && (value != myTagProperty.getDefaultValue(key))) {
750 color = parse<RGBColor>(value);
751 // mark parameter as set
753 } else {
754 // set default value
755 color = parse<RGBColor>(myTagProperty.getDefaultValue(key));
756 // unset parameter
757 parametersSet &= ~VEHPARS_COLOR_SET;
758 }
759 break;
761 if (!value.empty() && (value != myTagProperty.getDefaultValue(key))) {
763 // mark parameter as set
765 } else {
766 // set default value
768 // unset parameter
769 parametersSet &= ~VEHPARS_DEPARTPOS_SET;
770 }
771 // compute container
773 break;
774 // Others
776 if (parse<bool>(value)) {
778 } else {
780 }
781 break;
783 setParametersStr(value);
784 break;
785 default:
786 setFlowAttribute(this, key, value);
787 break;
788 }
789}
790
791
792void
794 // toggle flow attributes
795 toggleFlowAttribute(key, value);
796}
797
798
799void
801 // change departPos
803 departPos = moveResult.newFirstPos;
804 // update geometry
806}
807
808
809void
811 undoList->begin(this, "departPos of " + getTagStr());
812 // now set departPos
814 undoList->end();
815}
816
817/****************************************************************************/
FXDEFMAP(GNEContainer::GNEContainerPopupMenu) containerPopupMenuMap[]
@ MID_GNE_CONTAINER_TRANSFORM
transform container to another container type (ej: container to containerflow)
@ MID_COPY_TYPED_NAME
Copy typed object name - popup entry.
Definition GUIAppEnum.h:455
@ MID_COPY_NAME
Copy object name - popup entry.
Definition GUIAppEnum.h:453
@ GLO_CONTAINER
a container
@ GLO_CONTAINERFLOW
a person flow
GUIIcon
An enumeration of icons used by the gui applications.
Definition GUIIcons.h:33
@ CONTAINERFLOW
const std::string DEFAULT_CONTAINERTYPE_ID
SUMOVehicleClass
Definition of vehicle classes to differ between different lane usage and authority types.
DepartPosDefinition
Possible ways to choose the departure position.
@ GIVEN
The position is given.
const long long int VEHPARS_COLOR_SET
const long long int VEHPARS_DEPARTPOS_SET
const long long int VEHPARS_VTYPE_SET
SumoXMLTag
Numbers representing SUMO-XML - element names.
@ SUMO_TAG_VTYPE
description of a vehicle/person/container type
@ SUMO_TAG_CONTAINERFLOW
@ GNE_TAG_STOPCONTAINER_CONTAINERSTOP
@ SUMO_TAG_FLOW
a flow definition using from and to edges or a route
@ SUMO_TAG_CONTAINER
@ SUMO_TAG_TRIP
a single trip definition (used by router)
@ SUMO_TAG_EDGE
begin/end of the description of an edge
SumoXMLAttr
Numbers representing SUMO-XML - attributes.
@ GNE_ATTR_PLAN_GEOMETRY_STARTPOS
person/container geometry start position
@ GNE_ATTR_SELECTED
element is selected
@ GNE_ATTR_TAZ_CENTROID
TAZ Center (uses to return the TAZ centroid if center is not defined)
@ GNE_ATTR_PARAMETERS
parameters "key1=value1|key2=value2|...|keyN=valueN"
@ SUMO_ATTR_CONTAINERSPERHOUR
@ SUMO_ATTR_DEPARTPOS
@ SUMO_ATTR_CENTER
@ SUMO_ATTR_END
weights: time range end
@ SUMO_ATTR_TYPE
@ SUMO_ATTR_LENGTH
@ SUMO_ATTR_COLOR
A color information.
@ SUMO_ATTR_ID
@ SUMO_ATTR_IMGFILE
@ SUMO_ATTR_WIDTH
std::string toString(const T &t, std::streamsize accuracy=gPrecision)
Definition ToString.h:46
A class that stores a 2D geometrical boundary.
Definition Boundary.h:39
void add(double x, double y, double z=0)
Makes the boundary include the given coordinate.
Definition Boundary.cpp:78
Boundary & grow(double by)
extends the boundary by the given amount
Definition Boundary.cpp:343
static void setColor(const RGBColor &c)
Sets the gl-color to this value.
Definition GLHelper.cpp:654
static void popMatrix()
pop matrix
Definition GLHelper.cpp:130
static RGBColor getColor()
gets the gl-color
Definition GLHelper.cpp:660
static void pushMatrix()
push matrix
Definition GLHelper.cpp:117
const std::string getID() const
get ID (all Attribute Carriers have one)
bool isAttributeCarrierSelected() const
check if attribute carrier is selected
const std::string & getTagStr() const
get tag assigned to this object in string format
const GNETagProperties & getTagProperty() const
get tagProperty associated with this Attribute Carrier
void unselectAttributeCarrier(const bool changeFlag=true)
unselect attribute carrier using GUIGlobalSelection
bool drawUsingSelectColor() const
check if attribute carrier must be drawn using selecting color.
void resetDefaultValues()
reset attribute carrier to their default values
GNENet * myNet
pointer to net
GNENet * getNet() const
get pointer to net
void selectAttributeCarrier(const bool changeFlag=true)
select attribute carrier using GUIGlobalSelection
const GNETagProperties & myTagProperty
reference to tagProperty associated with this attribute carrier
static void changeAttribute(GNEAttributeCarrier *AC, SumoXMLAttr key, const std::string &value, GNEUndoList *undoList, const bool force=false)
change attribute
class used in GUIGLObjectPopupMenu for container transformations
long onCmdTransform(FXObject *obj, FXSelector, void *)
Called to transform the current container to another container type.
class used in GUIGLObjectPopupMenu for single container transformations
long onCmdTransform(FXObject *obj, FXSelector, void *)
Called to transform the current container to another container type.
GNESelectedContainersPopupMenu(GNEContainer *container, const std::vector< GNEContainer * > &selectedContainer, GUIMainWindow &app, GUISUMOAbstractView &parent)
Constructor.
FXMenuCommand * myTransformToContainer
menu command for transform to container
FXMenuCommand * myTransformToContainerFlow
menu command for transform to containerFlow
Position getPositionInView() const
Returns position of demand element in view.
std::string getAttribute(SumoXMLAttr key) const
inherited from GNEAttributeCarrier
GNELane * getLastPathLane() const
get last path lane
void updateGeometry()
update pre-computed geometry information
Position getAttributePosition(SumoXMLAttr key) const
Problem isDemandElementValid() const
check if current demand element is valid to be written into XML (by default true, can be reimplemente...
bool isValid(SumoXMLAttr key, const std::string &value)
method for checking if the key and their conrrespond attribute are valids
const RGBColor & getColor() const
get color
GNEContainer(SumoXMLTag tag, GNENet *net)
default constructor
void toggleAttribute(SumoXMLAttr key, const bool value)
method for enable or disable the attribute and nothing else (used in GNEChange_ToggleAttribute)
Boundary getCenteringBoundary() const
Returns the boundary to which the view shall be centered in order to show the object.
GUIGLObjectPopupMenu * getPopUpMenu(GUIMainWindow &app, GUISUMOAbstractView &parent)
Returns an own popup-menu.
void splitEdgeGeometry(const double splitPosition, const GNENetworkElement *originalElement, const GNENetworkElement *newElement, GNEUndoList *undoList)
split geometry
void drawAction_drawAsPoly() const
draw container as poly
std::string getPopUpID() const
get PopPup ID (Used in AC Hierarchy)
void commitMoveShape(const GNEMoveResult &moveResult, GNEUndoList *undoList)
commit move shape
void drawJunctionPartialGL(const GUIVisualizationSettings &s, const GNESegment *segment, const double offsetFront) const
Draws partial object over junction.
void writeDemandElement(OutputDevice &device) const
write demand element element into a xml file
void computePathElement()
compute pathElement
void drawAction_drawAsImage(const GUIVisualizationSettings &s) const
draw container as image
void disableAttribute(SumoXMLAttr key, GNEUndoList *undoList)
~GNEContainer()
destructor
std::string getDemandElementProblem() const
return a string with the current demand element problem (by default empty, can be reimplemented in ch...
std::string getParentName() const
Returns the name of the parent object.
std::string getHierarchyName() const
get Hierarchy Name (Used in AC Hierarchy)
RGBColor getDrawingColor(const GUIVisualizationSettings &s) const
get drawing color
void enableAttribute(SumoXMLAttr key, GNEUndoList *undoList)
double getExaggeration(const GUIVisualizationSettings &s) const
return exaggeration associated with this GLObject
SUMOVehicleClass getVClass() const
obtain VClass related with this demand element
GNEMoveOperation * getMoveOperation()
get move operation
double getAttributeDouble(SumoXMLAttr key) const
bool isAttributeEnabled(SumoXMLAttr key) const
void setMoveShape(const GNEMoveResult &moveResult)
set move shape
void drawGL(const GUIVisualizationSettings &s) const
Draws the object.
GNEContour myContainerContour
variable used for contours
GNELane * getFirstPathLane() const
get first path lane
void drawLanePartialGL(const GUIVisualizationSettings &s, const GNESegment *segment, const double offsetFront) const
Draws partial object over lane.
const Parameterised::Map & getACParametersMap() const
get parameters map
void setAttribute(SumoXMLAttr key, const std::string &value, GNEUndoList *undoList)
method for setting the attribute and letting the object perform demand element changes
void fixDemandElementProblem()
fix demand element problem (by default throw an exception, has to be reimplemented in children)
void calculateContourRectangleShape(const GUIVisualizationSettings &s, const GUIVisualizationSettings::Detail d, const GUIGlObject *glObject, const Position &pos, const double width, const double height, const double layer, const double offsetX, const double offsetY, const double rot, const double scale) const
calculate contour (for rectangled elements)
void drawDottedContours(const GUIVisualizationSettings &s, const GUIVisualizationSettings::Detail d, const GNEAttributeCarrier *AC, const double lineWidth, const bool addOffset) const
draw dotted contours (basics, select, delete, inspect...)
void toggleFlowAttribute(const SumoXMLAttr attribute, const bool value)
toggle flow parameters (used in toggleAttribute(...) function of vehicles, persons and containers
void drawFlowLabel(const Position &position, const double rotation, const double width, const double length, const double exaggeration) const
draw flow label
void disableFlowAttribute(GNEDemandElement *flowElement, SumoXMLAttr key, GNEUndoList *undoList)
bool isFlowAttributeEnabled(SumoXMLAttr key) const
double getFlowAttributeDouble(SumoXMLAttr key) const
bool isValidFlowAttribute(GNEDemandElement *flowElement, SumoXMLAttr key, const std::string &value)
void writeFlowAttributes(const GNEDemandElement *flowElement, OutputDevice &device) const
write flow attributes
void enableFlowAttribute(GNEDemandElement *flowElement, SumoXMLAttr key, GNEUndoList *undoList)
std::string getFlowAttribute(SumoXMLAttr key) const
inherited from GNEAttributeCarrier and adapted to GNEDemandElementFlow
void setFlowAttribute(GNEDemandElement *flowElement, SumoXMLAttr key, const std::string &value, GNEUndoList *undoList)
void replaceDemandElementParent(SumoXMLTag tag, const std::string &value, const int parentIndex)
replace demand element parent
void drawStackLabel(const int number, const std::string &element, const Position &position, const double rotation, const double width, const double length, const double exaggeration) const
draw stack label
virtual double getAttributeDouble(SumoXMLAttr key) const =0
bool isValidDemandElementID(const std::string &value) const
check if a new demand element ID is valid
void drawJunctionLine(const GNEDemandElement *element) const
draw line between junctions
virtual std::string getAttribute(SumoXMLAttr key) const =0
void setDemandElementID(const std::string &newID)
set demand element id
GNEDemandElement * getTypeParent() const
get type parent (needed because first parent can be either type or typeDistribution)
int myStackedLabelNumber
stacked label number
virtual Position getPositionInView() const =0
Returns position of demand element in view.
RGBColor getColorByScheme(const GUIColorer &c, const SUMOVehicleParameter *parameters) const
get color by scheme (used by vehicles, persons and containers)
Problem
enum class for demandElement problems
virtual Position getAttributePosition(SumoXMLAttr key) const =0
const std::vector< GNEJunction * > & getParentJunctions() const
get parent junctions
const std::vector< GNEDemandElement * > & getChildDemandElements() const
return child demand elements
const std::vector< GNEDemandElement * > & getParentDemandElements() const
get parent demand elements
const std::vector< GNEAdditional * > & getParentAdditionals() const
get parent additionals
const std::vector< GNEEdge * > & getParentEdges() const
get parent edges
This lane is powered by an underlying GNEEdge and basically knows how to draw itself.
Definition GNELane.h:46
move operation
move result
double newFirstPos
new first position
GNEDemandElement * retrieveDemandElements(const std::vector< SumoXMLTag > types, const std::string &id, bool hardFail=true) const
Returns the named demand element.
A NBNetBuilder extended by visualisation and editing capabilities.
Definition GNENet.h:42
GNEPathManager * getDemandPathManager()
get demand path manager
Definition GNENet.cpp:145
GNENetHelper::AttributeCarriers * getAttributeCarriers() const
get all attribute carriers used in this net
Definition GNENet.cpp:127
GNEViewNet * getViewNet() const
get view net
Definition GNENet.cpp:2155
bool isPathValid(const GNEPathElement *pathElement) const
check if path element is valid
static void transformToContainerFlow(GNEContainer *originalContainer)
transform routeFlow over an existent route
static void transformToContainer(GNEContainer *originalContainer)
transform container functions
bool planFromJunction() const
return true if tag correspond to a plan that starts in junction
bool isFlow() const
return true if tag correspond to a flow element
const std::string & getTagStr() const
get Tag vinculated with this attribute Property in String Format (used to avoid multiple calls to toS...
bool isPlanStopContainer() const
return true if tag correspond to a container stop plan
SumoXMLTag getTag() const
get Tag vinculated with this attribute Property
bool planFromTAZ() const
return true if tag correspond to a plan that starts in TAZ
const std::string & getDefaultValue(SumoXMLAttr attr) const
return the default value of the attribute of an element
SumoXMLTag getXMLTag() const
get XML tag
void end()
End undo command sub-group. If the sub-group is still empty, it will be deleted; otherwise,...
void begin(GUIIcon icon, const std::string &description)
Begin undo command sub-group with current supermode. This begins a new group of commands that are tre...
const GNEViewNetHelper::DataViewOptions & getDataViewOptions() const
get data view options
const GNEViewNetHelper::EditModes & getEditModes() const
get edit modes
GNEViewNetHelper::InspectedElements & getInspectedElements()
get inspected elements
const GNEViewNetHelper::NetworkViewOptions & getNetworkViewOptions() const
get network view options
void drawTranslateFrontAttributeCarrier(const GNEAttributeCarrier *AC, double typeOrLayer, const double extraOffset=0)
draw front attributeCarrier
void buildSelectionACPopupEntry(GUIGLObjectPopupMenu *ret, GNEAttributeCarrier *AC)
Builds an entry which allows to (de)select the object.
const GNEViewNetHelper::DemandViewOptions & getDemandViewOptions() const
get demand view options
static FXMenuCommand * buildFXMenuCommand(FXComposite *p, const std::string &text, FXIcon *icon, FXObject *tgt, FXSelector sel, const bool disable=false)
build menu command
The popup menu of a globject.
void insertMenuPaneChild(FXMenuPane *child)
Insert a sub-menu pane in this GUIGLObjectPopupMenu.
const std::string & getMicrosimID() const
Returns the id of the object as known to microsim.
void buildShowParamsPopupEntry(GUIGLObjectPopupMenu *ret, bool addSeparator=true)
Builds an entry which allows to open the parameter window.
void buildCenterPopupEntry(GUIGLObjectPopupMenu *ret, bool addSeparator=true)
Builds an entry which allows to center to the object.
void buildPopupHeader(GUIGLObjectPopupMenu *ret, GUIMainWindow &app, bool addSeparator=true)
Builds the header.
GUIGlObjectType getType() const
Returns the type of the object as coded in GUIGlObjectType.
void buildPositionCopyEntry(GUIGLObjectPopupMenu *ret, const GUIMainWindow &app) const
Builds an entry which allows to copy the cursor position if geo projection is used,...
void drawName(const Position &pos, const double scale, const GUIVisualizationTextSettings &settings, const double angle=0, bool forceShow=false) const
draw name of item
static FXIcon * getIcon(const GUIIcon which)
returns a icon previously defined in the enum GUIIcon
static void drawTexturedBox(int which, double size)
Draws a named texture as a box with the given size.
static int getTextureID(const std::string &filename, const bool mirrorX=false)
return texture id for the given filename (initialize on first use)
Stores the information about how to visualize structures.
GUIVisualizationSizeSettings containerSize
int containerQuality
The quality of container drawing.
Detail getDetailLevel(const double exaggeration) const
return the detail level
GUIVisualizationColorSettings colorSettings
color settings
bool checkDrawContainer(Detail d, const bool selected) const
check if draw container
GUIVisualizationDottedContourSettings dottedContourSettings
dotted contour settings
double scale
information about a lane's width (temporary, used for a single view)
GUIVisualizationTextSettings containerName
GUIColorer containerColorer
The container colorer.
double angle
The current view rotation angle.
static const std::vector< SumoXMLTag > types
type namespace
static const std::vector< SumoXMLTag > containers
containers namespace
static OptionsCont & getOptions()
Retrieves the options.
Static storage of an output device and its base (abstract) implementation.
bool closeTag(const std::string &comment="")
Closes the most recently opened tag and optionally adds a comment.
static bool areParametersValid(const std::string &value, bool report=false, const std::string kvsep="=", const std::string sep="|")
check if given string can be parsed to a parameters map "key1=value1|key2=value2|....
std::map< std::string, std::string > Map
parameters map
void setParametersStr(const std::string &paramsString, const std::string kvsep="=", const std::string sep="|")
set the inner key/value map in string format "key1=value1|key2=value2|...|keyN=valueN"
const Parameterised::Map & getParametersMap() const
Returns the inner key/value map.
void writeParams(OutputDevice &device) const
write Params in the given outputdevice
std::string getParametersStr(const std::string kvsep="=", const std::string sep="|") const
Returns the inner key/value map in string format "key1=value1|key2=value2|...|keyN=valueN".
A point in 2D or 3D with translation and scaling methods.
Definition Position.h:37
static const Position INVALID
used to indicate that a position is valid
Definition Position.h:322
double x() const
Returns the x-position.
Definition Position.h:55
double y() const
Returns the y-position.
Definition Position.h:60
Structure representing possible vehicle parameter.
SumoXMLTag tag
The vehicle tag.
std::string vtypeid
The vehicle's type id.
std::vector< std::string > via
List of the via-edges the vehicle must visit.
long long int parametersSet
Information for the router which parameter were set, TraCI may modify this (when changing color)
void write(OutputDevice &dev, const OptionsCont &oc, const SumoXMLTag altTag=SUMO_TAG_VEHICLE, const std::string &typeID="") const
Writes the parameters as a beginning element.
bool wasSet(long long int what) const
Returns whether the given parameter was set.
double departPos
(optional) The position the vehicle shall depart from
RGBColor color
The vehicle's color, TraCI may change this.
double arrivalPos
(optional) The position the vehicle shall arrive on
std::string getDepartPos() const
obtain depart pos parameter in string format
static bool parseDepartPos(const std::string &val, const std::string &element, const std::string &id, double &pos, DepartPosDefinition &dpd, std::string &error)
Validates a given departPos value.
DepartPosDefinition departPosProcedure
Information how the vehicle shall choose the departure position.
bool showDemandElements() const
check if show demand elements checkbox is enabled
bool showNonInspectedDemandElements(const GNEDemandElement *demandElement) const
check if non inspected element has to be hidden
bool isCurrentSupermodeDemand() const
@check if current supermode is Demand
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
bool showDemandElements() const
check if show demand elements checkbox is enabled
RGBColor selectedContainerColor
container selection color
static const double segmentWidth
width of dotted contour segments
double getExaggeration(const GUIVisualizationSettings &s, const GUIGlObject *o, double factor=20) const
return the drawing size including exaggeration and constantSize values