Eclipse SUMO - Simulation of Urban MObility
GNERerouter.cpp
Go to the documentation of this file.
1 /****************************************************************************/
2 // Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.org/sumo
3 // Copyright (C) 2001-2019 German Aerospace Center (DLR) and others.
4 // This program and the accompanying materials
5 // are made available under the terms of the Eclipse Public License v2.0
6 // which accompanies this distribution, and is available at
7 // http://www.eclipse.org/legal/epl-v20.html
8 // SPDX-License-Identifier: EPL-2.0
9 /****************************************************************************/
14 //
15 /****************************************************************************/
16 
17 // ===========================================================================
18 // included modules
19 // ===========================================================================
20 
21 #include <netedit/GNENet.h>
22 #include <netedit/GNEUndoList.h>
23 #include <netedit/GNEViewNet.h>
26 #include <utils/gui/div/GLHelper.h>
29 
30 #include "GNERerouter.h"
31 
32 
33 // ===========================================================================
34 // member method definitions
35 // ===========================================================================
36 
37 GNERerouter::GNERerouter(const std::string& id, GNEViewNet* viewNet, const Position& pos, const std::vector<GNEEdge*>& edges, const std::string& name, const std::string& filename, double probability, bool off, SUMOTime timeThreshold, const std::string& vTypes, bool blockMovement) :
38  GNEAdditional(id, viewNet, GLO_REROUTER, SUMO_TAG_REROUTER, name, blockMovement, {}, {}, {}, {}, {}, edges, {}, {}, {}, {}),
39  myPosition(pos),
40  myFilename(filename),
41  myProbability(probability),
42  myOff(off),
43  myTimeThreshold(timeThreshold),
44 myVTypes(vTypes) {
45 }
46 
47 
49 }
50 
51 
52 void
54  // Set block icon position
56 
57  // Set block icon offset
58  myBlockIcon.offset = Position(-0.5, -0.5);
59 
60  // Set block icon rotation, and using their rotation for draw logo
62 
63  // update connection positions
65 }
66 
67 
70  return myPosition;
71 }
72 
73 
76  // Return Boundary depending if myMovingGeometryBoundary is initialised (important for move geometry)
79  } else {
80  Boundary b;
81  b.add(myPosition);
82  b.grow(5);
83  return b;
84  }
85 }
86 
87 
88 void
89 GNERerouter::splitEdgeGeometry(const double /*splitPosition*/, const GNENetElement* /*originalElement*/, const GNENetElement* /*newElement*/, GNEUndoList* /*undoList*/) {
90  // geometry of this element cannot be splitted
91 }
92 
93 
94 void
96  // Open rerouter dialog
97  GNERerouterDialog(this);
98 }
99 
100 
101 void
103  // restore old position, apply offset and update Geometry
105  myPosition.add(offset);
106  // filtern position using snap to active grid
108  updateGeometry();
109 }
110 
111 
112 void
114  // commit new position allowing undo/redo
115  undoList->p_begin("position of " + getTagStr());
117  undoList->p_end();
118 }
119 
120 
121 std::string
123  return myViewNet->getNet()->getMicrosimID();
124 }
125 
126 
127 void
129  // Obtain exaggeration of the draw
130  const double exaggeration = s.addSize.getExaggeration(s, this);
131  // first check if additional has to be drawn
132  if (s.drawAdditionals(exaggeration)) {
133  // check if boundary has to be drawn
134  if (s.drawBoundaries) {
136  }
137  // Start drawing adding an gl identificator
138  glPushName(getGlID());
139  // Add a draw matrix for drawing logo
140  glPushMatrix();
141  glTranslated(myPosition.x(), myPosition.y(), getType());
142  // scale
143  glScaled(exaggeration, exaggeration, 1);
144  // Draw icon depending of detector is selected and if isn't being drawn for selecting
145  if (!s.drawForRectangleSelection && s.drawDetail(s.detailSettings.laneTextures, exaggeration)) {
146  glColor3d(1, 1, 1);
147  glRotated(180, 0, 0, 1);
148  if (drawUsingSelectColor()) {
150  } else {
152  }
153  } else {
155  GLHelper::drawBoxLine(Position(0, 1), 0, 2, 1);
156  }
157  // Pop draw matrix
158  glPopMatrix();
159  // Show Lock icon
160  myBlockIcon.drawIcon(s, exaggeration, 0.4);
161  // Draw child connections
163  // check if dotted contour has to be drawn
164  if (myViewNet->getDottedAC() == this) {
166  // draw shape dotte contour aroud alld connections between child and parents
167  for (auto i : myChildConnections.connectionPositions) {
169  }
170  }
171  // Draw name
173  // Pop name
174  glPopName();
175  }
176 }
177 
178 
179 std::string
181  switch (key) {
182  case SUMO_ATTR_ID:
183  return getAdditionalID();
184  case SUMO_ATTR_EDGES:
185  return parseIDs(getChildEdges());
186  case SUMO_ATTR_POSITION:
187  return toString(myPosition);
188  case SUMO_ATTR_NAME:
189  return myAdditionalName;
190  case SUMO_ATTR_FILE:
191  return myFilename;
192  case SUMO_ATTR_PROB:
193  return toString(myProbability);
196  case SUMO_ATTR_VTYPES:
197  return myVTypes;
198  case SUMO_ATTR_OFF:
199  return toString(myOff);
201  return toString(myBlockMovement);
202  case GNE_ATTR_SELECTED:
204  case GNE_ATTR_PARAMETERS:
205  return getParametersStr();
206  default:
207  throw InvalidArgument(getTagStr() + " doesn't have an attribute of type '" + toString(key) + "'");
208  }
209 }
210 
211 
212 double
214  throw InvalidArgument(getTagStr() + " doesn't have a double attribute of type '" + toString(key) + "'");
215 }
216 
217 
218 void
219 GNERerouter::setAttribute(SumoXMLAttr key, const std::string& value, GNEUndoList* undoList) {
220  if (value == getAttribute(key)) {
221  return; //avoid needless changes, later logic relies on the fact that attributes have changed
222  }
223  switch (key) {
224  case SUMO_ATTR_ID: {
225  // change ID of Rerouter Interval
226  undoList->p_add(new GNEChange_Attribute(this, myViewNet->getNet(), key, value));
227  // Change Ids of all Rerouter interval children
228  for (auto i : getChildAdditionals()) {
229  i->setAttribute(SUMO_ATTR_ID, generateChildID(SUMO_TAG_INTERVAL), undoList);
230  }
231  break;
232  }
233  case SUMO_ATTR_EDGES:
234  case SUMO_ATTR_POSITION:
235  case SUMO_ATTR_NAME:
236  case SUMO_ATTR_FILE:
237  case SUMO_ATTR_PROB:
239  case SUMO_ATTR_VTYPES:
240  case SUMO_ATTR_OFF:
242  case GNE_ATTR_SELECTED:
243  case GNE_ATTR_PARAMETERS:
244  undoList->p_add(new GNEChange_Attribute(this, myViewNet->getNet(), key, value));
245  break;
246  default:
247  throw InvalidArgument(getTagStr() + " doesn't have an attribute of type '" + toString(key) + "'");
248  }
249 }
250 
251 
252 bool
253 GNERerouter::isValid(SumoXMLAttr key, const std::string& value) {
254  switch (key) {
255  case SUMO_ATTR_ID:
256  return isValidAdditionalID(value);
257  case SUMO_ATTR_EDGES:
258  if (value.empty()) {
259  return false;
260  } else {
261  return canParse<std::vector<GNEEdge*> >(myViewNet->getNet(), value, false);
262  }
263  case SUMO_ATTR_POSITION:
264  return canParse<Position>(value);
265  case SUMO_ATTR_NAME:
267  case SUMO_ATTR_FILE:
269  case SUMO_ATTR_PROB:
270  return canParse<double>(value) && (parse<double>(value) >= 0) && (parse<double>(value) <= 1);
272  return canParse<SUMOTime>(value);
273  case SUMO_ATTR_VTYPES:
274  if (value.empty()) {
275  return true;
276  } else {
278  }
279  case SUMO_ATTR_OFF:
280  return canParse<bool>(value);
282  return canParse<bool>(value);
283  case GNE_ATTR_SELECTED:
284  return canParse<bool>(value);
285  case GNE_ATTR_PARAMETERS:
286  return Parameterised::areParametersValid(value);
287  default:
288  throw InvalidArgument(getTagStr() + " doesn't have an attribute of type '" + toString(key) + "'");
289  }
290 }
291 
292 
293 bool
295  return true;
296 }
297 
298 
299 std::string
301  return getTagStr() + ": " + getID();
302 }
303 
304 
305 std::string
307  return getTagStr();
308 }
309 
310 // ===========================================================================
311 // private
312 // ===========================================================================
313 
314 void
315 GNERerouter::setAttribute(SumoXMLAttr key, const std::string& value) {
316  switch (key) {
317  case SUMO_ATTR_ID:
318  changeAdditionalID(value);
319  break;
320  case SUMO_ATTR_EDGES:
321  changeChildEdges(this, value);
322  break;
323  case SUMO_ATTR_POSITION:
325  myPosition = parse<Position>(value);
327  break;
328  case SUMO_ATTR_NAME:
329  myAdditionalName = value;
330  break;
331  case SUMO_ATTR_FILE:
332  myFilename = value;
333  break;
334  case SUMO_ATTR_PROB:
335  myProbability = parse<double>(value);
336  break;
338  myTimeThreshold = parse<SUMOTime>(value);
339  break;
340  case SUMO_ATTR_VTYPES:
341  myVTypes = value;
342  break;
343  case SUMO_ATTR_OFF:
344  myOff = parse<bool>(value);
345  break;
347  myBlockMovement = parse<bool>(value);
348  break;
349  case GNE_ATTR_SELECTED:
350  if (parse<bool>(value)) {
352  } else {
354  }
355  break;
356  case GNE_ATTR_PARAMETERS:
357  setParametersStr(value);
358  break;
359  default:
360  throw InvalidArgument(getTagStr() + " doesn't have an attribute of type '" + toString(key) + "'");
361  }
362 }
363 
364 /****************************************************************************/
GUIGlObject::getType
GUIGlObjectType getType() const
Returns the type of the object as coded in GUIGlObjectType.
Definition: GUIGlObject.cpp:180
SUMOXMLDefinitions::isValidAttribute
static bool isValidAttribute(const std::string &value)
whether the given string is a valid attribute for a certain key (for example, a name)
Definition: SUMOXMLDefinitions.cpp:995
GNERerouterDialog.h
GNEAdditional::BlockIcon::position
Position position
position of the block icon
Definition: GNEAdditional.h:318
GNERerouter::myFilename
std::string myFilename
filename of rerouter
Definition: GNERerouter.h:145
GNERerouter::drawGL
void drawGL(const GUIVisualizationSettings &s) const
Draws the object.
Definition: GNERerouter.cpp:128
GNERerouter::GNERerouter
GNERerouter(const std::string &id, GNEViewNet *viewNet, const Position &pos, const std::vector< GNEEdge * > &edges, const std::string &name, const std::string &filename, double probability, bool off, SUMOTime timeThreshold, const std::string &vTypes, bool blockMovement)
Constructor.
Definition: GNERerouter.cpp:37
GNEAdditional
An Element which don't belongs to GNENet but has influency in the simulation.
Definition: GNEAdditional.h:48
Parameterised::getParametersStr
std::string getParametersStr() const
Returns the inner key/value map in string format "key1=value1|key2=value2|...|keyN=valueN".
Definition: Parameterised.cpp:112
GNEAdditional::getAdditionalID
const std::string & getAdditionalID() const
Definition: GNEAdditional.cpp:476
GNEAttributeCarrier::getID
const std::string getID() const
function to support debugging
Definition: GNEAttributeCarrier.cpp:1289
GNERerouter::myVTypes
std::string myVTypes
optional vehicle types for restricting the rerouter
Definition: GNERerouter.h:157
SUMOXMLDefinitions::isValidFilename
static bool isValidFilename(const std::string &value)
whether the given string is a valid attribute for a filename (for example, a name)
Definition: SUMOXMLDefinitions.cpp:1001
GNEAdditional::BlockIcon::setRotation
void setRotation(GNELane *additionalLane=nullptr)
set Rotation of block Icon (must be called in updateGeometry() function)
Definition: GNEAdditional.cpp:400
GNEAdditional::AdditionalMove::movingGeometryBoundary
Boundary movingGeometryBoundary
boundary used during moving of elements (to avoid insertion in RTREE
Definition: GNEAdditional.h:288
GUIGlObject::drawName
void drawName(const Position &pos, const double scale, const GUIVisualizationTextSettings &settings, const double angle=0) const
draw name of item
Definition: GUIGlObject.cpp:354
GNEUndoList::p_end
void p_end()
End undo command sub-group. If the sub-group is still empty, it will be deleted; otherwise,...
Definition: GNEUndoList.cpp:79
GUIVisualizationSettings::drawForRectangleSelection
bool drawForRectangleSelection
whether drawing is performed for the purpose of selecting objects using a rectangle
Definition: GUIVisualizationSettings.h:647
GNEAttributeCarrier::parseIDs
static std::string parseIDs(const std::vector< T > &ACs)
parses a list of specific Attribute Carriers into a string of IDs
GUIVisualizationSettings::drawBoundaries
bool drawBoundaries
enable or disable draw boundaries
Definition: GUIVisualizationSettings.h:638
GNENet::removeGLObjectFromGrid
void removeGLObjectFromGrid(GUIGlObject *o)
add GL Object into net
Definition: GNENet.cpp:1328
GNEHierarchicalChildElements::getChildEdges
const std::vector< GNEEdge * > & getChildEdges() const
get child edges
Definition: GNEHierarchicalChildElements.cpp:376
GNEAdditional::generateChildID
std::string generateChildID(SumoXMLTag childTag)
gererate a new ID for an element child
Definition: GNEAdditional.cpp:96
GNEHierarchicalChildElements::drawChildConnections
void drawChildConnections(const GUIVisualizationSettings &s, const GUIGlObjectType GLTypeParent) const
Definition: GNEHierarchicalChildElements.cpp:89
GNERerouterDialog
Dialog for edit rerouters.
Definition: GNERerouterDialog.h:44
SUMO_ATTR_OFF
@ SUMO_ATTR_OFF
Definition: SUMOXMLDefinitions.h:764
GNERerouter::getCenteringBoundary
Boundary getCenteringBoundary() const
Returns the boundary to which the view shall be centered in order to show the object.
Definition: GNERerouter.cpp:75
SUMOTime
long long int SUMOTime
Definition: SUMOTime.h:34
GNEViewNet
Definition: GNEViewNet.h:42
GNERerouter::getHierarchyName
std::string getHierarchyName() const
get Hierarchy Name (Used in AC Hierarchy)
Definition: GNERerouter.cpp:306
SUMO_ATTR_ID
@ SUMO_ATTR_ID
Definition: SUMOXMLDefinitions.h:378
GLHelper.h
GNEAdditional::changeAdditionalID
void changeAdditionalID(const std::string &newID)
change ID of additional
Definition: GNEAdditional.cpp:502
GNEAdditional::unselectAttributeCarrier
void unselectAttributeCarrier(bool changeFlag=true)
unselect attribute carrier using GUIGlobalSelection
Definition: GNEAdditional.cpp:532
GNEAdditional::myBlockIcon
BlockIcon myBlockIcon
variable BlockIcon
Definition: GNEAdditional.h:353
GLHelper::setColor
static void setColor(const RGBColor &c)
Sets the gl-color to this value.
Definition: GLHelper.cpp:621
SUMO_ATTR_FILE
@ SUMO_ATTR_FILE
Definition: SUMOXMLDefinitions.h:664
GNERerouter::isValid
bool isValid(SumoXMLAttr key, const std::string &value)
method for checking if the key and their conrrespond attribute are valids
Definition: GNERerouter.cpp:253
GNERerouter::isAttributeEnabled
bool isAttributeEnabled(SumoXMLAttr key) const
Definition: GNERerouter.cpp:294
GUISUMOAbstractView::snapToActiveGrid
Position snapToActiveGrid(const Position &pos, bool snapXY=true) const
Returns a position that is mapped to the closest grid point if the grid is active.
Definition: GUISUMOAbstractView.cpp:196
GNERerouter::getPositionInView
Position getPositionInView() const
Returns position of additional in view.
Definition: GNERerouter.cpp:69
GUITexturesHelper::drawTexturedBox
static void drawTexturedBox(int which, double size)
Draws a named texture as a box with the given size.
Definition: GUITexturesHelper.cpp:72
GNEAdditional::myMove
AdditionalMove myMove
variable AdditionalMove
Definition: GNEAdditional.h:344
GNEAdditional::myViewNet
GNEViewNet * myViewNet
The GNEViewNet this additional element belongs.
Definition: GNEAdditional.h:335
GLHelper::drawBoundary
static void drawBoundary(const Boundary &b)
Draw a boundary (used for debugging)
Definition: GLHelper.cpp:817
GNEAttributeCarrier::GNEChange_Attribute
friend class GNEChange_Attribute
declare friend class
Definition: GNEAttributeCarrier.h:57
GNEUndoList::p_add
void p_add(GNEChange_Attribute *cmd)
special method, avoid empty changes, always execute
Definition: GNEUndoList.cpp:131
GNEViewNet::getNet
GNENet * getNet() const
get the net object
Definition: GNEViewNet.cpp:1014
GNEAdditional::isAttributeCarrierSelected
bool isAttributeCarrierSelected() const
check if attribute carrier is selected
Definition: GNEAdditional.cpp:548
GNEHierarchicalChildElements::ChildConnections::update
void update()
update Connection's geometry
Definition: GNEHierarchicalChildElements.cpp:517
GUIVisualizationSettings::addName
GUIVisualizationTextSettings addName
Definition: GUIVisualizationSettings.h:591
SUMO_ATTR_PROB
@ SUMO_ATTR_PROB
Definition: SUMOXMLDefinitions.h:629
GNERerouter::myTimeThreshold
SUMOTime myTimeThreshold
attribute to configure activation time threshold
Definition: GNERerouter.h:154
GUIVisualizationSettings::detailSettings
GUIVisualizationDetailSettings detailSettings
detail settings
Definition: GUIVisualizationSettings.h:683
GNEAdditional::selectAttributeCarrier
void selectAttributeCarrier(bool changeFlag=true)
Definition: GNEAdditional.cpp:517
GNERerouter::myPosition
Position myPosition
position of rerouter in view
Definition: GNERerouter.h:142
GNEViewNet.h
GUIGlObject::getGlID
GUIGlID getGlID() const
Returns the numerical id of the object.
Definition: GUIGlObject.cpp:149
GNEViewNet::getDottedAC
const GNEAttributeCarrier * getDottedAC() const
get AttributeCarrier under cursor
Definition: GNEViewNet.cpp:1026
SUMO_ATTR_EDGES
@ SUMO_ATTR_EDGES
the edges of a route
Definition: SUMOXMLDefinitions.h:427
Boundary
A class that stores a 2D geometrical boundary.
Definition: Boundary.h:41
GNERerouter::getAttribute
std::string getAttribute(SumoXMLAttr key) const
Definition: GNERerouter.cpp:180
GNE_ATTR_PARAMETERS
@ GNE_ATTR_PARAMETERS
parameters "key1=value1|key2=value2|...|keyN=valueN"
Definition: SUMOXMLDefinitions.h:989
GUITextureSubSys::getTexture
static GUIGlID getTexture(GUITexture which)
returns a texture previously defined in the enum GUITexture
Definition: GUITextureSubSys.cpp:101
GLHelper::drawShapeDottedContourRectangle
static void drawShapeDottedContourRectangle(const GUIVisualizationSettings &s, const int type, const Position &center, const double width, const double height, const double rotation=0, const double offsetX=0, const double offsetY=0)
draw a dotted contour around the given Position with certain width and height
Definition: GLHelper.cpp:560
GUIVisualizationSettings::scale
double scale
information about a lane's width (temporary, used for a single view)
Definition: GUIVisualizationSettings.h:632
GNERerouter::moveGeometry
void moveGeometry(const Position &offset)
change the position of the element geometry without saving in undoList
Definition: GNERerouter.cpp:102
Position
A point in 2D or 3D with translation and scaling methods.
Definition: Position.h:38
Position::x
double x() const
Returns the x-position.
Definition: Position.h:56
GNERerouter::~GNERerouter
~GNERerouter()
Destructor.
Definition: GNERerouter.cpp:48
Boundary::add
void add(double x, double y, double z=0)
Makes the boundary include the given coordinate.
Definition: Boundary.cpp:78
time2string
std::string time2string(SUMOTime t)
Definition: SUMOTime.cpp:67
GNERerouter::myProbability
double myProbability
probability of rerouter
Definition: GNERerouter.h:148
GNEAdditional::myAdditionalName
std::string myAdditionalName
name of additional
Definition: GNEAdditional.h:347
GNERerouter::getParentName
std::string getParentName() const
Returns the name of the parent object (if any)
Definition: GNERerouter.cpp:122
RGBColor::RED
static const RGBColor RED
named colors
Definition: RGBColor.h:189
SUMO_TAG_REROUTER
@ SUMO_TAG_REROUTER
A rerouter.
Definition: SUMOXMLDefinitions.h:95
GNENetElement
Definition: GNENetElement.h:43
GNEHierarchicalChildElements::changeChildEdges
void changeChildEdges(GNEAdditional *elementChild, const std::string &newEdgeIDs)
change child edges of an additional
Definition: GNEHierarchicalChildElements.cpp:462
GUIVisualizationDetailSettings::laneTextures
static const double laneTextures
details for lane textures
Definition: GUIVisualizationSettings.h:283
GNEAdditional::myBlockMovement
bool myBlockMovement
boolean to check if additional element is blocked (i.e. cannot be moved with mouse)
Definition: GNEAdditional.h:350
GLHelper::drawShapeDottedContourAroundShape
static void drawShapeDottedContourAroundShape(const GUIVisualizationSettings &s, const int type, const PositionVector &shape, const double width)
draw a dotted contour around the given Non closed shape with certain width
Definition: GLHelper.cpp:461
GNERerouter::getAttributeDouble
double getAttributeDouble(SumoXMLAttr key) const
Definition: GNERerouter.cpp:213
SUMO_ATTR_POSITION
@ SUMO_ATTR_POSITION
Definition: SUMOXMLDefinitions.h:660
GNERerouter::setAttribute
void setAttribute(SumoXMLAttr key, const std::string &value, GNEUndoList *undoList)
method for setting the attribute and letting the object perform additional changes
Definition: GNERerouter.cpp:219
Parameterised::setParametersStr
void setParametersStr(const std::string &paramsString)
set the inner key/value map in string format "key1=value1|key2=value2|...|keyN=valueN"
Definition: Parameterised.cpp:139
GLIncludes.h
toString
std::string toString(const T &t, std::streamsize accuracy=gPrecision)
Definition: ToString.h:47
GNEAdditional::BlockIcon::drawIcon
void drawIcon(const GUIVisualizationSettings &s, const double exaggeration, const double size=0.5) const
draw lock icon
Definition: GNEAdditional.cpp:416
GNENet::addGLObjectIntoGrid
void addGLObjectIntoGrid(GUIGlObject *o)
add GL Object into net
Definition: GNENet.cpp:1322
GNERerouter::commitGeometryMoving
void commitGeometryMoving(GNEUndoList *undoList)
commit geometry changes in the attributes of an element after use of moveGeometry(....
Definition: GNERerouter.cpp:113
Position::y
double y() const
Returns the y-position.
Definition: Position.h:61
SUMO_ATTR_HALTING_TIME_THRESHOLD
@ SUMO_ATTR_HALTING_TIME_THRESHOLD
Definition: SUMOXMLDefinitions.h:750
GNEHierarchicalChildElements::myChildConnections
ChildConnections myChildConnections
variable ChildConnections
Definition: GNEHierarchicalChildElements.h:237
GNETEXTURE_REROUTER
@ GNETEXTURE_REROUTER
Definition: GUITextures.h:42
Parameterised::areParametersValid
static bool areParametersValid(const std::string &value, bool report=false)
check if given string can be parsed to a parameters map "key1=value1|key2=value2|....
Definition: Parameterised.cpp:166
SUMO_ATTR_VTYPES
@ SUMO_ATTR_VTYPES
Definition: SUMOXMLDefinitions.h:632
InvalidArgument
Definition: UtilExceptions.h:56
GLHelper::drawBoxLine
static void drawBoxLine(const Position &beg, double rot, double visLength, double width, double offset=0)
Draws a thick line.
Definition: GLHelper.cpp:136
GLO_REROUTER
@ GLO_REROUTER
a Rerouter
Definition: GUIGlObjectTypes.h:85
GNE_ATTR_BLOCK_MOVEMENT
@ GNE_ATTR_BLOCK_MOVEMENT
block movement of a graphic element
Definition: SUMOXMLDefinitions.h:981
GNETEXTURE_REROUTERSELECTED
@ GNETEXTURE_REROUTERSELECTED
Definition: GUITextures.h:43
GUIVisualizationSettings::drawAdditionals
bool drawAdditionals(const double exaggeration) const
check if additionals must be drawn
Definition: GUIVisualizationSettings.cpp:1663
GNERerouter.h
GNEAdditional::drawUsingSelectColor
bool drawUsingSelectColor() const
check if attribute carrier must be drawn using selecting color.
Definition: GNEAdditional.cpp:554
GUIVisualizationSettings::addSize
GUIVisualizationSizeSettings addSize
Definition: GUIVisualizationSettings.h:589
Position::add
void add(const Position &pos)
Adds the given position to this one.
Definition: Position.h:126
Boundary::isInitialised
bool isInitialised() const
check if Boundary is Initialised
Definition: Boundary.cpp:216
GNE_ATTR_SELECTED
@ GNE_ATTR_SELECTED
element is selected
Definition: SUMOXMLDefinitions.h:971
GNERerouter::openAdditionalDialog
void openAdditionalDialog()
open GNERerouterDialog
Definition: GNERerouter.cpp:95
Boundary::grow
Boundary & grow(double by)
extends the boundary by the given amount
Definition: Boundary.cpp:300
GUIVisualizationSettings::drawDetail
bool drawDetail(const double detail, const double exaggeration) const
check if details can be drawn for the given GUIVisualizationDetailSettings and current scale and exxa...
Definition: GUIVisualizationSettings.cpp:1669
SUMO_TAG_INTERVAL
@ SUMO_TAG_INTERVAL
an aggreagated-output interval
Definition: SUMOXMLDefinitions.h:159
GNEAttributeCarrier::getTagStr
const std::string & getTagStr() const
get tag assigned to this object in string format
Definition: GNEAttributeCarrier.cpp:1267
SUMOXMLDefinitions::isValidListOfTypeID
static bool isValidListOfTypeID(const std::string &value)
whether the given string is a valid list of ids for an edge or vehicle type (empty aren't allowed)
Definition: SUMOXMLDefinitions.cpp:1024
SUMO_ATTR_NAME
@ SUMO_ATTR_NAME
Definition: SUMOXMLDefinitions.h:380
GNEUndoList
Definition: GNEUndoList.h:48
GUIVisualizationSettings
Stores the information about how to visualize structures.
Definition: GUIVisualizationSettings.h:345
GNEAdditional::isValidAdditionalID
bool isValidAdditionalID(const std::string &newID) const
check if a new additional ID is valid
Definition: GNEAdditional.cpp:482
GNEUndoList::p_begin
void p_begin(const std::string &description)
Begin undo command sub-group. This begins a new group of commands that are treated as a single comman...
Definition: GNEUndoList.cpp:72
SumoXMLAttr
SumoXMLAttr
Numbers representing SUMO-XML - attributes.
Definition: SUMOXMLDefinitions.h:372
GNEAdditional::AdditionalMove::originalViewPosition
Position originalViewPosition
value for saving first original position over lane before moving
Definition: GNEAdditional.h:291
GUIGlObject::getMicrosimID
virtual const std::string & getMicrosimID() const
Returns the id of the object as known to microsim.
Definition: GUIGlObject.cpp:163
GNERerouter::updateGeometry
void updateGeometry()
update pre-computed geometry information
Definition: GNERerouter.cpp:53
GUITextureSubSys.h
GNEHierarchicalChildElements::getChildAdditionals
const std::vector< GNEAdditional * > & getChildAdditionals() const
return child additionals
Definition: GNEHierarchicalChildElements.cpp:131
GNEChange_Attribute.h
GNENet.h
GNERerouter::splitEdgeGeometry
void splitEdgeGeometry(const double splitPosition, const GNENetElement *originalElement, const GNENetElement *newElement, GNEUndoList *undoList)
split geometry
Definition: GNERerouter.cpp:89
GUIVisualizationSizeSettings::getExaggeration
double getExaggeration(const GUIVisualizationSettings &s, const GUIGlObject *o, double factor=20) const
return the drawing size including exaggeration and constantSize values
Definition: GUIVisualizationSettings.cpp:212
GNEAdditional::BlockIcon::offset
Position offset
The offSet of the block icon.
Definition: GNEAdditional.h:321
GNERerouter::getPopUpID
std::string getPopUpID() const
get PopPup ID (Used in AC Hierarchy)
Definition: GNERerouter.cpp:300
GNEHierarchicalChildElements::ChildConnections::connectionPositions
std::vector< PositionVector > connectionPositions
Matrix with the Vertex's positions of connections between parents an their children.
Definition: GNEHierarchicalChildElements.h:223
GNEUndoList.h
GNERerouter::myOff
bool myOff
attribute to enable or disable inactive initially
Definition: GNERerouter.h:151