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 /****************************************************************************/
15 //
16 /****************************************************************************/
17 
18 // ===========================================================================
19 // included modules
20 // ===========================================================================
21 #include <config.h>
22 
24 #include <utils/gui/div/GLHelper.h>
25 #include <netedit/GNEViewNet.h>
28 #include <netedit/GNEUndoList.h>
29 #include <netedit/GNENet.h>
32 
33 #include "GNERouteProbe.h"
34 
35 
36 // ===========================================================================
37 // member method definitions
38 // ===========================================================================
39 
40 GNERouteProbe::GNERouteProbe(const std::string& id, GNEViewNet* viewNet, GNEEdge* edge, const std::string& frequency, const std::string& name, const std::string& filename, SUMOTime begin) :
41  GNEAdditional(id, viewNet, GLO_ROUTEPROBE, SUMO_TAG_ROUTEPROBE, name, false, {
42  edge
43 }, {}, {}, {}, {}, {}, {}, {}, {}, {}),
44 myFrequency(frequency),
45 myFilename(filename),
46 myBegin(begin),
47 myRelativePositionY(0) {
48 }
49 
50 
52 }
53 
54 
55 void
57  // Clear all containers
59 
60  // obtain relative position of routeProbe in edge
61  myRelativePositionY = 2 * getEdgeParents().front()->getRouteProbeRelativePosition(this);
62 
63  // get lanes of edge
64  GNELane* firstLane = getEdgeParents().front()->getLanes().at(0);
65 
66  // Get shape of lane parent
67  double offset = firstLane->getGeometry().shape.length() < 0.5 ? firstLane->getGeometry().shape.length() : 0.5;
68  myGeometry.shape.push_back(firstLane->getGeometry().shape.positionAtOffset(offset));
69 
70  // Save rotation (angle) of the vector constructed by points f and s
71  myGeometry.shapeRotations.push_back(firstLane->getGeometry().shape.rotationDegreeAtOffset(offset) * -1);
72 
73  // Set block icon position
75 
76  // Set offset of the block icon
78 
79  // Set block icon rotation, and using their rotation for logo
80  myBlockIcon.setRotation(firstLane);
81 }
82 
83 
86  if (getEdgeParents().front()->getLanes().front()->getGeometry().shape.length() < 0.5) {
87  return getEdgeParents().front()->getLanes().front()->getGeometry().shape.front();
88  } else {
89  Position A = getEdgeParents().front()->getLanes().front()->getGeometry().shape.positionAtOffset(0.5);
90  Position B = getEdgeParents().front()->getLanes().back()->getGeometry().shape.positionAtOffset(0.5);
91  // return Middle point
92  return Position((A.x() + B.x()) / 2, (A.y() + B.y()) / 2);
93  }
94 }
95 
96 
99  return myGeometry.shape.getBoxBoundary().grow(10);
100 }
101 
102 
103 void
105  // This additional cannot be moved
106 }
107 
108 
109 void
111  // This additional cannot be moved
112 }
113 
114 
115 std::string
117  return getEdgeParents().front()->getMicrosimID();
118 }
119 
120 
121 void
123  // get values
124  const double width = (double) 2.0 * s.scale;
125  const double exaggeration = s.addSize.getExaggeration(s, this);
126  const int numberOfLanes = int(getEdgeParents().front()->getLanes().size());
127  // start drawing
128  glPushName(getGlID());
129  glLineWidth(1.0);
130  // set color
131  if (drawUsingSelectColor()) {
133  } else {
135  }
136  // draw shape
137  glPushMatrix();
138  glTranslated(0, 0, getType());
139  glTranslated(myGeometry.shape[0].x(), myGeometry.shape[0].y(), 0);
140  glRotated(myGeometry.shapeRotations[0], 0, 0, 1);
141  glScaled(exaggeration, exaggeration, 1);
142  glTranslated(-1.6, -1.6, 0);
143  glBegin(GL_QUADS);
144  glVertex2d(0, 0.25);
145  glVertex2d(0, -0.25);
146  glVertex2d((numberOfLanes * 3.3), -0.25);
147  glVertex2d((numberOfLanes * 3.3), 0.25);
148  glEnd();
149  glTranslated(0, 0, .01);
150  glBegin(GL_LINES);
151  glVertex2d(0, 0.25 - .1);
152  glVertex2d(0, -0.25 + .1);
153  glEnd();
154  // position indicator (White)
155  if ((width * exaggeration > 1) && !s.drawForSelecting) {
156  if (drawUsingSelectColor()) {
158  } else {
160  }
161  glRotated(90, 0, 0, -1);
162  glBegin(GL_LINES);
163  glVertex2d(0, 0);
164  glVertex2d(0, (numberOfLanes * 3.3));
165  glEnd();
166  }
167  // Pop shape matrix
168  glPopMatrix();
169  // Add a draw matrix for drawing logo
170  glPushMatrix();
171  glTranslated(myGeometry.shape[0].x(), myGeometry.shape[0].y(), getType());
172  glRotated(myGeometry.shapeRotations[0], 0, 0, 1);
173  glTranslated((-2.56) - myRelativePositionY, (-1.6), 0);
174  // Draw icon depending of Route Probe is selected and if isn't being drawn for selecting
175  if (!s.drawForSelecting && s.drawDetail(s.detailSettings.laneTextures, exaggeration)) {
176  glColor3d(1, 1, 1);
177  glRotated(-90, 0, 0, 1);
178  if (drawUsingSelectColor()) {
180  } else {
182  }
183  } else {
185  GLHelper::drawBoxLine(Position(0, 1), 0, 2, 1);
186  }
187  // Pop logo matrix
188  glPopMatrix();
189  // Show Lock icon depending of the Edit mode
190  myBlockIcon.drawIcon(s, exaggeration, 0.4);
191  // draw name
193  // check if dotted contour has to be drawn
194  if (myViewNet->getDottedAC() == this) {
196  }
197  // pop name
198  glPopName();
199 }
200 
201 
202 std::string
204  switch (key) {
205  case SUMO_ATTR_ID:
206  return getAdditionalID();
207  case SUMO_ATTR_EDGE:
208  return getEdgeParents().front()->getID();
209  case SUMO_ATTR_NAME:
210  return myAdditionalName;
211  case SUMO_ATTR_FILE:
212  return myFilename;
213  case SUMO_ATTR_FREQUENCY:
214  return toString(myFrequency);
215  case SUMO_ATTR_BEGIN:
216  return time2string(myBegin);
217  case GNE_ATTR_SELECTED:
219  case GNE_ATTR_GENERIC:
220  return getGenericParametersStr();
221  default:
222  throw InvalidArgument(getTagStr() + " doesn't have an attribute of type '" + toString(key) + "'");
223  }
224 }
225 
226 
227 void
228 GNERouteProbe::setAttribute(SumoXMLAttr key, const std::string& value, GNEUndoList* undoList) {
229  if (value == getAttribute(key)) {
230  return; //avoid needless changes, later logic relies on the fact that attributes have changed
231  }
232  switch (key) {
233  case SUMO_ATTR_ID:
234  case SUMO_ATTR_EDGE:
235  case SUMO_ATTR_NAME:
236  case SUMO_ATTR_FILE:
237  case SUMO_ATTR_FREQUENCY:
238  case SUMO_ATTR_BEGIN:
239  case GNE_ATTR_SELECTED:
240  case GNE_ATTR_GENERIC:
241  undoList->p_add(new GNEChange_Attribute(this, myViewNet->getNet(), key, value));
242  break;
243  default:
244  throw InvalidArgument(getTagStr() + " doesn't have an attribute of type '" + toString(key) + "'");
245  }
246 }
247 
248 
249 std::string
251  return getTagStr();
252 }
253 
254 
255 std::string
257  return getTagStr() + ": " + getAttribute(SUMO_ATTR_BEGIN);
258 }
259 
260 // ===========================================================================
261 // private
262 // ===========================================================================
263 
264 bool
265 GNERouteProbe::isValid(SumoXMLAttr key, const std::string& value) {
266  switch (key) {
267  case SUMO_ATTR_ID:
268  return isValidAdditionalID(value);
269  case SUMO_ATTR_EDGE:
270  if (myViewNet->getNet()->retrieveEdge(value, false) != nullptr) {
271  return true;
272  } else {
273  return false;
274  }
275  case SUMO_ATTR_NAME:
277  case SUMO_ATTR_FILE:
279  case SUMO_ATTR_FREQUENCY:
280  if (value.empty()) {
281  return true;
282  } else {
283  return canParse<SUMOTime>(value);
284  }
285  case SUMO_ATTR_BEGIN:
286  return canParse<SUMOTime>(value);
287  case GNE_ATTR_SELECTED:
288  return canParse<bool>(value);
289  case GNE_ATTR_GENERIC:
290  return isGenericParametersValid(value);
291  default:
292  throw InvalidArgument(getTagStr() + " doesn't have an attribute of type '" + toString(key) + "'");
293  }
294 }
295 
296 
297 void
298 GNERouteProbe::setAttribute(SumoXMLAttr key, const std::string& value) {
299  switch (key) {
300  case SUMO_ATTR_ID:
301  changeAdditionalID(value);
302  break;
303  case SUMO_ATTR_EDGE:
304  changeEdgeParents(this, value);
305  break;
306  case SUMO_ATTR_NAME:
307  myAdditionalName = value;
308  break;
309  case SUMO_ATTR_FILE:
310  myFilename = value;
311  break;
312  case SUMO_ATTR_FREQUENCY:
313  myFrequency = value;
314  break;
315  case SUMO_ATTR_BEGIN:
316  myBegin = parse<SUMOTime>(value);
317  break;
318  case GNE_ATTR_SELECTED:
319  if (parse<bool>(value)) {
321  } else {
323  }
324  break;
325  case GNE_ATTR_GENERIC:
327  break;
328  default:
329  throw InvalidArgument(getTagStr() + " doesn't have an attribute of type '" + toString(key) + "'");
330  }
331 }
332 
333 /****************************************************************************/
GUIGlObject::getType
GUIGlObjectType getType() const
Returns the type of the object as coded in GUIGlObjectType.
Definition: GUIGlObject.cpp:181
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:988
GNEAdditional::BlockIcon::position
Position position
position of the block icon
Definition: GNEAdditional.h:351
GNERouteProbe::myBegin
SUMOTime myBegin
begin of rerouter
Definition: GNERouteProbe.h:124
GNEAdditional
An Element which don't belongs to GNENet but has influency in the simulation.
Definition: GNEAdditional.h:47
GNERouteProbe::getPositionInView
Position getPositionInView() const
Returns position of additional in view.
Definition: GNERouteProbe.cpp:85
GNEAdditional::setGenericParametersStr
void setGenericParametersStr(const std::string &value)
set generic parameters in string format
Definition: GNEAdditional.cpp:704
GNEAdditional::getAdditionalID
const std::string & getAdditionalID() const
Definition: GNEAdditional.cpp:578
GNEAdditional::AdditionalGeometry::shape
PositionVector shape
The shape of the additional element.
Definition: GNEAdditional.h:68
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:994
GNEAdditional::BlockIcon::setRotation
void setRotation(GNELane *additionalLane=nullptr)
set Rotation of block Icon (must be called in updateGeometry() function)
Definition: GNEAdditional.cpp:502
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:355
GNERouteProbe.h
GNERouteProbe::updateGeometry
void updateGeometry()
update pre-computed geometry information
Definition: GNERouteProbe.cpp:56
GNETEXTURE_ROUTEPROBESELECTED
Definition: GUITextures.h:46
GNEAdditional::AdditionalGeometry::shapeRotations
std::vector< double > shapeRotations
The rotations of the single shape parts.
Definition: GNEAdditional.h:74
GNEAttributeCarrier::isGenericParametersValid
static bool isGenericParametersValid(const std::string &value)
check if given string can be parsed to a map/list of generic parameters
Definition: GNEAttributeCarrier.cpp:1354
SUMOTime
long long int SUMOTime
Definition: SUMOTime.h:35
SUMO_ATTR_EDGE
Definition: SUMOXMLDefinitions.h:424
GNEViewNet
Definition: GNEViewNet.h:43
GNEHierarchicalElementParents::getEdgeParents
const std::vector< GNEEdge * > & getEdgeParents() const
get edge parents
Definition: GNEHierarchicalElementParents.cpp:150
SUMO_ATTR_ID
Definition: SUMOXMLDefinitions.h:379
PositionVector::length
double length() const
Returns the length.
Definition: PositionVector.cpp:476
GLHelper.h
GNEAdditional::changeAdditionalID
void changeAdditionalID(const std::string &newID)
change ID of additional
Definition: GNEAdditional.cpp:604
GNEAdditional::unselectAttributeCarrier
void unselectAttributeCarrier(bool changeFlag=true)
unselect attribute carrier using GUIGlobalSelection
Definition: GNEAdditional.cpp:634
GNEAdditional::myBlockIcon
BlockIcon myBlockIcon
variable BlockIcon
Definition: GNEAdditional.h:380
GLHelper::setColor
static void setColor(const RGBColor &c)
Sets the gl-color to this value.
Definition: GLHelper.cpp:616
SUMO_ATTR_FILE
Definition: SUMOXMLDefinitions.h:662
PositionVector::getBoxBoundary
Boundary getBoxBoundary() const
Returns a boundary enclosing this list of lines.
Definition: PositionVector.cpp:382
GUITexturesHelper::drawTexturedBox
static void drawTexturedBox(int which, double size)
Draws a named texture as a box with the given size.
Definition: GUITexturesHelper.cpp:73
GNENetElement::NetElementGeometry::shape
PositionVector shape
The shape of the netElement element.
Definition: GNENetElement.h:57
GNEAdditional::myViewNet
GNEViewNet * myViewNet
The GNEViewNet this additional element belongs.
Definition: GNEAdditional.h:365
SUMO_ATTR_BEGIN
weights: time range begin
Definition: SUMOXMLDefinitions.h:675
GNEEdge
A road/street connecting two junctions (netedit-version)
Definition: GNEEdge.h:50
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:40
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:132
GNEViewNet::getNet
GNENet * getNet() const
get the net object
Definition: GNEViewNet.cpp:927
GNEAdditional::isAttributeCarrierSelected
bool isAttributeCarrierSelected() const
check if attribute carrier is selected
Definition: GNEAdditional.cpp:650
GUIVisualizationSettings::addName
GUIVisualizationTextSettings addName
Definition: GUIVisualizationSettings.h:582
GUIVisualizationSettings::detailSettings
GUIVisualizationDetailSettings detailSettings
detail settings
Definition: GUIVisualizationSettings.h:655
GNETEXTURE_ROUTEPROBE
Definition: GUITextures.h:45
GUIVisualizationColorSettings::selectedAdditionalColor
RGBColor selectedAdditionalColor
additional selection color (busStops, Detectors...)
Definition: GUIVisualizationSettings.h:148
GNERouteProbe::myFilename
std::string myFilename
filename of RouteProbe
Definition: GNERouteProbe.h:121
GNEAdditional::selectAttributeCarrier
void selectAttributeCarrier(bool changeFlag=true)
Definition: GNEAdditional.cpp:619
GLO_ROUTEPROBE
a RouteProbe
Definition: GUIGlObjectTypes.h:94
GNEViewNet.h
PositionVector::positionAtOffset
Position positionAtOffset(double pos, double lateralOffset=0) const
Returns the position at the given length.
Definition: PositionVector.cpp:246
PositionVector::rotationDegreeAtOffset
double rotationDegreeAtOffset(double pos) const
Returns the rotation at the given length.
Definition: PositionVector.cpp:311
GUIGlObject::getGlID
GUIGlID getGlID() const
Returns the numerical id of the object.
Definition: GUIGlObject.cpp:150
GNEViewNet::getDottedAC
const GNEAttributeCarrier * getDottedAC() const
get AttributeCarrier under cursor
Definition: GNEViewNet.cpp:939
Boundary
A class that stores a 2D geometrical boundary.
Definition: Boundary.h:42
GUIVisualizationColorSettings::routeProbe
static const RGBColor routeProbe
color for route probes
Definition: GUIVisualizationSettings.h:226
GNERouteProbe::getAttribute
std::string getAttribute(SumoXMLAttr key) const
Definition: GNERouteProbe.cpp:203
GUITextureSubSys::getTexture
static GUIGlID getTexture(GUITexture which)
returns a texture previously defined in the enum GUITexture
Definition: GUITextureSubSys.cpp:102
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:555
GUIVisualizationSettings::scale
double scale
information about a lane's width (temporary, used for a single view)
Definition: GUIVisualizationSettings.h:623
GNEAdditional::AdditionalGeometry::clearGeometry
void clearGeometry()
reset geometry
Definition: GNEAdditional.cpp:53
Position
A point in 2D or 3D with translation and scaling methods.
Definition: Position.h:39
Position::x
double x() const
Returns the x-position.
Definition: Position.h:57
GNEEdge.h
time2string
std::string time2string(SUMOTime t)
Definition: SUMOTime.cpp:65
GNEAdditional::myAdditionalName
std::string myAdditionalName
name of additional
Definition: GNEAdditional.h:374
GNERouteProbe::~GNERouteProbe
~GNERouteProbe()
Destructor.
Definition: GNERouteProbe.cpp:51
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:228
GUIVisualizationDetailSettings::laneTextures
static const double laneTextures
details for lane textures
Definition: GUIVisualizationSettings.h:284
GNELane.h
GNENetElement::getGeometry
const NetElementGeometry & getGeometry() const
Definition: GNENetElement.cpp:95
SUMO_ATTR_FREQUENCY
Definition: SUMOXMLDefinitions.h:660
GNERouteProbe::getParentName
std::string getParentName() const
Returns the name of the parent object (if any)
Definition: GNERouteProbe.cpp:116
GUIVisualizationSettings::colorSettings
GUIVisualizationColorSettings colorSettings
color settings
Definition: GUIVisualizationSettings.h:649
GUIVisualizationColorSettings::selectionColor
RGBColor selectionColor
basic selection color
Definition: GUIVisualizationSettings.h:130
GLIncludes.h
toString
std::string toString(const T &t, std::streamsize accuracy=gPrecision)
Definition: ToString.h:48
GNE_ATTR_GENERIC
generic attribute
Definition: SUMOXMLDefinitions.h:986
GNEAdditional::BlockIcon::drawIcon
void drawIcon(const GUIVisualizationSettings &s, const double exaggeration, const double size=0.5) const
draw lock icon
Definition: GNEAdditional.cpp:518
GNERouteProbe::moveGeometry
void moveGeometry(const Position &offset)
change the position of the element geometry without saving in undoList
Definition: GNERouteProbe.cpp:104
GNERouteProbe::myFrequency
std::string myFrequency
Frequency of RouteProbe.
Definition: GNERouteProbe.h:118
Position::y
double y() const
Returns the y-position.
Definition: Position.h:62
InvalidArgument
Definition: UtilExceptions.h:57
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:256
GNEAdditional::getGenericParametersStr
std::string getGenericParametersStr() const
return generic parameters in string format
Definition: GNEAdditional.cpp:678
GNERouteProbe::getPopUpID
std::string getPopUpID() const
get PopPup ID (Used in AC Hierarchy)
Definition: GNERouteProbe.cpp:250
GNEAdditional::drawUsingSelectColor
bool drawUsingSelectColor() const
check if attribute carrier must be drawn using selecting color.
Definition: GNEAdditional.cpp:656
GNERouteProbe::myRelativePositionY
int myRelativePositionY
relative position regarding to other route probes
Definition: GNERouteProbe.h:130
SUMO_TAG_ROUTEPROBE
a routeprobe detector
Definition: SUMOXMLDefinitions.h:116
GNENet::retrieveEdge
GNEEdge * retrieveEdge(const std::string &id, bool failHard=true)
get edge by id
Definition: GNENet.cpp:1020
GNEAdditional::myGeometry
AdditionalGeometry myGeometry
geometry to be precomputed in updateGeometry(...)
Definition: GNEAdditional.h:368
config.h
GUIVisualizationSettings::addSize
GUIVisualizationSizeSettings addSize
Definition: GUIVisualizationSettings.h:580
GNE_ATTR_SELECTED
element is selected
Definition: SUMOXMLDefinitions.h:968
Boundary::grow
Boundary & grow(double by)
extends the boundary by the given amount
Definition: Boundary.cpp:301
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:1621
GNEAttributeCarrier::getTagStr
const std::string & getTagStr() const
get tag assigned to this object in string format
Definition: GNEAttributeCarrier.cpp:1165
SUMO_ATTR_NAME
Definition: SUMOXMLDefinitions.h:381
GNEUndoList
Definition: GNEUndoList.h:49
GUIVisualizationSettings
Stores the information about how to visualize structures.
Definition: GUIVisualizationSettings.h:346
PositionVector::getLineCenter
Position getLineCenter() const
get line center
Definition: PositionVector.cpp:466
GNEHierarchicalElementParents::changeEdgeParents
void changeEdgeParents(GNEShape *elementChild, const std::string &newEdgeIDs)
change edge parents of a shape
Definition: GNEHierarchicalElementParents.cpp:340
GNEAdditional::isValidAdditionalID
bool isValidAdditionalID(const std::string &newID) const
check if a new additional ID is valid
Definition: GNEAdditional.cpp:584
SumoXMLAttr
SumoXMLAttr
Numbers representing SUMO-XML - attributes.
Definition: SUMOXMLDefinitions.h:373
GNERouteProbe::commitGeometryMoving
void commitGeometryMoving(GNEUndoList *undoList)
commit geometry changes in the attributes of an element after use of moveGeometry(....
Definition: GNERouteProbe.cpp:110
GNELane
This lane is powered by an underlying GNEEdge and basically knows how to draw itself.
Definition: GNELane.h:46
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:265
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:122
GNEAdditional::BlockIcon::offset
Position offset
The offSet of the block icon.
Definition: GNEAdditional.h:354
RGBColor::WHITE
static const RGBColor WHITE
Definition: RGBColor.h:197
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:98
GUIVisualizationSettings::drawForSelecting
bool drawForSelecting
whether drawing is performed for the purpose of selecting objects
Definition: GUIVisualizationSettings.h:635