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-2025 German Aerospace Center (DLR) and others.
4// This program and the accompanying materials are made available under the
5// terms of the Eclipse Public License 2.0 which is available at
6// https://www.eclipse.org/legal/epl-2.0/
7// This Source Code may also be made available under the following Secondary
8// Licenses when the conditions for such availability set forth in the Eclipse
9// Public License 2.0 are satisfied: GNU General Public License, version 2
10// or later which is available at
11// https://www.gnu.org/licenses/old-licenses/gpl-2.0-standalone.html
12// SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-or-later
13/****************************************************************************/
18// Representation of containers in netedit
19/****************************************************************************/
20
24#include <netedit/GNENet.h>
31
32#include "GNEContainer.h"
33#include "GNERouteHandler.h"
34
35// ===========================================================================
36// FOX callback mapping
37// ===========================================================================
38
42
46
47// Object implementation
48FXIMPLEMENT(GNEContainer::GNEContainerPopupMenu, GUIGLObjectPopupMenu, containerPopupMenuMap, ARRAYNUMBER(containerPopupMenuMap))
49FXIMPLEMENT(GNEContainer::GNESelectedContainersPopupMenu, GUIGLObjectPopupMenu, selectedContainersPopupMenuMap, ARRAYNUMBER(selectedContainersPopupMenuMap))
50
51// ===========================================================================
52// GNEContainer::GNEContainerPopupMenu
53// ===========================================================================
54
56 GUIGLObjectPopupMenu(app, parent, container),
57 myContainer(container),
58 myTransformToContainer(nullptr),
59 myTransformToContainerFlow(nullptr) {
60 // build common options
61 container->buildPopUpMenuCommonOptions(this, app, container->myNet->getViewNet(), container->getTagProperty()->getTag(), container->isAttributeCarrierSelected());
62 // add transform functions only in demand mode
63 if (myContainer->getNet()->getViewNet()->getEditModes().isCurrentSupermodeDemand()) {
64 // create menu pane for transform operations
65 FXMenuPane* transformOperation = new FXMenuPane(this);
66 this->insertMenuPaneChild(transformOperation);
67 new FXMenuCascade(this, "transform to", nullptr, transformOperation);
68 // Create menu comands for all transformations
69 myTransformToContainer = GUIDesigns::buildFXMenuCommand(transformOperation, "Container", GUIIconSubSys::getIcon(GUIIcon::CONTAINER), this, MID_GNE_CONTAINER_TRANSFORM);
70 myTransformToContainerFlow = GUIDesigns::buildFXMenuCommand(transformOperation, "ContainerFlow", GUIIconSubSys::getIcon(GUIIcon::CONTAINERFLOW), this, MID_GNE_CONTAINER_TRANSFORM);
71 // check what menu command has to be disabled
72 if (myContainer->getTagProperty()->getTag() == SUMO_TAG_CONTAINER) {
73 myTransformToContainer->disable();
74 } else if (myContainer->getTagProperty()->getTag() == SUMO_TAG_CONTAINERFLOW) {
75 myTransformToContainerFlow->disable();
76 }
77 }
78}
79
80
82
83
84long
85GNEContainer::GNEContainerPopupMenu::onCmdTransform(FXObject* obj, FXSelector, void*) {
86 if (obj == myTransformToContainer) {
88 } else if (obj == myTransformToContainerFlow) {
90 }
91 return 1;
92}
93
94
95// ===========================================================================
96// GNEContainer::GNESelectedContainersPopupMenu
97// ===========================================================================
98
99GNEContainer::GNESelectedContainersPopupMenu::GNESelectedContainersPopupMenu(GNEContainer* container, const std::vector<GNEContainer*>& selectedContainer, GUIMainWindow& app, GUISUMOAbstractView& parent) :
100 GUIGLObjectPopupMenu(app, parent, container),
101 myContainerTag(container->getTagProperty()->getTag()),
102 mySelectedContainers(selectedContainer),
103 myTransformToContainer(nullptr),
104 myTransformToContainerFlow(nullptr) {
105 // build common options
106 container->buildPopUpMenuCommonOptions(this, app, container->myNet->getViewNet(), container->getTagProperty()->getTag(), container->isAttributeCarrierSelected());
107 // add transform functions only in demand mode
108 if (container->getNet()->getViewNet()->getEditModes().isCurrentSupermodeDemand()) {
109 // create menu pane for transform operations
110 FXMenuPane* transformOperation = new FXMenuPane(this);
111 this->insertMenuPaneChild(transformOperation);
112 new FXMenuCascade(this, "transform to", nullptr, transformOperation);
113 // Create menu comands for all transformations
116 }
117}
118
119
121
122
123long
125 // iterate over all selected containers
126 for (const auto& container : mySelectedContainers) {
127 if ((obj == myTransformToContainer) &&
128 (container->getTagProperty()->getTag() == myContainerTag)) {
130 } else if ((obj == myTransformToContainerFlow) &&
131 (container->getTagProperty()->getTag() == myContainerTag)) {
133 }
134 }
135 return 1;
136}
137
138// ===========================================================================
139// member method definitions
140// ===========================================================================
141
142#ifdef _MSC_VER
143#pragma warning(push)
144#pragma warning(disable: 4355) // mask warning about "this" in initializers
145#endif
154
155
157 GNEDemandElement* pType, const SUMOVehicleParameter& containerparameters) :
158 GNEDemandElement(containerparameters.id, net, tag, fileBucket),
159 GNEDemandElementFlow(this, containerparameters),
160 myMoveElementPlanParent(new GNEMoveElementPlanParent(this, departPos, departPosProcedure)) {
161 // set parents
162 setParent<GNEDemandElement*>(pType);
163 // set manually vtypeID (needed for saving)
164 vtypeid = pType->getID();
165}
166#ifdef _MSC_VER
167#pragma warning(pop)
168#endif
169
171
172
177
178
181 return this;
182}
183
184
185const Parameterised*
187 return this;
188}
189
190
191void
193 // attribute VType musn't be written if is DEFAULT_PEDTYPE_ID
195 // unset VType parameter
196 parametersSet &= ~VEHPARS_VTYPE_SET;
197 // write container attributes (VType will not be written)
199 // set VType parameter again
201 } else {
202 // write container attributes, including VType
204 }
205 // write parameters
206 writeParams(device);
207 // write child demand elements associated to this container (Rides, Walks...)
208 for (const auto& containerPlan : getChildDemandElements()) {
209 containerPlan->writeDemandElement(device);
210 }
211 // close container tag
212 device.closeTag();
213}
214
215
218 if (getChildDemandElements().size() == 0) {
219 return Problem::NO_PLANS;
220 } else {
221 return Problem::OK;
222 }
223}
224
225
226std::string
228 if (getChildDemandElements().size() == 0) {
229 return "Container needs at least one plan";
230 } else {
231 return "";
232 }
233}
234
235
236void
238 // nothing to fix
239}
240
241
244 return getParentDemandElements().front()->getVClass();
245}
246
247
248const RGBColor&
250 return color;
251}
252
253
254void
256 // only update geometry of childrens
257 for (const auto& demandElement : getChildDemandElements()) {
258 demandElement->updateGeometry();
259 }
260}
261
262
267
268
271 // return a GNEContainerPopupMenu
272 return new GNEContainerPopupMenu(this, app, parent);
273}
274
275
276std::string
278 return getParentDemandElements().front()->getID();
279}
280
281
282double
286
287
290 Boundary containerBoundary;
291 if (getChildDemandElements().size() > 0) {
292 if (getChildDemandElements().front()->getTagProperty()->isPlanStopContainer()) {
293 // use boundary of stop center
294 return getChildDemandElements().front()->getCenteringBoundary();
295 } else {
296 containerBoundary.add(getPositionInView());
297 }
298 } else {
299 containerBoundary = Boundary(-0.1, -0.1, 0.1, 0.1);
300 }
301 containerBoundary.grow(20);
302 return containerBoundary;
303}
304
305
306void
307GNEContainer::splitEdgeGeometry(const double /*splitPosition*/, const GNENetworkElement* /*originalElement*/,
308 const GNENetworkElement* /*newElement*/, GNEUndoList* /*undoList*/) {
309 // geometry of this element cannot be splitted
310}
311
312
313void
315 bool drawContainer = true;
316 // check if container can be drawn
318 drawContainer = false;
320 drawContainer = false;
322 drawContainer = false;
323 } else if (getChildDemandElements().empty()) {
324 drawContainer = false;
325 }
326 // continue if container can be drawn
327 if (drawContainer) {
328 // obtain exaggeration (and add the special containerExaggeration)
329 const double exaggeration = getExaggeration(s) + 10;
330 // get detail level
331 const auto d = s.getDetailLevel(exaggeration);
332 // obtain position
333 const Position containerPosition = getAttributePosition(SUMO_ATTR_DEPARTPOS);
334 if (containerPosition == Position::INVALID) {
335 return;
336 }
337 // draw geometry only if we'rent in drawForObjectUnderCursor mode
339 // obtain img file
340 const std::string file = getTypeParent()->getAttribute(SUMO_ATTR_IMGFILE);
341 // push draw matrix
343 // Start with the drawing of the area traslating matrix to origin
345 // translate and rotate
346 glTranslated(containerPosition.x(), containerPosition.y(), 0);
347 glRotated(90, 0, 0, 1);
348 // set container color
350 // set scale
351 glScaled(exaggeration, exaggeration, 1);
352 // draw container depending of detail level
353 switch (s.containerQuality) {
354 case 0:
355 case 1:
356 case 2:
358 break;
359 case 3:
360 default:
362 break;
363 }
364 // pop matrix
366 // draw line between junctions if container plan isn't valid
367 for (const auto& containerPlan : getChildDemandElements()) {
368 if (containerPlan->getTagProperty()->isPlanContainer() && (containerPlan->getParentJunctions().size() > 0) &&
369 !myNet->getDemandPathManager()->isPathValid(containerPlan)) {
370 drawJunctionLine(containerPlan);
371 }
372 }
373 // draw stack label
374 if (myStackedLabelNumber > 0) {
375 drawStackLabel(myStackedLabelNumber, "container", Position(containerPosition.x() - 2.5, containerPosition.y() - 0.8), -90, 1.3, 5, getExaggeration(s));
377 // declare counter for stacked containers over stops
378 int stackedCounter = 0;
379 // get stoppingPlace
380 const auto stoppingPlace = getChildDemandElements().front()->getParentAdditionals().front();
381 // get stacked containers
382 for (const auto& stopContainer : stoppingPlace->getChildDemandElements()) {
383 if (stopContainer->getTagProperty()->getTag() == GNE_TAG_STOPCONTAINER_CONTAINERSTOP) {
384 // get container parent
385 const auto containerParent = stopContainer->getParentDemandElements().front();
386 // check if the stop if the first container plan parent
387 if (stopContainer->getPreviousChildDemandElement(containerParent) == nullptr) {
388 stackedCounter++;
389 }
390 }
391 }
392 // if we have more than two stacked elements, draw label
393 if (stackedCounter > 1) {
394 drawStackLabel(stackedCounter, "container", Position(containerPosition.x() - 2.5, containerPosition.y() - 0.8), -90, 1.3, 5, getExaggeration(s));
395 }
396 }
397 // draw flow label
398 if (myTagProperty->isFlow()) {
399 drawFlowLabel(Position(containerPosition.x() - 1, containerPosition.y() - 4.25), -90, 1.8, 2, getExaggeration(s));
400 }
401 // draw name
402 drawName(containerPosition, s.scale, s.containerName, s.angle);
403 // draw lock icon
405 // draw dotted contour
407 }
408 // calculate contour
409 myContainerContour.calculateContourRectangleShape(s, d, this, containerPosition, 0.5, 0.18, getType(), -5.5, 0, 0, exaggeration, nullptr);
410 }
411}
412
413
414void
416 // compute all container plan children (because aren't computed in "computeDemandElements()")
417 for (const auto& demandElement : getChildDemandElements()) {
418 demandElement->computePathElement();
419 }
420}
421
422
423void
424GNEContainer::drawLanePartialGL(const GUIVisualizationSettings& /*s*/, const GNESegment* /*segment*/, const double /*offsetFront*/) const {
425 // Stops don't use drawJunctionPartialGL
426}
427
428
429void
430GNEContainer::drawJunctionPartialGL(const GUIVisualizationSettings& /*s*/, const GNESegment* /*segment*/, const double /*offsetFront*/) const {
431 // Stops don't use drawJunctionPartialGL
432}
433
434
435GNELane*
437 // use path lane of first container plan
438 return getChildDemandElements().front()->getFirstPathLane();
439}
440
441
442GNELane*
444 // use path lane of first container plan
445 return getChildDemandElements().front()->getLastPathLane();
446}
447
448
449std::string
451 // declare string error
452 std::string error;
453 switch (key) {
454 case SUMO_ATTR_ID:
455 return getMicrosimID();
456 case SUMO_ATTR_TYPE:
457 return getTypeParent()->getID();
458 case SUMO_ATTR_COLOR:
460 return toString(color);
461 } else {
463 }
466 return getDepartPos();
467 } else {
469 }
470 default:
471 return getFlowAttribute(this, key);
472 }
473}
474
475
476double
478 switch (key) {
481 return departPos;
482 } else {
483 return 0;
484 }
485 default:
486 return getFlowAttributeDouble(key);
487 }
488}
489
490
493 switch (key) {
494 case SUMO_ATTR_DEPARTPOS: {
495 // first check number of child demand elements
496 if (getChildDemandElements().empty()) {
497 return Position();
498 }
499 // get container plan
500 const GNEDemandElement* containerPlan = getChildDemandElements().front();
501 // first check if first container plan is a stop
502 if (containerPlan->getTagProperty()->isPlanStopContainer()) {
503 // stop center
504 return containerPlan->getPositionInView();
505 } else if (containerPlan->getTagProperty()->planFromTAZ()) {
506 // TAZ
507 if (containerPlan->getParentAdditionals().front()->getAttribute(SUMO_ATTR_CENTER).empty()) {
508 return containerPlan->getParentAdditionals().front()->getAttributePosition(GNE_ATTR_TAZ_CENTROID);
509 } else {
510 return containerPlan->getParentAdditionals().front()->getAttributePosition(SUMO_ATTR_CENTER);
511 }
512 } else if (containerPlan->getTagProperty()->planFromJunction()) {
513 // juncrtion
514 return containerPlan->getParentJunctions().front()->getPositionInView();
515 } else {
517 }
518 }
519 default:
520 return getCommonAttributePosition(key);
521 }
522}
523
524
525void
526GNEContainer::setAttribute(SumoXMLAttr key, const std::string& value, GNEUndoList* undoList) {
527 switch (key) {
528 case SUMO_ATTR_ID:
529 case SUMO_ATTR_TYPE:
530 case SUMO_ATTR_COLOR:
532 GNEChange_Attribute::changeAttribute(this, key, value, undoList);
533 break;
534 default:
535 setFlowAttribute(this, key, value, undoList);
536 break;
537 }
538}
539
540
541bool
542GNEContainer::isValid(SumoXMLAttr key, const std::string& value) {
543 // declare string error
544 std::string error;
545 switch (key) {
546 case SUMO_ATTR_ID:
548 case SUMO_ATTR_TYPE:
549 return (myNet->getAttributeCarriers()->retrieveDemandElements(NamespaceIDs::types, value, false) != nullptr);
550 case SUMO_ATTR_COLOR:
551 return canParse<RGBColor>(value);
552 case SUMO_ATTR_DEPARTPOS: {
553 double dummyDepartPos;
554 DepartPosDefinition dummyDepartPosProcedure;
555 parseDepartPos(value, myTagProperty->getTagStr(), id, dummyDepartPos, dummyDepartPosProcedure, error);
556 // if error is empty, given value is valid
557 return error.empty();
558 }
559 default:
560 return isValidFlowAttribute(this, key, value);
561 }
562}
563
564
565void
567 enableFlowAttribute(this, key, undoList);
568}
569
570
571void
573 disableFlowAttribute(this, key, undoList);
574}
575
576
577bool
581
582
583std::string
585 return getTagStr();
586}
587
588
589std::string
591 const auto& inspectedElements = myNet->getViewNet()->getInspectedElements();
592 // special case for Trips and flow
594 // check if we're inspecting an Edge
595 if (inspectedElements.getFirstAC() && (inspectedElements.getFirstAC()->getTagProperty()->getTag() == SUMO_TAG_EDGE)) {
596 // check if edge correspond to a "from", "to" or "via" edge
597 if (inspectedElements.isACInspected(getParentEdges().front())) {
598 return getTagStr() + ": " + getAttribute(SUMO_ATTR_ID) + " (from)";
599 } else if (inspectedElements.isACInspected(getParentEdges().front())) {
600 return getTagStr() + ": " + getAttribute(SUMO_ATTR_ID) + " (to)";
601 } else {
602 // iterate over via
603 for (const auto& viaEdgeID : via) {
604 if (viaEdgeID == inspectedElements.getFirstAC()->getID()) {
605 return getTagStr() + ": " + getAttribute(SUMO_ATTR_ID) + " (via)";
606 }
607 }
608 }
609 }
610 }
611 return getTagStr() + ": " + getAttribute(SUMO_ATTR_ID);
612}
613
614// ===========================================================================
615// protected
616// ===========================================================================
617
620 // change color
621 if (drawUsingSelectColor()) {
623 } else {
624 return getColorByScheme(s.containerColorer, this);
625 }
626}
627
628
629void
631 // obtain width and length
632 const double length = getTypeParent()->getAttributeDouble(SUMO_ATTR_LENGTH);
633 const double width = getTypeParent()->getAttributeDouble(SUMO_ATTR_WIDTH);
634 // draw pedestrian shape
635 glScaled(length * 0.2, width * 0.2, 1);
636 glBegin(GL_QUADS);
637 glVertex2d(0, 0.5);
638 glVertex2d(0, -0.5);
639 glVertex2d(-1, -0.5);
640 glVertex2d(-1, 0.5);
641 glEnd();
642 GLHelper::setColor(GLHelper::getColor().changedBrightness(-30));
643 glTranslated(0, 0, .045);
644 glBegin(GL_QUADS);
645 glVertex2d(-0.1, 0.4);
646 glVertex2d(-0.1, -0.4);
647 glVertex2d(-0.9, -0.4);
648 glVertex2d(-0.9, 0.4);
649 glEnd();
650}
651
652
653void
655 const std::string& file = getTypeParent()->getAttribute(SUMO_ATTR_IMGFILE);
656 // obtain width and length
657 const double length = getTypeParent()->getAttributeDouble(SUMO_ATTR_LENGTH);
658 const double width = getTypeParent()->getAttributeDouble(SUMO_ATTR_WIDTH);
659 if (file != "") {
660 // @todo invent an option for controlling whether images should be rotated or not
661 //if (getVehicleType().getGuiShape() == SVS_CONTAINER) {
662 // glRotated(RAD2DEG(getAngle() + M_PI / 2.), 0, 0, 1);
663 //}
664 int textureID = GUITexturesHelper::getTextureID(file);
665 if (textureID > 0) {
666 const double exaggeration = s.containerSize.getExaggeration(s, this);
667 const double halfLength = length / 2.0 * exaggeration;
668 const double halfWidth = width / 2.0 * exaggeration;
669 GUITexturesHelper::drawTexturedBox(textureID, -halfWidth, -halfLength, halfWidth, halfLength);
670 }
671 } else {
672 // fallback if no image is defined
674 }
675}
676
677// ===========================================================================
678// private
679// ===========================================================================
680
682 containerPlan(_containerPlan),
683 edge(nullptr),
684 arrivalPos(-1) {
685}
686
687
689 containerPlan(nullptr),
690 edge(nullptr),
691 arrivalPos(-1) {
692}
693
694
695void
696GNEContainer::setAttribute(SumoXMLAttr key, const std::string& value) {
697 // declare string error
698 std::string error;
699 switch (key) {
700 case SUMO_ATTR_ID:
701 // update microsimID
702 setDemandElementID(value);
703 // update id
704 id = value;
705 break;
706 case SUMO_ATTR_TYPE:
707 if (getID().size() > 0) {
709 // set manually vtypeID (needed for saving)
710 vtypeid = value;
711 }
712 break;
713 case SUMO_ATTR_COLOR:
714 if (!value.empty() && (value != myTagProperty->getDefaultStringValue(key))) {
715 color = parse<RGBColor>(value);
716 // mark parameter as set
718 } else {
719 // set default value
720 color = parse<RGBColor>(myTagProperty->getDefaultStringValue(key));
721 // unset parameter
722 parametersSet &= ~VEHPARS_COLOR_SET;
723 }
724 break;
726 if (!value.empty() && (value != myTagProperty->getDefaultStringValue(key))) {
728 // mark parameter as set
730 } else {
731 // set default value
733 // unset parameter
734 parametersSet &= ~VEHPARS_DEPARTPOS_SET;
735 }
736 // compute container
738 break;
739 default:
740 setFlowAttribute(this, key, value);
741 break;
742 }
743}
744
745void
747 // toggle flow attributes
748 toggleFlowAttribute(key, value);
749}
750
751/****************************************************************************/
FXDEFMAP(GNEContainer::GNEContainerPopupMenu) containerPopupMenuMap[]
@ MID_GNE_CONTAINER_TRANSFORM
transform container to another container type (ej: container to containerflow)
@ 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_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_TAZ_CENTROID
TAZ Center (uses to return the TAZ centroid if center is not defined)
@ 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:75
Boundary & grow(double by)
extends the boundary by the given amount
Definition Boundary.cpp:340
static void setColor(const RGBColor &c)
Sets the gl-color to this value.
Definition GLHelper.cpp:649
static void popMatrix()
pop matrix
Definition GLHelper.cpp:131
static RGBColor getColor()
gets the gl-color
Definition GLHelper.cpp:655
static void pushMatrix()
push matrix
Definition GLHelper.cpp:118
virtual double getAttributeDouble(SumoXMLAttr key) const =0
bool isAttributeCarrierSelected() const
check if attribute carrier is selected
const std::string getID() const override
get ID (all Attribute Carriers have one)
const std::string & getTagStr() const
get tag assigned to this object in string format
bool drawUsingSelectColor() const
check if attribute carrier must be drawn using selecting color.
void drawInLayer(const double typeOrLayer, const double extraOffset=0) const
draw element in the given layer, or in front if corresponding flag is enabled
Position getCommonAttributePosition(SumoXMLAttr key) const
const GNETagProperties * getTagProperty() const
get tagProperty associated with this Attribute Carrier
GNENet * myNet
pointer to net
GNENet * getNet() const
get pointer to net
virtual std::string getAttribute(SumoXMLAttr key) const =0
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
GNELane * getLastPathLane() const override
get last path lane
void drawJunctionPartialGL(const GUIVisualizationSettings &s, const GNESegment *segment, const double offsetFront) const override
Draws partial object over junction.
void splitEdgeGeometry(const double splitPosition, const GNENetworkElement *originalElement, const GNENetworkElement *newElement, GNEUndoList *undoList) override
split geometry
std::string getDemandElementProblem() const override
return a string with the current demand element problem (by default empty, can be reimplemented in ch...
void updateGeometry() override
update pre-computed geometry information
Parameterised * getParameters() override
get parameters associated with this container
void writeDemandElement(OutputDevice &device) const override
write demand element element into a xml file
void disableAttribute(SumoXMLAttr key, GNEUndoList *undoList) override
Problem isDemandElementValid() const override
check if current demand element is valid to be written into XML (by default true, can be reimplemente...
GNEContainer(SumoXMLTag tag, GNENet *net)
default constructor
std::string getPopUpID() const override
get PopPup ID (Used in AC Hierarchy)
std::string getAttribute(SumoXMLAttr key) const override
inherited from GNEAttributeCarrier
SUMOVehicleClass getVClass() const override
obtain VClass related with this demand element
GNEMoveElement * getMoveElement() const override
methods to retrieve the elements linked to this container
void toggleAttribute(SumoXMLAttr key, const bool value) override
method for enable or disable the attribute and nothing else (used in GNEChange_ToggleAttribute)
void fixDemandElementProblem() override
fix demand element problem (by default throw an exception, has to be reimplemented in children)
bool isAttributeEnabled(SumoXMLAttr key) const override
double getAttributeDouble(SumoXMLAttr key) const override
void setAttribute(SumoXMLAttr key, const std::string &value, GNEUndoList *undoList) override
double getExaggeration(const GUIVisualizationSettings &s) const override
return exaggeration associated with this GLObject
bool isValid(SumoXMLAttr key, const std::string &value) override
void drawAction_drawAsPoly() const
draw container as poly
std::string getParentName() const override
Returns the name of the parent object.
GNEMoveElementPlanParent * myMoveElementPlanParent
move element plan parent
Position getPositionInView() const override
Returns position of demand element in view.
Position getAttributePosition(SumoXMLAttr key) const override
GNELane * getFirstPathLane() const override
get first path lane
void drawAction_drawAsImage(const GUIVisualizationSettings &s) const
draw container as image
void drawLanePartialGL(const GUIVisualizationSettings &s, const GNESegment *segment, const double offsetFront) const override
Draws partial object over lane.
Boundary getCenteringBoundary() const override
Returns the boundary to which the view shall be centered in order to show the object.
~GNEContainer()
destructor
RGBColor getDrawingColor(const GUIVisualizationSettings &s) const
get drawing color
GUIGLObjectPopupMenu * getPopUpMenu(GUIMainWindow &app, GUISUMOAbstractView &parent) override
Returns an own popup-menu.
std::string getHierarchyName() const override
get Hierarchy Name (Used in AC Hierarchy)
void drawGL(const GUIVisualizationSettings &s) const override
Draws the object.
void computePathElement() override
compute pathElement
GNEContour myContainerContour
variable used for contours
const RGBColor & getColor() const override
get color
void enableAttribute(SumoXMLAttr key, GNEUndoList *undoList) override
bool 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 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 GUIGlObject *boundaryParent) const
calculate contour (for rectangled elements)
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
std::string getFlowAttribute(const GNEDemandElement *flowElement, SumoXMLAttr key) const
inherited from GNEAttributeCarrier and adapted to GNEDemandElementFlow
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 enableFlowAttribute(GNEDemandElement *flowElement, SumoXMLAttr key, GNEUndoList *undoList)
void setFlowAttribute(GNEDemandElement *flowElement, SumoXMLAttr key, const std::string &value, GNEUndoList *undoList)
Position getAttributePosition(SumoXMLAttr key) const override
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
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
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)
void replaceDemandElementParent(const std::vector< SumoXMLTag > tags, const std::string &value, const int parentIndex)
replace demand element parent
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
const GNEHierarchicalContainerParents< GNEAdditional * > & getParentAdditionals() const
get parent additionals
const GNEHierarchicalContainerParents< GNEDemandElement * > & getParentDemandElements() const
get parent demand elements
const GNEHierarchicalContainerParents< GNEEdge * > & getParentEdges() const
get parent edges
const GNEHierarchicalContainerParents< GNEJunction * > & getParentJunctions() const
get parent junctions
const GNEHierarchicalContainerChildren< GNEDemandElement * > & getChildDemandElements() const
return child demand elements
GNEDemandElement * retrieveDemandElements(const std::vector< SumoXMLTag > types, const std::string &id, bool hardFail=true) const
Returns the named demand element.
GNEPathManager * getDemandPathManager()
get demand path manager
Definition GNENet.cpp:198
GNENetHelper::AttributeCarriers * getAttributeCarriers() const
get all attribute carriers used in this net
Definition GNENet.cpp:174
GNEViewNet * getViewNet() const
get view net (used for simplify code)
Definition GNENet.cpp:144
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
SumoXMLTag getXMLTag() const
default values
const std::string & getDefaultStringValue(SumoXMLAttr attr) const
default values
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
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.
GUIGlObjectType getType() const
Returns the type of the object as coded in GUIGlObjectType.
void buildPopUpMenuCommonOptions(GUIGLObjectPopupMenu *ret, GUIMainWindow &app, GUISUMOAbstractView *parent, const SumoXMLTag tag, const bool selected, bool addSeparator=true)
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.
An upper class for objects with additional parameters.
void writeParams(OutputDevice &device) const
write Params in the given outputdevice
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:323
double x() const
Returns the x-position.
Definition Position.h:52
double y() const
Returns the y-position.
Definition Position.h:57
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