Eclipse SUMO - Simulation of Urban MObility
GNERouteProbe.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 #include <config.h>
21 
23 #include <utils/gui/div/GLHelper.h>
24 #include <netedit/GNEViewNet.h>
27 #include <netedit/GNEUndoList.h>
28 #include <netedit/GNENet.h>
31 
32 #include "GNERouteProbe.h"
33 
34 
35 // ===========================================================================
36 // member method definitions
37 // ===========================================================================
38 
39 GNERouteProbe::GNERouteProbe(const std::string& id, GNEViewNet* viewNet, GNEEdge* edge, const std::string& frequency, const std::string& name, const std::string& filename, SUMOTime begin) :
40  GNEAdditional(id, viewNet, GLO_ROUTEPROBE, SUMO_TAG_ROUTEPROBE, name, false, {
41  edge
42 }, {}, {}, {}, {}, {}, {}, {}, {}, {}),
43 myFrequency(frequency),
44 myFilename(filename),
45 myBegin(begin),
46 myRelativePositionY(0) {
47 }
48 
49 
51 }
52 
53 
54 void
56  // obtain relative position of routeProbe in edge
57  myRelativePositionY = 2 * getParentEdges().front()->getRouteProbeRelativePosition(this);
58 
59  // get lanes of edge
60  GNELane* firstLane = getParentEdges().front()->getLanes().at(0);
61 
62  // Get shape of parent lane
63  const double offset = firstLane->getLaneShape().length() < 0.5 ? firstLane->getLaneShape().length() : 0.5;
64 
65  // update geometry
67 
68  // Set block icon position
70 
71  // Set offset of the block icon
73 
74  // Set block icon rotation, and using their rotation for logo
75  myBlockIcon.setRotation(firstLane);
76 }
77 
78 
81  if (getParentEdges().front()->getLanes().front()->getLaneShape().length() < 0.5) {
82  return getParentEdges().front()->getLanes().front()->getLaneShape().front();
83  } else {
84  Position A = getParentEdges().front()->getLanes().front()->getLaneShape().positionAtOffset(0.5);
85  Position B = getParentEdges().front()->getLanes().back()->getLaneShape().positionAtOffset(0.5);
86  // return Middle point
87  return Position((A.x() + B.x()) / 2, (A.y() + B.y()) / 2);
88  }
89 }
90 
91 
95 }
96 
97 
98 void
99 GNERouteProbe::splitEdgeGeometry(const double /*splitPosition*/, const GNENetElement* /*originalElement*/, const GNENetElement* /*newElement*/, GNEUndoList* /*undoList*/) {
100  // geometry of this element cannot be splitted
101 }
102 
103 
104 void
106  // This additional cannot be moved
107 }
108 
109 
110 void
112  // This additional cannot be moved
113 }
114 
115 
116 std::string
118  return getParentEdges().front()->getMicrosimID();
119 }
120 
121 
122 void
124  // Obtain exaggeration of the draw
125  const double exaggeration = s.addSize.getExaggeration(s, this);
126  // first check if additional has to be drawn
127  if (s.drawAdditionals(exaggeration)) {
128  // get values
129  const double width = (double) 2.0 * s.scale;
130  const int numberOfLanes = int(getParentEdges().front()->getLanes().size());
131  // start drawing
132  glPushName(getGlID());
133  glLineWidth(1.0);
134  // set color
135  if (drawUsingSelectColor()) {
137  } else {
139  }
140  // draw shape
141  glPushMatrix();
142  glTranslated(0, 0, getType());
144  glRotated(myAdditionalGeometry.getRotation(), 0, 0, 1);
145  glScaled(exaggeration, exaggeration, 1);
146  glTranslated(-1.6, -1.6, 0);
147  glBegin(GL_QUADS);
148  glVertex2d(0, 0.25);
149  glVertex2d(0, -0.25);
150  glVertex2d((numberOfLanes * 3.3), -0.25);
151  glVertex2d((numberOfLanes * 3.3), 0.25);
152  glEnd();
153  glTranslated(0, 0, .01);
154  glBegin(GL_LINES);
155  glVertex2d(0, 0.25 - .1);
156  glVertex2d(0, -0.25 + .1);
157  glEnd();
158  // position indicator (White)
159  if ((width * exaggeration > 1) && !s.drawForRectangleSelection) {
160  if (drawUsingSelectColor()) {
162  } else {
164  }
165  glRotated(90, 0, 0, -1);
166  glBegin(GL_LINES);
167  glVertex2d(0, 0);
168  glVertex2d(0, (numberOfLanes * 3.3));
169  glEnd();
170  }
171  // Pop shape matrix
172  glPopMatrix();
173  // Add a draw matrix for drawing logo
174  glPushMatrix();
176  glRotated(myAdditionalGeometry.getRotation(), 0, 0, 1);
177  glTranslated((-2.56) - myRelativePositionY, (-1.6), 0);
178  // Draw icon depending of Route Probe is selected and if isn't being drawn for selecting
179  if (!s.drawForRectangleSelection && s.drawDetail(s.detailSettings.laneTextures, exaggeration)) {
180  glColor3d(1, 1, 1);
181  glRotated(-90, 0, 0, 1);
182  if (drawUsingSelectColor()) {
184  } else {
186  }
187  } else {
189  GLHelper::drawBoxLine(Position(0, 1), 0, 2, 1);
190  }
191  // Pop logo matrix
192  glPopMatrix();
193  // Show Lock icon depending of the Edit mode
194  myBlockIcon.drawIcon(s, exaggeration, 0.4);
195  // draw name
197  // check if dotted contour has to be drawn
198  if (myViewNet->getDottedAC() == this) {
200  }
201  // pop name
202  glPopName();
203  }
204 }
205 
206 
207 std::string
209  switch (key) {
210  case SUMO_ATTR_ID:
211  return getAdditionalID();
212  case SUMO_ATTR_EDGE:
213  return getParentEdges().front()->getID();
214  case SUMO_ATTR_NAME:
215  return myAdditionalName;
216  case SUMO_ATTR_FILE:
217  return myFilename;
218  case SUMO_ATTR_FREQUENCY:
219  return toString(myFrequency);
220  case SUMO_ATTR_BEGIN:
221  return time2string(myBegin);
222  case GNE_ATTR_SELECTED:
224  case GNE_ATTR_PARAMETERS:
225  return getParametersStr();
226  default:
227  throw InvalidArgument(getTagStr() + " doesn't have an attribute of type '" + toString(key) + "'");
228  }
229 }
230 
231 
232 double
234  switch (key) {
235  case SUMO_ATTR_BEGIN:
236  return STEPS2TIME(myBegin);
237  default:
238  throw InvalidArgument(getTagStr() + " doesn't have a double attribute of type '" + toString(key) + "'");
239  }
240 }
241 
242 
243 void
244 GNERouteProbe::setAttribute(SumoXMLAttr key, const std::string& value, GNEUndoList* undoList) {
245  if (value == getAttribute(key)) {
246  return; //avoid needless changes, later logic relies on the fact that attributes have changed
247  }
248  switch (key) {
249  case SUMO_ATTR_ID:
250  case SUMO_ATTR_EDGE:
251  case SUMO_ATTR_NAME:
252  case SUMO_ATTR_FILE:
253  case SUMO_ATTR_FREQUENCY:
254  case SUMO_ATTR_BEGIN:
255  case GNE_ATTR_SELECTED:
256  case GNE_ATTR_PARAMETERS:
257  undoList->p_add(new GNEChange_Attribute(this, myViewNet->getNet(), key, value));
258  break;
259  default:
260  throw InvalidArgument(getTagStr() + " doesn't have an attribute of type '" + toString(key) + "'");
261  }
262 }
263 
264 
265 bool
267  return true;
268 }
269 
270 
271 std::string
273  return getTagStr();
274 }
275 
276 
277 std::string
279  return getTagStr() + ": " + getAttribute(SUMO_ATTR_BEGIN);
280 }
281 
282 // ===========================================================================
283 // private
284 // ===========================================================================
285 
286 bool
287 GNERouteProbe::isValid(SumoXMLAttr key, const std::string& value) {
288  switch (key) {
289  case SUMO_ATTR_ID:
290  return isValidAdditionalID(value);
291  case SUMO_ATTR_EDGE:
292  if (myViewNet->getNet()->retrieveEdge(value, false) != nullptr) {
293  return true;
294  } else {
295  return false;
296  }
297  case SUMO_ATTR_NAME:
299  case SUMO_ATTR_FILE:
301  case SUMO_ATTR_FREQUENCY:
302  if (value.empty()) {
303  return true;
304  } else {
305  return canParse<SUMOTime>(value);
306  }
307  case SUMO_ATTR_BEGIN:
308  return canParse<SUMOTime>(value);
309  case GNE_ATTR_SELECTED:
310  return canParse<bool>(value);
311  case GNE_ATTR_PARAMETERS:
312  return Parameterised::areParametersValid(value);
313  default:
314  throw InvalidArgument(getTagStr() + " doesn't have an attribute of type '" + toString(key) + "'");
315  }
316 }
317 
318 
319 void
320 GNERouteProbe::setAttribute(SumoXMLAttr key, const std::string& value) {
321  switch (key) {
322  case SUMO_ATTR_ID:
323  changeAdditionalID(value);
324  break;
325  case SUMO_ATTR_EDGE:
326  replaceParentEdges(this, 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_FREQUENCY:
335  myFrequency = value;
336  break;
337  case SUMO_ATTR_BEGIN:
338  myBegin = parse<SUMOTime>(value);
339  break;
340  case GNE_ATTR_SELECTED:
341  if (parse<bool>(value)) {
343  } else {
345  }
346  break;
347  case GNE_ATTR_PARAMETERS:
348  setParametersStr(value);
349  break;
350  default:
351  throw InvalidArgument(getTagStr() + " doesn't have an attribute of type '" + toString(key) + "'");
352  }
353 }
354 
355 /****************************************************************************/
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
GNEAdditional::BlockIcon::position
Position position
position of the block icon
Definition: GNEAdditional.h:318
GNERouteProbe::myBegin
SUMOTime myBegin
begin of rerouter
Definition: GNERouteProbe.h:137
GNEAdditional
An Element which don't belongs to GNENet but has influency in the simulation.
Definition: GNEAdditional.h:48
GNERouteProbe::getPositionInView
Position getPositionInView() const
Returns position of additional in view.
Definition: GNERouteProbe.cpp:80
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
GNEHierarchicalParentElements::replaceParentEdges
void replaceParentEdges(GNEShape *elementChild, const std::string &newEdgeIDs)
replace the parent edges of a shape
Definition: GNEHierarchicalParentElements.cpp:276
GNEAdditional::getAdditionalID
const std::string & getAdditionalID() const
Definition: GNEAdditional.cpp:476
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
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
GNEHierarchicalParentElements::getParentEdges
const std::vector< GNEEdge * > & getParentEdges() const
get parent edges
Definition: GNEHierarchicalParentElements.cpp:181
GUIVisualizationSettings::drawForRectangleSelection
bool drawForRectangleSelection
whether drawing is performed for the purpose of selecting objects using a rectangle
Definition: GUIVisualizationSettings.h:647
GNERouteProbe.h
GNERouteProbe::updateGeometry
void updateGeometry()
update pre-computed geometry information
Definition: GNERouteProbe.cpp:55
GNEGeometry::Geometry::updateGeometryPosition
void updateGeometryPosition(const GNELane *lane, const double posOverLane)
update position and rotation
Definition: GNEGeometry.cpp:100
GNETEXTURE_ROUTEPROBESELECTED
@ GNETEXTURE_ROUTEPROBESELECTED
Definition: GUITextures.h:45
SUMOTime
long long int SUMOTime
Definition: SUMOTime.h:34
SUMO_ATTR_EDGE
@ SUMO_ATTR_EDGE
Definition: SUMOXMLDefinitions.h:423
GNEViewNet
Definition: GNEViewNet.h:42
SUMO_ATTR_ID
@ SUMO_ATTR_ID
Definition: SUMOXMLDefinitions.h:378
PositionVector::length
double length() const
Returns the length.
Definition: PositionVector.cpp:484
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
PositionVector::getBoxBoundary
Boundary getBoxBoundary() const
Returns a boundary enclosing this list of lines.
Definition: PositionVector.cpp:390
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::myViewNet
GNEViewNet * myViewNet
The GNEViewNet this additional element belongs.
Definition: GNEAdditional.h:335
SUMO_ATTR_BEGIN
@ SUMO_ATTR_BEGIN
weights: time range begin
Definition: SUMOXMLDefinitions.h:678
GNEEdge
A road/street connecting two junctions (netedit-version)
Definition: GNEEdge.h:51
GNERouteProbe::splitEdgeGeometry
void splitEdgeGeometry(const double splitPosition, const GNENetElement *originalElement, const GNENetElement *newElement, GNEUndoList *undoList)
split geometry
Definition: GNERouteProbe.cpp:99
GNERouteProbe::GNERouteProbe
GNERouteProbe(const std::string &id, GNEViewNet *viewNet, GNEEdge *edge, const std::string &frequency, const std::string &name, const std::string &filename, SUMOTime begin)
Constructor.
Definition: GNERouteProbe.cpp:39
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
GUIVisualizationSettings::addName
GUIVisualizationTextSettings addName
Definition: GUIVisualizationSettings.h:591
GUIVisualizationSettings::detailSettings
GUIVisualizationDetailSettings detailSettings
detail settings
Definition: GUIVisualizationSettings.h:683
GNETEXTURE_ROUTEPROBE
@ GNETEXTURE_ROUTEPROBE
Definition: GUITextures.h:44
GUIVisualizationColorSettings::selectedAdditionalColor
RGBColor selectedAdditionalColor
additional selection color (busStops, Detectors...)
Definition: GUIVisualizationSettings.h:147
GNEGeometry::Geometry::getShape
const PositionVector & getShape() const
The shape of the additional element.
Definition: GNEGeometry.cpp:147
GNERouteProbe::myFilename
std::string myFilename
filename of RouteProbe
Definition: GNERouteProbe.h:134
GNELane::getLaneShape
const PositionVector & getLaneShape() const
Definition: GNELane.cpp:86
GNEAdditional::selectAttributeCarrier
void selectAttributeCarrier(bool changeFlag=true)
Definition: GNEAdditional.cpp:517
GLO_ROUTEPROBE
@ GLO_ROUTEPROBE
a RouteProbe
Definition: GUIGlObjectTypes.h:93
GNEViewNet.h
STEPS2TIME
#define STEPS2TIME(x)
Definition: SUMOTime.h:56
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
Boundary
A class that stores a 2D geometrical boundary.
Definition: Boundary.h:41
GUIVisualizationColorSettings::routeProbe
static const RGBColor routeProbe
color for route probes
Definition: GUIVisualizationSettings.h:225
GNERouteProbe::getAttribute
std::string getAttribute(SumoXMLAttr key) const
Definition: GNERouteProbe.cpp:208
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
GNEGeometry::Geometry::getRotation
double getRotation() const
get rotation
Definition: GNEGeometry.cpp:137
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
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
GNEEdge.h
time2string
std::string time2string(SUMOTime t)
Definition: SUMOTime.cpp:67
GNEAdditional::myAdditionalGeometry
GNEGeometry::Geometry myAdditionalGeometry
geometry to be precomputed in updateGeometry(...)
Definition: GNEAdditional.h:338
GNEAdditional::myAdditionalName
std::string myAdditionalName
name of additional
Definition: GNEAdditional.h:347
GNENetElement
Definition: GNENetElement.h:43
GNERouteProbe::~GNERouteProbe
~GNERouteProbe()
Destructor.
Definition: GNERouteProbe.cpp:50
GNERouteProbe::setAttribute
void setAttribute(SumoXMLAttr key, const std::string &value, GNEUndoList *undoList)
method for setting the attribute and letting the object perform additional changes
Definition: GNERouteProbe.cpp:244
GUIVisualizationDetailSettings::laneTextures
static const double laneTextures
details for lane textures
Definition: GUIVisualizationSettings.h:283
GNELane.h
SUMO_ATTR_FREQUENCY
@ SUMO_ATTR_FREQUENCY
Definition: SUMOXMLDefinitions.h:662
GNERouteProbe::getParentName
std::string getParentName() const
Returns the name of the parent object (if any)
Definition: GNERouteProbe.cpp:117
GNEGeometry::Geometry::getPosition
const Position & getPosition() const
get Position
Definition: GNEGeometry.cpp:127
GUIVisualizationSettings::colorSettings
GUIVisualizationColorSettings colorSettings
color settings
Definition: GUIVisualizationSettings.h:677
GUIVisualizationColorSettings::selectionColor
RGBColor selectionColor
basic selection color
Definition: GUIVisualizationSettings.h:129
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
GNERouteProbe::moveGeometry
void moveGeometry(const Position &offset)
change the position of the element geometry without saving in undoList
Definition: GNERouteProbe.cpp:105
GNERouteProbe::myFrequency
std::string myFrequency
Frequency of RouteProbe.
Definition: GNERouteProbe.h:131
Position::y
double y() const
Returns the y-position.
Definition: Position.h:61
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
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
GNERouteProbe::getHierarchyName
std::string getHierarchyName() const
get Hierarchy Name (Used in AC Hierarchy)
Definition: GNERouteProbe.cpp:278
GNERouteProbe::getPopUpID
std::string getPopUpID() const
get PopPup ID (Used in AC Hierarchy)
Definition: GNERouteProbe.cpp:272
GUIVisualizationSettings::drawAdditionals
bool drawAdditionals(const double exaggeration) const
check if additionals must be drawn
Definition: GUIVisualizationSettings.cpp:1663
GNEAdditional::drawUsingSelectColor
bool drawUsingSelectColor() const
check if attribute carrier must be drawn using selecting color.
Definition: GNEAdditional.cpp:554
GNERouteProbe::myRelativePositionY
int myRelativePositionY
relative position regarding to other route probes
Definition: GNERouteProbe.h:143
SUMO_TAG_ROUTEPROBE
@ SUMO_TAG_ROUTEPROBE
a routeprobe detector
Definition: SUMOXMLDefinitions.h:115
GNENet::retrieveEdge
GNEEdge * retrieveEdge(const std::string &id, bool failHard=true)
get edge by id
Definition: GNENet.cpp:1069
config.h
GUIVisualizationSettings::addSize
GUIVisualizationSizeSettings addSize
Definition: GUIVisualizationSettings.h:589
GNE_ATTR_SELECTED
@ GNE_ATTR_SELECTED
element is selected
Definition: SUMOXMLDefinitions.h:971
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
GNERouteProbe::isAttributeEnabled
bool isAttributeEnabled(SumoXMLAttr key) const
Definition: GNERouteProbe.cpp:266
GNEAttributeCarrier::getTagStr
const std::string & getTagStr() const
get tag assigned to this object in string format
Definition: GNEAttributeCarrier.cpp:1267
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
PositionVector::getLineCenter
Position getLineCenter() const
get line center
Definition: PositionVector.cpp:474
GNERouteProbe::getAttributeDouble
double getAttributeDouble(SumoXMLAttr key) const
Definition: GNERouteProbe.cpp:233
GNEAdditional::isValidAdditionalID
bool isValidAdditionalID(const std::string &newID) const
check if a new additional ID is valid
Definition: GNEAdditional.cpp:482
SumoXMLAttr
SumoXMLAttr
Numbers representing SUMO-XML - attributes.
Definition: SUMOXMLDefinitions.h:372
GNERouteProbe::commitGeometryMoving
void commitGeometryMoving(GNEUndoList *undoList)
commit geometry changes in the attributes of an element after use of moveGeometry(....
Definition: GNERouteProbe.cpp:111
GNELane
This lane is powered by an underlying GNEEdge and basically knows how to draw itself.
Definition: GNELane.h:45
GNERouteProbe::isValid
bool isValid(SumoXMLAttr key, const std::string &value)
method for checking if the key and their conrrespond attribute are valids
Definition: GNERouteProbe.cpp:287
GUITextureSubSys.h
GNEChange_Attribute.h
GNENet.h
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
GNERouteProbe::drawGL
void drawGL(const GUIVisualizationSettings &s) const
Draws the object.
Definition: GNERouteProbe.cpp:123
GNEAdditional::BlockIcon::offset
Position offset
The offSet of the block icon.
Definition: GNEAdditional.h:321
RGBColor::WHITE
static const RGBColor WHITE
Definition: RGBColor.h:196
GNEUndoList.h
GNERouteProbe::getCenteringBoundary
Boundary getCenteringBoundary() const
Returns the boundary to which the view shall be centered in order to show the object.
Definition: GNERouteProbe.cpp:93