Eclipse SUMO - Simulation of Urban MObility
GNEPerson.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 persons 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>
29 #include <utils/xml/NamespaceIDs.h>
30 
31 #include "GNEPerson.h"
32 #include "GNERouteHandler.h"
33 
34 // ===========================================================================
35 // FOX callback mapping
36 // ===========================================================================
37 FXDEFMAP(GNEPerson::GNEPersonPopupMenu) personPopupMenuMap[] = {
39 };
40 
41 FXDEFMAP(GNEPerson::GNESelectedPersonsPopupMenu) selectedPersonsPopupMenuMap[] = {
43 };
44 
45 // Object implementation
46 FXIMPLEMENT(GNEPerson::GNEPersonPopupMenu, GUIGLObjectPopupMenu, personPopupMenuMap, ARRAYNUMBER(personPopupMenuMap))
47 FXIMPLEMENT(GNEPerson::GNESelectedPersonsPopupMenu, GUIGLObjectPopupMenu, selectedPersonsPopupMenuMap, ARRAYNUMBER(selectedPersonsPopupMenuMap))
48 
49 // ===========================================================================
50 // GNEPerson::GNEPersonPopupMenu
51 // ===========================================================================
52 
54  GUIGLObjectPopupMenu(app, parent, *person),
55  myPerson(person),
56  myTransformToPerson(nullptr),
57  myTransformToPersonFlow(nullptr) {
58  // build header
59  myPerson->buildPopupHeader(this, app);
60  // build menu command for center button and copy cursor position to clipboard
61  myPerson->buildCenterPopupEntry(this);
62  myPerson->buildPositionCopyEntry(this, app);
63  // build menu commands for names
64  GUIDesigns::buildFXMenuCommand(this, ("Copy " + myPerson->getTagStr() + " name to clipboard").c_str(), nullptr, this, MID_COPY_NAME);
65  GUIDesigns::buildFXMenuCommand(this, ("Copy " + myPerson->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  myPerson->getNet()->getViewNet()->buildSelectionACPopupEntry(this, myPerson);
69  myPerson->buildShowParamsPopupEntry(this);
70  // add transform functions only in demand mode
71  if (myPerson->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  myTransformToPerson = GUIDesigns::buildFXMenuCommand(transformOperation, "Person", GUIIconSubSys::getIcon(GUIIcon::PERSON), this, MID_GNE_PERSON_TRANSFORM);
78  myTransformToPersonFlow = GUIDesigns::buildFXMenuCommand(transformOperation, "PersonFlow", GUIIconSubSys::getIcon(GUIIcon::PERSONFLOW), this, MID_GNE_PERSON_TRANSFORM);
79  // check what menu command has to be disabled
80  if (myPerson->getTagProperty().getTag() == SUMO_TAG_PERSON) {
81  myTransformToPerson->disable();
82  } else if (myPerson->getTagProperty().getTag() == SUMO_TAG_PERSONFLOW) {
83  myTransformToPersonFlow->disable();
84  }
85  }
86 }
87 
88 
90 
91 
92 long
93 GNEPerson::GNEPersonPopupMenu::onCmdTransform(FXObject* obj, FXSelector, void*) {
94  if (obj == myTransformToPerson) {
96  } else if (obj == myTransformToPersonFlow) {
98  }
99  return 1;
100 }
101 
102 
103 // ===========================================================================
104 // GNEPerson::GNESelectedPersonsPopupMenu
105 // ===========================================================================
106 
107 GNEPerson::GNESelectedPersonsPopupMenu::GNESelectedPersonsPopupMenu(GNEPerson* person, const std::vector<GNEPerson*>& selectedPerson, GUIMainWindow& app, GUISUMOAbstractView& parent) :
108  GUIGLObjectPopupMenu(app, parent, *person),
109  myPersonTag(person->getTagProperty().getTag()),
110  mySelectedPersons(selectedPerson),
111  myTransformToPerson(nullptr),
112  myTransformToPersonFlow(nullptr) {
113  // build header
114  person->buildPopupHeader(this, app);
115  // build menu command for center button and copy cursor position to clipboard
116  person->buildCenterPopupEntry(this);
117  person->buildPositionCopyEntry(this, app);
118  // build menu commands for names
119  GUIDesigns::buildFXMenuCommand(this, ("Copy " + person->getTagStr() + " name to clipboard").c_str(), nullptr, this, MID_COPY_NAME);
120  GUIDesigns::buildFXMenuCommand(this, ("Copy " + person->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  person->getNet()->getViewNet()->buildSelectionACPopupEntry(this, person);
124  person->buildShowParamsPopupEntry(this);
125  // add transform functions only in demand mode
126  if (person->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 persons
144  for (const auto& i : mySelectedPersons) {
145  if ((obj == myTransformToPerson) &&
146  (i->getTagProperty().getTag() == myPersonTag)) {
148  } else if ((obj == myTransformToPersonFlow) &&
149  (i->getTagProperty().getTag() == myPersonTag)) {
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  // enable set and persons per hour as default flow values
169 }
170 
171 
172 GNEPerson::GNEPerson(SumoXMLTag tag, GNENet* net, GNEDemandElement* pType, const SUMOVehicleParameter& personparameters) :
173  GNEDemandElement(personparameters.id, net, (tag == SUMO_TAG_PERSONFLOW) ? GLO_PERSONFLOW : GLO_PERSON, tag,
175  GNEPathManager::PathElement::Options::DEMAND_ELEMENT, {}, {}, {}, {}, {pType}, {}),
176 GNEDemandElementFlow(this, personparameters) {
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 person plan
189  if (firstContainerPlan->getTagProperty().isPlanStopPerson()) {
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
210  if (getTypeParent()->getID() == DEFAULT_PEDTYPE_ID) {
211  // unset VType parameter
213  // write person attributes (VType will not be written)
215  // set VType parameter again
217  } else {
218  // write person 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 person (Rides, Walks...)
226  for (const auto& i : getChildDemandElements()) {
227  i->writeDemandElement(device);
228  }
229  // close person 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 "Person 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 GNEPersonPopupMenu
290  return new GNEPersonPopupMenu(this, app, parent);
291 }
292 
293 
294 std::string
296  return getParentDemandElements().front()->getID();
297 }
298 
299 
300 double
302  return s.personSize.getExaggeration(s, this, 80);
303 }
304 
305 
306 Boundary
308  Boundary personBoundary;
309  if (getChildDemandElements().size() > 0) {
310  if (getChildDemandElements().front()->getTagProperty().isPlanStopPerson()) {
311  // use boundary of stop center
312  return getChildDemandElements().front()->getCenteringBoundary();
313  } else {
314  personBoundary.add(getPositionInView());
315  }
316  } else {
317  personBoundary = Boundary(-0.1, -0.1, 0.1, 0.1);
318  }
319  personBoundary.grow(20);
320  return personBoundary;
321 }
322 
323 
324 void
325 GNEPerson::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 drawPerson = true;
333  // check if person can be drawn
335  drawPerson = false;
337  drawPerson = false;
339  drawPerson = false;
340  } else if (getChildDemandElements().empty()) {
341  drawPerson = false;
342  }
343  // continue if person can be drawn
344  if (drawPerson) {
345  // obtain exaggeration (and add the special personExaggeration)
346  const double exaggeration = getExaggeration(s) + 10;
347  // obtain position
348  const Position personPosition = getAttributePosition(SUMO_ATTR_DEPARTPOS);
349  if (personPosition == Position::INVALID) {
350  return;
351  }
352  // get detail level
353  const auto d = s.getDetailLevel(exaggeration);
354  // draw geometry only if we'rent in drawForObjectUnderCursor mode
356  // obtain width and length
357  const double length = getTypeParent()->getAttributeDouble(SUMO_ATTR_LENGTH);
358  const double width = getTypeParent()->getAttributeDouble(SUMO_ATTR_WIDTH);
359  // obtain img file
360  const std::string file = getTypeParent()->getAttribute(SUMO_ATTR_IMGFILE);
361  // push draw matrix
363  // Start with the drawing of the area traslating matrix to origin
365  // translate and rotate
366  glTranslated(personPosition.x(), personPosition.y(), 0);
367  glRotated(90, 0, 0, 1);
368  // set person color
370  // set scale
371  glScaled(exaggeration, exaggeration, 1);
372  // draw person depending of detail level
373  if (s.personQuality >= 2) {
374  GUIBasePersonHelper::drawAction_drawAsImage(0, length, width, file, SUMOVehicleShape::PEDESTRIAN, exaggeration);
375  } else if (s.personQuality == 1) {
376  GUIBasePersonHelper::drawAction_drawAsCenteredCircle(length / 2, width / 2, s.scale * exaggeration);
377  } else if (s.personQuality == 0) {
379  }
380  // pop matrix
382  // draw stack label
383  if (myStackedLabelNumber > 0) {
384  drawStackLabel(myStackedLabelNumber, "person", Position(personPosition.x() - 2.5, personPosition.y()), -90, 1.3, 5, getExaggeration(s));
385  } else if ((getChildDemandElements().front()->getTagProperty().getTag() == GNE_TAG_STOPPERSON_BUSSTOP) ||
387  // declare counter for stacked persons over stops
388  int stackedCounter = 0;
389  // get stoppingPlace
390  const auto stoppingPlace = getChildDemandElements().front()->getParentAdditionals().front();
391  // get stacked persons
392  for (const auto& stopPerson : stoppingPlace->getChildDemandElements()) {
393  if ((stopPerson->getTagProperty().getTag() == GNE_TAG_STOPPERSON_BUSSTOP) ||
394  (stopPerson->getTagProperty().getTag() == GNE_TAG_STOPPERSON_TRAINSTOP)) {
395  // get person parent
396  const auto personParent = stopPerson->getParentDemandElements().front();
397  // check if the stop if the first person plan parent
398  if (stopPerson->getPreviousChildDemandElement(personParent) == nullptr) {
399  stackedCounter++;
400  }
401  }
402  }
403  // if we have more than two stacked elements, draw label
404  if (stackedCounter > 1) {
405  drawStackLabel(stackedCounter, "person", Position(personPosition.x() - 2.5, personPosition.y()), -90, 1.3, 5, getExaggeration(s));
406  }
407  }
408  // draw flow label
409  if (myTagProperty.isFlow()) {
410  drawFlowLabel(Position(personPosition.x() - 1, personPosition.y() - 0.25), -90, 1.8, 2, getExaggeration(s));
411  }
412  // draw lock icon
413  GNEViewNetHelper::LockIcon::drawLockIcon(d, this, getType(), personPosition, exaggeration, s.dottedContourSettings.segmentWidth);
414  // draw name
415  drawName(personPosition, s.scale, s.personName, s.angle);
416  if (s.personValue.show(this)) {
417  Position personValuePosition = personPosition + Position(0, 0.6 * s.personName.scaledSize(s.scale));
418  const double value = getColorValue(s, s.personColorer.getActive());
419  GLHelper::drawTextSettings(s.personValue, toString(value), personValuePosition, s.scale, s.angle, GLO_MAX - getType());
420  }
421  // draw dotted contour
423  }
424  // calculate contour
425  myPersonContour.calculateContourRectangleShape(s, d, this, personPosition, 0.1, 0.2, -1.1, 0, 0, exaggeration);
426  }
427 }
428 
429 
430 void
432  // compute all person plan children (because aren't computed in "computeDemandElements()")
433  for (const auto& demandElement : getChildDemandElements()) {
434  demandElement->computePathElement();
435  }
436 }
437 
438 
439 void
440 GNEPerson::drawLanePartialGL(const GUIVisualizationSettings& /*s*/, const GNEPathManager::Segment* /*segment*/, const double /*offsetFront*/) const {
441  // Stops don't use drawJunctionPartialGL
442 }
443 
444 
445 void
446 GNEPerson::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 person plan
454  return getChildDemandElements().front()->getFirstPathLane();
455 }
456 
457 
458 GNELane*
460  // use path lane of first person 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  // Others
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 person plan
521  const GNEDemandElement* personPlan = getChildDemandElements().front();
522  // first check if first person plan is a stop
523  if (personPlan->getTagProperty().isPlanStopPerson()) {
524  // stop center
525  return personPlan->getPositionInView();
526  } else if (personPlan->getTagProperty().planFromTAZ()) {
527  // TAZ
528  if (personPlan->getParentAdditionals().front()->getAttribute(SUMO_ATTR_CENTER).empty()) {
529  return personPlan->getParentAdditionals().front()->getAttributePosition(GNE_ATTR_TAZ_CENTROID);
530  } else {
531  return personPlan->getParentAdditionals().front()->getAttributePosition(SUMO_ATTR_CENTER);
532  }
533  } else if (personPlan->getTagProperty().planFromJunction()) {
534  // juncrtion
535  return personPlan->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 GNEPerson::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 GNEPerson::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, toString(SUMO_TAG_PERSON), 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  return getTagStr() + ": " + getAttribute(SUMO_ATTR_ID);
621 }
622 
623 
624 const Parameterised::Map&
626  return getParametersMap();
627 }
628 
629 // ===========================================================================
630 // protected
631 // ===========================================================================
632 
633 RGBColor
637  } else {
638  return getColorByScheme(s.personColorer, this);
639  }
640 }
641 
642 // ===========================================================================
643 // private
644 // ===========================================================================
645 
647  personPlan(_personPlan),
648  edge(nullptr),
649  arrivalPos(-1) {
650 }
651 
652 
654  personPlan(nullptr),
655  edge(nullptr),
656  arrivalPos(-1) {
657 }
658 
659 
660 void
661 GNEPerson::setAttribute(SumoXMLAttr key, const std::string& value) {
662  // declare string error
663  std::string error;
664  switch (key) {
665  case SUMO_ATTR_ID:
666  // update microsimID
667  setDemandElementID(value);
668  // update id
669  id = value;
670  break;
671  case SUMO_ATTR_TYPE:
672  if (getID().size() > 0) {
674  // set manually vtypeID (needed for saving)
675  vtypeid = value;
676  }
677  break;
678  case SUMO_ATTR_COLOR:
679  if (!value.empty() && (value != myTagProperty.getDefaultValue(key))) {
680  color = parse<RGBColor>(value);
681  // mark parameter as set
683  } else {
684  // set default value
685  color = parse<RGBColor>(myTagProperty.getDefaultValue(key));
686  // unset parameter
688  }
689  break;
690  case SUMO_ATTR_DEPARTPOS:
691  if (!value.empty() && (value != myTagProperty.getDefaultValue(key))) {
693  // mark parameter as set
695  } else {
696  // set default value
698  // unset parameter
700  }
701  // compute person
702  updateGeometry();
703  break;
704  // Other
705  case GNE_ATTR_SELECTED:
706  if (parse<bool>(value)) {
708  } else {
710  }
711  break;
712  case GNE_ATTR_PARAMETERS:
713  setParametersStr(value);
714  break;
715  default:
716  setFlowAttribute(this, key, value);
717  break;
718  }
719 }
720 
721 
722 void
723 GNEPerson::toggleAttribute(SumoXMLAttr key, const bool value) {
724  // toggle flow attributes
725  toggleFlowAttribute(key, value);
726 }
727 
728 
729 void
731  // change departPos
733  departPos = moveResult.newFirstPos;
734  // update geometry
735  updateGeometry();
736 }
737 
738 
739 void
740 GNEPerson::commitMoveShape(const GNEMoveResult& moveResult, GNEUndoList* undoList) {
741  undoList->begin(this, "departPos of " + getTagStr());
742  // now set departPos
743  setAttribute(SUMO_ATTR_DEPARTPOS, toString(moveResult.newFirstPos), undoList);
744  undoList->end();
745 }
746 
747 /****************************************************************************/
FXDEFMAP(GNEPerson::GNEPersonPopupMenu) personPopupMenuMap[]
@ MID_COPY_TYPED_NAME
Copy typed object name - popup entry.
Definition: GUIAppEnum.h:455
@ MID_GNE_PERSON_TRANSFORM
transform person to another person type (ej: person to personflow)
Definition: GUIAppEnum.h:1406
@ MID_COPY_NAME
Copy object name - popup entry.
Definition: GUIAppEnum.h:453
@ GLO_MAX
empty max
@ GLO_PERSON
a person
@ GLO_PERSONFLOW
a person flow
GUIIcon
An enumeration of icons used by the gui applications.
Definition: GUIIcons.h:33
const std::string DEFAULT_PEDTYPE_ID
@ PEDESTRIAN
render as a pedestrian
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
@ GNE_TAG_STOPPERSON_BUSSTOP
@ SUMO_TAG_PERSON
@ GNE_TAG_STOPPERSON_TRAINSTOP
@ SUMO_TAG_PERSONFLOW
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_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
@ SUMO_ATTR_PERSONSPERHOUR
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 void pushMatrix()
push matrix
Definition: GLHelper.cpp:117
static void drawTextSettings(const GUIVisualizationTextSettings &settings, const std::string &text, const Position &pos, const double scale, const double angle=0, const double layer=2048, const int align=0)
Definition: GLHelper.cpp:787
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
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
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
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
GNEViewNet * getViewNet() const
get view net
Definition: GNENet.cpp:2136
PathElement()=delete
invalidate default constructor
class used in GUIGLObjectPopupMenu for person transformations
Definition: GNEPerson.h:36
long onCmdTransform(FXObject *obj, FXSelector, void *)
Called to transform the current person to another person type.
Definition: GNEPerson.cpp:93
~GNEPersonPopupMenu()
Destructor.
Definition: GNEPerson.cpp:89
class used in GUIGLObjectPopupMenu for single person transformations
Definition: GNEPerson.h:68
GNESelectedPersonsPopupMenu(GNEPerson *person, const std::vector< GNEPerson * > &selectedPerson, GUIMainWindow &app, GUISUMOAbstractView &parent)
Constructor.
Definition: GNEPerson.cpp:107
long onCmdTransform(FXObject *obj, FXSelector, void *)
Called to transform the current person to another person type.
Definition: GNEPerson.cpp:142
FXMenuCommand * myTransformToPerson
menu command for transform to person
Definition: GNEPerson.h:97
FXMenuCommand * myTransformToPersonFlow
menu command for transform to personFlow
Definition: GNEPerson.h:100
void drawGL(const GUIVisualizationSettings &s) const
Draws the object.
Definition: GNEPerson.cpp:331
void commitMoveShape(const GNEMoveResult &moveResult, GNEUndoList *undoList)
commit move shape
Definition: GNEPerson.cpp:740
GNEMoveOperation * getMoveOperation()
get move operation
Definition: GNEPerson.cpp:186
Position getPositionInView() const
Returns position of demand element in view.
Definition: GNEPerson.cpp:282
void updateGeometry()
update pre-computed geometry information
Definition: GNEPerson.cpp:273
double getExaggeration(const GUIVisualizationSettings &s) const
return exaggeration associated with this GLObject
Definition: GNEPerson.cpp:301
const RGBColor & getColor() const
get color
Definition: GNEPerson.cpp:267
bool isAttributeEnabled(SumoXMLAttr key) const
Definition: GNEPerson.cpp:607
void writeDemandElement(OutputDevice &device) const
write demand element element into a xml file
Definition: GNEPerson.cpp:208
GNELane * getLastPathLane() const
get last path lane
Definition: GNEPerson.cpp:459
Position getAttributePosition(SumoXMLAttr key) const
Definition: GNEPerson.cpp:513
void fixDemandElementProblem()
fix demand element problem (by default throw an exception, has to be reimplemented in children)
Definition: GNEPerson.cpp:255
void toggleAttribute(SumoXMLAttr key, const bool value)
method for enable or disable the attribute and nothing else (used in GNEChange_ToggleAttribute)
Definition: GNEPerson.cpp:723
void setMoveShape(const GNEMoveResult &moveResult)
set move shape
Definition: GNEPerson.cpp:730
std::string getHierarchyName() const
get Hierarchy Name (Used in AC Hierarchy)
Definition: GNEPerson.cpp:619
RGBColor getDrawingColor(const GUIVisualizationSettings &s) const
get drawing color
Definition: GNEPerson.cpp:634
void enableAttribute(SumoXMLAttr key, GNEUndoList *undoList)
Definition: GNEPerson.cpp:595
~GNEPerson()
destructor
Definition: GNEPerson.cpp:182
SUMOVehicleClass getVClass() const
obtain VClass related with this demand element
Definition: GNEPerson.cpp:261
void computePathElement()
compute pathElement
Definition: GNEPerson.cpp:431
std::string getParentName() const
Returns the name of the parent object.
Definition: GNEPerson.cpp:295
GNEContour myPersonContour
variable used for contours
Definition: GNEPerson.h:278
bool isValid(SumoXMLAttr key, const std::string &value)
method for checking if the key and their conrrespond attribute are valids
Definition: GNEPerson.cpp:566
void splitEdgeGeometry(const double splitPosition, const GNENetworkElement *originalElement, const GNENetworkElement *newElement, GNEUndoList *undoList)
split geometry
Definition: GNEPerson.cpp:325
void disableAttribute(SumoXMLAttr key, GNEUndoList *undoList)
Definition: GNEPerson.cpp:601
void setAttribute(SumoXMLAttr key, const std::string &value, GNEUndoList *undoList)
method for setting the attribute and letting the object perform demand element changes
Definition: GNEPerson.cpp:547
GNEPerson(SumoXMLTag tag, GNENet *net)
default constructor
Definition: GNEPerson.cpp:160
std::string getAttribute(SumoXMLAttr key) const
inherited from GNEAttributeCarrier
Definition: GNEPerson.cpp:466
void drawLanePartialGL(const GUIVisualizationSettings &s, const GNEPathManager::Segment *segment, const double offsetFront) const
Draws partial object over lane.
Definition: GNEPerson.cpp:440
const Parameterised::Map & getACParametersMap() const
get parameters map
Definition: GNEPerson.cpp:625
Boundary getCenteringBoundary() const
Returns the boundary to which the view shall be centered in order to show the object.
Definition: GNEPerson.cpp:307
double getAttributeDouble(SumoXMLAttr key) const
Definition: GNEPerson.cpp:498
Problem isDemandElementValid() const
check if current demand element is valid to be written into XML (by default true, can be reimplemente...
Definition: GNEPerson.cpp:235
GNELane * getFirstPathLane() const
get first path lane
Definition: GNEPerson.cpp:452
GUIGLObjectPopupMenu * getPopUpMenu(GUIMainWindow &app, GUISUMOAbstractView &parent)
Returns an own popup-menu.
Definition: GNEPerson.cpp:288
std::string getDemandElementProblem() const
return a string with the current demand element problem (by default empty, can be reimplemented in ch...
Definition: GNEPerson.cpp:245
void drawJunctionPartialGL(const GUIVisualizationSettings &s, const GNEPathManager::Segment *segment, const double offsetFront) const
Draws partial object over junction.
Definition: GNEPerson.cpp:446
std::string getPopUpID() const
get PopPup ID (Used in AC Hierarchy)
Definition: GNEPerson.cpp:613
static void transformToPerson(GNEPerson *originalPerson)
transform person functions
static void transformToPersonFlow(GNEPerson *originalPerson)
transform routeFlow over an existent route
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
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
bool isPlanStopPerson() const
return true if tag correspond to a person stop plan
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
void buildSelectionACPopupEntry(GUIGLObjectPopupMenu *ret, GNEAttributeCarrier *AC)
Builds an entry which allows to (de)select the object.
Definition: GNEViewNet.cpp:553
const GNEViewNetHelper::DemandViewOptions & getDemandViewOptions() const
get demand view options
Definition: GNEViewNet.cpp:741
static void drawAction_drawAsImage(const double angle, const double length, const double width, const std::string &file, const SUMOVehicleShape guiShape, const double exaggeration)
static void drawAction_drawAsCenteredCircle(const double length, const double width, double detail)
static void drawAction_drawAsTriangle(const double angle, const double length, const double width)
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.
virtual double getColorValue(const GUIVisualizationSettings &, int) const
Definition: GUIGlObject.h:203
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
Stores the information about how to visualize structures.
GUIVisualizationTextSettings personValue
int personQuality
The quality of person drawing.
Detail getDetailLevel(const double exaggeration) const
return the detail level
GUIVisualizationSizeSettings personSize
GUIVisualizationColorSettings colorSettings
color settings
GUIColorer personColorer
The person colorer.
GUIVisualizationDottedContourSettings dottedContourSettings
dotted contour settings
double scale
information about a lane's width (temporary, used for a single view)
bool checkDrawPerson(Detail d, const bool selected) const
check if draw person
GUIVisualizationTextSettings personName
double angle
The current view rotation angle.
static const std::vector< SumoXMLTag > types
type namespace
Definition: NamespaceIDs.h:53
static const std::vector< SumoXMLTag > persons
persons namespace
Definition: NamespaceIDs.h:62
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.
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 selectedPersonColor
person 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
bool show(const GUIGlObject *o) const
whether to show the text
double scaledSize(double scale, double constFactor=0.1) const
get scale size