Eclipse SUMO - Simulation of Urban MObility
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>
25 #include <utils/gui/div/GLHelper.h>
28 #include <utils/xml/NamespaceIDs.h>
29 
30 #include "GNEContainer.h"
31 #include "GNERouteHandler.h"
32 
33 // ===========================================================================
34 // FOX callback mapping
35 // ===========================================================================
36 
37 FXDEFMAP(GNEContainer::GNEContainerPopupMenu) containerPopupMenuMap[] = {
39 };
40 
41 FXDEFMAP(GNEContainer::GNESelectedContainersPopupMenu) selectedContainersPopupMenuMap[] = {
43 };
44 
45 // Object implementation
46 FXIMPLEMENT(GNEContainer::GNEContainerPopupMenu, GUIGLObjectPopupMenu, containerPopupMenuMap, ARRAYNUMBER(containerPopupMenuMap))
47 FXIMPLEMENT(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 
92 long
93 GNEContainer::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 
107 GNEContainer::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 
141 long
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  GNEPathManager::PathElement::Options::DEMAND_ELEMENT, {}, {}, {}, {}, {}, {}),
163 GNEDemandElementFlow(this) {
164  // reset default values
166  // set end and container per hours as default flow values
169 }
170 
171 
172 GNEContainer::GNEContainer(SumoXMLTag tag, GNENet* net, GNEDemandElement* pType, const SUMOVehicleParameter& containerparameters) :
173  GNEDemandElement(containerparameters.id, net, (tag == SUMO_TAG_CONTAINERFLOW) ? GLO_CONTAINERFLOW : GLO_CONTAINER, tag,
175  GNEPathManager::PathElement::Options::DEMAND_ELEMENT, {}, {}, {}, {}, {pType}, {}),
176 GNEDemandElementFlow(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 
207 void
209  // attribute VType musn't be written if is DEFAULT_PEDTYPE_ID
211  // unset VType parameter
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 
244 std::string
246  if (getChildDemandElements().size() == 0) {
247  return "Container needs at least one plan";
248  } else {
249  return "";
250  }
251 }
252 
253 
254 void
256  // nothing to fix
257 }
258 
259 
262  return getParentDemandElements().front()->getVClass();
263 }
264 
265 
266 const RGBColor&
268  return color;
269 }
270 
271 
272 void
274  // only update geometry of childrens
275  for (const auto& demandElement : getChildDemandElements()) {
276  demandElement->updateGeometry();
277  }
278 }
279 
280 
281 Position
284 }
285 
286 
289  // return a GNEContainerPopupMenu
290  return new GNEContainerPopupMenu(this, app, parent);
291 }
292 
293 
294 std::string
296  return getParentDemandElements().front()->getID();
297 }
298 
299 
300 double
302  return s.containerSize.getExaggeration(s, this, 80);
303 }
304 
305 
306 Boundary
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 
324 void
325 GNEContainer::splitEdgeGeometry(const double /*splitPosition*/, const GNENetworkElement* /*originalElement*/, const GNENetworkElement* /*newElement*/, GNEUndoList* /*undoList*/) {
326  // geometry of this element cannot be splitted
327 }
328 
329 
330 void
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->getPathManager()->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));
392  } else if (getChildDemandElements().front()->getTagProperty().getTag() == GNE_TAG_STOPCONTAINER_CONTAINERSTOP) {
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, -5.5, 0, 0, exaggeration);
426  }
427 }
428 
429 
430 void
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 
439 void
440 GNEContainer::drawLanePartialGL(const GUIVisualizationSettings& /*s*/, const GNEPathManager::Segment* /*segment*/, const double /*offsetFront*/) const {
441  // Stops don't use drawJunctionPartialGL
442 }
443 
444 
445 void
446 GNEContainer::drawJunctionPartialGL(const GUIVisualizationSettings& /*s*/, const GNEPathManager::Segment* /*segment*/, const double /*offsetFront*/) const {
447  // Stops don't use drawJunctionPartialGL
448 }
449 
450 
451 GNELane*
453  // use path lane of first container plan
454  return getChildDemandElements().front()->getFirstPathLane();
455 }
456 
457 
458 GNELane*
460  // use path lane of first container plan
461  return getChildDemandElements().front()->getLastPathLane();
462 }
463 
464 
465 std::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:
475  if (wasSet(VEHPARS_COLOR_SET)) {
476  return toString(color);
477  } else {
479  }
480  case SUMO_ATTR_DEPARTPOS:
482  return getDepartPos();
483  } else {
485  }
486  // Other
487  case GNE_ATTR_SELECTED:
489  case GNE_ATTR_PARAMETERS:
490  return getParametersStr();
491  default:
492  return getFlowAttribute(key);
493  }
494 }
495 
496 
497 double
499  switch (key) {
500  case SUMO_ATTR_DEPARTPOS:
502  return departPos;
503  } else {
504  return 0;
505  }
506  default:
507  return getFlowAttributeDouble(key);
508  }
509 }
510 
511 
512 Position
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 
546 void
547 GNEContainer::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:
552  case SUMO_ATTR_DEPARTPOS:
553  // Other
554  case GNE_ATTR_PARAMETERS:
555  case GNE_ATTR_SELECTED:
556  GNEChange_Attribute::changeAttribute(this, key, value, undoList);
557  break;
558  default:
559  setFlowAttribute(this, key, value, undoList);
560  break;
561  }
562 }
563 
564 
565 bool
566 GNEContainer::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
584  case GNE_ATTR_SELECTED:
585  return canParse<bool>(value);
586  case GNE_ATTR_PARAMETERS:
587  return Parameterised::areParametersValid(value);
588  default:
589  return isValidFlowAttribute(this, key, value);
590  }
591 }
592 
593 
594 void
596  enableFlowAttribute(this, key, undoList);
597 }
598 
599 
600 void
602  disableFlowAttribute(this, key, undoList);
603 }
604 
605 
606 bool
608  return isFlowAttributeEnabled(key);
609 }
610 
611 
612 std::string
614  return getTagStr();
615 }
616 
617 
618 std::string
620  // special case for Trips and flow
622  // check if we're inspecting a Edge
623  if (myNet->getViewNet()->getInspectedAttributeCarriers().front() &&
624  myNet->getViewNet()->getInspectedAttributeCarriers().front()->getTagProperty().getTag() == SUMO_TAG_EDGE) {
625  // check if edge correspond to a "from", "to" or "via" edge
627  return getTagStr() + ": " + getAttribute(SUMO_ATTR_ID) + " (from)";
628  } else if (myNet->getViewNet()->isAttributeCarrierInspected(getParentEdges().front())) {
629  return getTagStr() + ": " + getAttribute(SUMO_ATTR_ID) + " (to)";
630  } else {
631  // iterate over via
632  for (const auto& i : via) {
633  if (i == myNet->getViewNet()->getInspectedAttributeCarriers().front()->getID()) {
634  return getTagStr() + ": " + getAttribute(SUMO_ATTR_ID) + " (via)";
635  }
636  }
637  }
638  }
639  }
640  return getTagStr() + ": " + getAttribute(SUMO_ATTR_ID);
641 }
642 
643 
644 const Parameterised::Map&
646  return getParametersMap();
647 }
648 
649 // ===========================================================================
650 // protected
651 // ===========================================================================
652 
653 RGBColor
655  // change color
656  if (drawUsingSelectColor()) {
658  } else {
659  return getColorByScheme(s.containerColorer, this);
660  }
661 }
662 
663 
664 void
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 
688 void
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 
730 void
731 GNEContainer::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
758  }
759  break;
760  case SUMO_ATTR_DEPARTPOS:
761  if (!value.empty() && (value != myTagProperty.getDefaultValue(key))) {
763  // mark parameter as set
765  } else {
766  // set default value
768  // unset parameter
770  }
771  // compute container
772  updateGeometry();
773  break;
774  // Others
775  case GNE_ATTR_SELECTED:
776  if (parse<bool>(value)) {
778  } else {
780  }
781  break;
782  case GNE_ATTR_PARAMETERS:
783  setParametersStr(value);
784  break;
785  default:
786  setFlowAttribute(this, key, value);
787  break;
788  }
789 }
790 
791 
792 void
794  // toggle flow attributes
795  toggleFlowAttribute(key, value);
796 }
797 
798 
799 void
801  // change departPos
803  departPos = moveResult.newFirstPos;
804  // update geometry
805  updateGeometry();
806 }
807 
808 
809 void
811  undoList->begin(this, "departPos of " + getTagStr());
812  // now set departPos
813  setAttribute(SUMO_ATTR_DEPARTPOS, toString(moveResult.newFirstPos), undoList);
814  undoList->end();
815 }
816 
817 /****************************************************************************/
FXDEFMAP(GNEContainer::GNEContainerPopupMenu) containerPopupMenuMap[]
@ MID_GNE_CONTAINER_TRANSFORM
transform container to another container type (ej: container to containerflow)
Definition: GUIAppEnum.h:1408
@ 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.
const int VEHPARS_COLOR_SET
DepartPosDefinition
Possible ways to choose the departure position.
@ GIVEN
The position is given.
const int VEHPARS_DEPARTPOS_SET
const 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:319
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
Definition: GNEContainer.h:37
long onCmdTransform(FXObject *obj, FXSelector, void *)
Called to transform the current container to another container type.
class used in GUIGLObjectPopupMenu for single container transformations
Definition: GNEContainer.h:69
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
Definition: GNEContainer.h:98
FXMenuCommand * myTransformToContainerFlow
menu command for transform to containerFlow
Definition: GNEContainer.h:101
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 drawLanePartialGL(const GUIVisualizationSettings &s, const GNEPathManager::Segment *segment, const double offsetFront) const
Draws partial object over lane.
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 GNEPathManager::Segment *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
Definition: GNEContainer.h:279
GNELane * getFirstPathLane() const
get first path 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 offsetX, const double offsetY, const double rot, const double scale) const
calculate contour (for rectangled elements)
Definition: GNEContour.cpp:103
void drawDottedContours(const GUIVisualizationSettings &s, const GUIVisualizationSettings::Detail d, const GNEAttributeCarrier *AC, const double lineWidth, const bool addOffset) const
drawing contour functions
Definition: GNEContour.cpp:265
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
GNENetHelper::AttributeCarriers * getAttributeCarriers() const
get all attribute carriers used in this net
Definition: GNENet.cpp:123
GNEPathManager * getPathManager()
get path manager
Definition: GNENet.cpp:135
GNEViewNet * getViewNet() const
get view net
Definition: GNENet.cpp:2136
PathElement()=delete
invalidate default constructor
bool isPathValid(const PathElement *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
Definition: GNEViewNet.cpp:747
const GNEViewNetHelper::EditModes & getEditModes() const
get edit modes
Definition: GNEViewNet.cpp:723
const GNEViewNetHelper::NetworkViewOptions & getNetworkViewOptions() const
get network view options
Definition: GNEViewNet.cpp:735
void drawTranslateFrontAttributeCarrier(const GNEAttributeCarrier *AC, double typeOrLayer, const double extraOffset=0)
draw front attributeCarrier
const std::vector< GNEAttributeCarrier * > & getInspectedAttributeCarriers() const
get inspected attribute carriers
void buildSelectionACPopupEntry(GUIGLObjectPopupMenu *ret, GNEAttributeCarrier *AC)
Builds an entry which allows to (de)select the object.
Definition: GNEViewNet.cpp:553
bool isAttributeCarrierInspected(const GNEAttributeCarrier *AC) const
check if attribute carrier is being inspected
const GNEViewNetHelper::DemandViewOptions & getDemandViewOptions() const
get demand view options
Definition: GNEViewNet.cpp:741
static FXMenuCommand * buildFXMenuCommand(FXComposite *p, const std::string &text, FXIcon *icon, FXObject *tgt, FXSelector sel, const bool disable=false)
build menu command
Definition: GUIDesigns.cpp:42
The popup menu of a globject.
void insertMenuPaneChild(FXMenuPane *child)
Insert a sub-menu pane in this GUIGLObjectPopupMenu.
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.
Definition: GUIGlObject.h:156
const std::string & getMicrosimID() const
Returns the id of the object as known to microsim.
Definition: GUIGlObject.h:143
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
Definition: NamespaceIDs.h:53
static const std::vector< SumoXMLTag > containers
containers namespace
Definition: NamespaceIDs.h:65
static OptionsCont & getOptions()
Retrieves the options.
Definition: OptionsCont.cpp:60
Static storage of an output device and its base (abstract) implementation.
Definition: OutputDevice.h:61
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
Definition: Parameterised.h:45
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.
int parametersSet
Information for the router which parameter were set, TraCI may modify this (when changing color)
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.
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.
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
bool wasSet(int what) const
Returns whether the given parameter was set.
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