Eclipse SUMO - Simulation of Urban MObility
GNECalibrator.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>
28 #include <utils/gui/div/GLHelper.h>
30 
31 #include "GNECalibrator.h"
32 
33 
34 // ===========================================================================
35 // member method definitions
36 // ===========================================================================
37 
38 GNECalibrator::GNECalibrator(const std::string& id, GNEViewNet* viewNet, GNEEdge* edge, double pos, SUMOTime frequency, const std::string& name, const std::string& output, const std::string& routeprobe) :
39  GNEAdditional(id, viewNet, GLO_CALIBRATOR, SUMO_TAG_CALIBRATOR, name, false, {
40  edge
41 }, {}, {}, {}, {}, {}, {}, {}, {}, {}),
42 myPositionOverLane(pos),
43 myFrequency(frequency),
44 myOutput(output),
45 myRouteProbe(routeprobe) {
46 }
47 
48 
49 GNECalibrator::GNECalibrator(const std::string& id, GNEViewNet* viewNet, GNELane* lane, double pos, SUMOTime frequency, const std::string& name, const std::string& output, const std::string& routeprobe) :
50  GNEAdditional(id, viewNet, GLO_CALIBRATOR, SUMO_TAG_LANECALIBRATOR, name, false, {}, {lane}, {}, {}, {}, {}, {}, {}, {}, {}),
51 myPositionOverLane(pos),
52 myFrequency(frequency),
53 myOutput(output),
54 myRouteProbe(routeprobe) {
55 }
56 
57 
59 
60 
61 void
63  // This additional cannot be moved
64 }
65 
66 
67 void
69  // This additional cannot be moved
70 }
71 
72 
73 void
75  // get shape depending of we have a edge or a lane
76  if (getParentLanes().size() > 0) {
77  // update geometry
79  } else if (getParentEdges().size() > 0) {
80  // update geometry of first edge
82  // clear extra geometries
84  // iterate over every lane and get point
85  for (int i = 1; i < (int)getParentEdges().front()->getLanes().size(); i++) {
86  // add new calibrator geometry
87  GNEGeometry::Geometry calibratorGeometry;
88  calibratorGeometry.updateGeometryPosition(getParentEdges().front()->getLanes().at(i), myPositionOverLane);
89  myEdgeCalibratorGeometries.push_back(calibratorGeometry);
90  }
91  } else {
92  throw ProcessError("Both edges and lanes aren't defined");
93  }
94 }
95 
96 
99  PositionVector shape = (getParentLanes().size() > 0) ? getParentLanes().front()->getLaneShape() : getParentEdges().front()->getLanes().at(0)->getLaneShape();
100  if (myPositionOverLane < 0) {
101  return shape.front();
102  } else if (myPositionOverLane > shape.length()) {
103  return shape.back();
104  } else {
105  return shape.positionAtOffset(myPositionOverLane);
106  }
107 }
108 
109 
110 Boundary
113 }
114 
115 
116 void
117 GNECalibrator::splitEdgeGeometry(const double splitPosition, const GNENetElement* /*originalElement*/, const GNENetElement* newElement, GNEUndoList* undoList) {
118  if (splitPosition < myPositionOverLane) {
119  // change lane or edge
120  if (newElement->getTagProperty().getTag() == SUMO_TAG_LANE) {
121  setAttribute(SUMO_ATTR_LANE, newElement->getID(), undoList);
122  } else {
123  setAttribute(SUMO_ATTR_EDGE, newElement->getID(), undoList);
124  }
125  // now adjust start position
126  setAttribute(SUMO_ATTR_POSITION, toString(myPositionOverLane - splitPosition), undoList);
127  }
128 }
129 
130 
131 std::string
133  // get parent name depending of we have a edge or a lane
134  if (getParentLanes().size() > 0) {
135  return getParentLanes().front()->getMicrosimID();
136  } else if (getParentEdges().size() > 0) {
137  return getParentEdges().front()->getLanes().at(0)->getMicrosimID();
138  } else {
139  throw ProcessError("Both myEdge and myLane aren't defined");
140  }
141 }
142 
143 
144 void
146  // get values
147  const double exaggeration = s.addSize.getExaggeration(s, this);
148  // first check if additional has to be drawn
149  if (s.drawAdditionals(exaggeration)) {
150  // begin draw
151  glPushName(getGlID());
152  glLineWidth(1.0);
153  // draw first symbol
155  // continue with the other symbols
156  for (const auto& edgeCalibratorGeometry : myEdgeCalibratorGeometries) {
157  drawCalibratorSymbol(s, exaggeration, edgeCalibratorGeometry.getPosition(), edgeCalibratorGeometry.getRotation());
158  }
159  // draw name
161  // pop name
162  glPopName();
163  }
164 }
165 
166 
167 void
169  // Open calibrator dialog
170  GNECalibratorDialog calibratorDialog(this);
171 }
172 
173 
174 std::string
176  switch (key) {
177  case SUMO_ATTR_ID:
178  return getAdditionalID();
179  case SUMO_ATTR_EDGE:
180  return getParentEdges().front()->getID();
181  case SUMO_ATTR_LANE:
182  return getParentLanes().front()->getID();
183  case SUMO_ATTR_POSITION:
185  case SUMO_ATTR_FREQUENCY:
186  return time2string(myFrequency);
187  case SUMO_ATTR_NAME:
188  return myAdditionalName;
189  case SUMO_ATTR_OUTPUT:
190  return myOutput;
192  return myRouteProbe;
193  case GNE_ATTR_SELECTED:
195  case GNE_ATTR_PARAMETERS:
196  return getParametersStr();
197  default:
198  throw InvalidArgument(getTagStr() + " doesn't have an attribute of type '" + toString(key) + "'");
199  }
200 }
201 
202 
203 double
205  throw InvalidArgument(getTagStr() + " doesn't have a double attribute of type '" + toString(key) + "'");
206 }
207 
208 
209 void
210 GNECalibrator::setAttribute(SumoXMLAttr key, const std::string& value, GNEUndoList* undoList) {
211  if (value == getAttribute(key)) {
212  return; //avoid needless changes, later logic relies on the fact that attributes have changed
213  }
214  switch (key) {
215  case SUMO_ATTR_ID:
216  case SUMO_ATTR_EDGE:
217  case SUMO_ATTR_LANE:
218  case SUMO_ATTR_POSITION:
219  case SUMO_ATTR_FREQUENCY:
220  case SUMO_ATTR_NAME:
221  case SUMO_ATTR_OUTPUT:
223  case GNE_ATTR_SELECTED:
224  case GNE_ATTR_PARAMETERS:
225  undoList->p_add(new GNEChange_Attribute(this, myViewNet->getNet(), key, value));
226  break;
227  default:
228  throw InvalidArgument(getTagStr() + " doesn't have an attribute of type '" + toString(key) + "'");
229  }
230 
231 }
232 
233 
234 bool
235 GNECalibrator::isValid(SumoXMLAttr key, const std::string& value) {
236  switch (key) {
237  case SUMO_ATTR_ID:
238  return isValidAdditionalID(value);
239  case SUMO_ATTR_EDGE:
240  if (myViewNet->getNet()->retrieveEdge(value, false) != nullptr) {
241  return true;
242  } else {
243  return false;
244  }
245  case SUMO_ATTR_LANE:
246  if (myViewNet->getNet()->retrieveLane(value, false) != nullptr) {
247  return true;
248  } else {
249  return false;
250  }
251  case SUMO_ATTR_POSITION:
252  if (canParse<double>(value)) {
253  // obtain position and check if is valid
254  double newPosition = parse<double>(value);
255  PositionVector shape = (getParentLanes().size() > 0) ? getParentLanes().front()->getLaneShape() : getParentEdges().front()->getLanes().at(0)->getLaneShape();
256  if ((newPosition < 0) || (newPosition > shape.length())) {
257  return false;
258  } else {
259  return true;
260  }
261  } else {
262  return false;
263  }
264  case SUMO_ATTR_FREQUENCY:
265  return canParse<SUMOTime>(value);
266  case SUMO_ATTR_NAME:
268  case SUMO_ATTR_OUTPUT:
272  case GNE_ATTR_SELECTED:
273  return canParse<bool>(value);
274  case GNE_ATTR_PARAMETERS:
275  return Parameterised::areParametersValid(value);
276  default:
277  throw InvalidArgument(getTagStr() + " doesn't have an attribute of type '" + toString(key) + "'");
278  }
279 }
280 
281 
282 bool
284  return true;
285 }
286 
287 
288 std::string
290  return getTagStr() + ": " + getID();
291 }
292 
293 
294 std::string
296  return getTagStr();
297 }
298 
299 // ===========================================================================
300 // private
301 // ===========================================================================
302 
303 void GNECalibrator::drawCalibratorSymbol(const GUIVisualizationSettings& s, const double exaggeration, const Position& pos, const double rot) const {
304  glPushMatrix();
305  glTranslated(pos.x(), pos.y(), getType());
306  glRotated(rot, 0, 0, 1);
307  glTranslated(0, 0, getType());
308  glScaled(exaggeration, exaggeration, 1);
309  glPolygonMode(GL_FRONT_AND_BACK, GL_FILL);
310  // set color
311  if (drawUsingSelectColor()) {
313  } else {
315  }
316  // base
317  glBegin(GL_TRIANGLES);
318  glVertex2d(0 - 1.4, 0);
319  glVertex2d(0 - 1.4, 6);
320  glVertex2d(0 + 1.4, 6);
321  glVertex2d(0 + 1.4, 0);
322  glVertex2d(0 - 1.4, 0);
323  glVertex2d(0 + 1.4, 6);
324  glEnd();
325  // draw text if isn't being drawn for selecting
326  if (!s.drawForRectangleSelection && s.drawDetail(s.detailSettings.calibratorText, exaggeration)) {
327  // set color depending of selection status
329  // draw "C"
330  GLHelper::drawText("C", Position(0, 1.5), 0.1, 3, textColor, 180);
331  // draw "edge" or "lane "
332  if (getParentLanes().size() > 0) {
333  GLHelper::drawText("lane", Position(0, 3), .1, 1, textColor, 180);
334  } else if (getParentEdges().size() > 0) {
335  GLHelper::drawText("edge", Position(0, 3), .1, 1, textColor, 180);
336  } else {
337  throw ProcessError("Both myEdge and myLane aren't defined");
338  }
339  }
340  glPopMatrix();
341  // check if dotted contour has to be drawn
342  if (myViewNet->getDottedAC() == this) {
343  GLHelper::drawShapeDottedContourRectangle(s, getType(), pos, 2.8, 6, rot, 0, 3);
344  }
345 }
346 
347 void
348 GNECalibrator::setAttribute(SumoXMLAttr key, const std::string& value) {
349  switch (key) {
350  case SUMO_ATTR_ID:
351  changeAdditionalID(value);
352  break;
353  case SUMO_ATTR_EDGE:
354  replaceParentEdges(this, value);
355  break;
356  case SUMO_ATTR_LANE:
357  replaceParentLanes(this, value);
358  break;
359  case SUMO_ATTR_POSITION:
360  myPositionOverLane = parse<double>(value);
361  break;
362  case SUMO_ATTR_FREQUENCY:
363  myFrequency = parse<SUMOTime>(value);
364  break;
365  case SUMO_ATTR_NAME:
366  myAdditionalName = value;
367  break;
368  case SUMO_ATTR_OUTPUT:
369  myOutput = value;
370  break;
372  myRouteProbe = value;
373  break;
374  case GNE_ATTR_SELECTED:
375  if (parse<bool>(value)) {
377  } else {
379  }
380  break;
381  case GNE_ATTR_PARAMETERS:
382  setParametersStr(value);
383  break;
384  default:
385  throw InvalidArgument(getTagStr() + " doesn't have an attribute of type '" + toString(key) + "'");
386  }
387 }
388 
389 /****************************************************************************/
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
SUMO_TAG_LANECALIBRATOR
@ SUMO_TAG_LANECALIBRATOR
A calibrator placed over lane (used in netedit)
Definition: SUMOXMLDefinitions.h:93
GNEAdditional
An Element which don't belongs to GNENet but has influency in the simulation.
Definition: GNEAdditional.h:48
SUMOXMLDefinitions::isValidAdditionalID
static bool isValidAdditionalID(const std::string &value)
whether the given string is a valid id for an additional object
Definition: SUMOXMLDefinitions.cpp:984
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
GNEAttributeCarrier::getID
const std::string getID() const
function to support debugging
Definition: GNEAttributeCarrier.cpp:1289
GNECalibrator::myRouteProbe
std::string myRouteProbe
ID to current RouteProbe.
Definition: GNECalibrator.h:169
GNECalibrator::commitGeometryMoving
void commitGeometryMoving(GNEUndoList *undoList)
commit geometry changes in the attributes of an element after use of moveGeometry(....
Definition: GNECalibrator.cpp: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:1001
GNECalibrator::isAttributeEnabled
bool isAttributeEnabled(SumoXMLAttr key) const
Definition: GNECalibrator.cpp:283
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
RGBColor::BLACK
static const RGBColor BLACK
Definition: RGBColor.h:197
GUIVisualizationSettings::drawForRectangleSelection
bool drawForRectangleSelection
whether drawing is performed for the purpose of selecting objects using a rectangle
Definition: GUIVisualizationSettings.h:647
GNECalibrator::getAttribute
std::string getAttribute(SumoXMLAttr key) const
Definition: GNECalibrator.cpp:175
GNECalibrator::getAttributeDouble
double getAttributeDouble(SumoXMLAttr key) const
Definition: GNECalibrator.cpp:204
GNECalibrator::myFrequency
SUMOTime myFrequency
Frequency of calibrator.
Definition: GNECalibrator.h:163
GNEGeometry::Geometry::updateGeometryPosition
void updateGeometryPosition(const GNELane *lane, const double posOverLane)
update position and rotation
Definition: GNEGeometry.cpp:100
SUMO_TAG_LANE
@ SUMO_TAG_LANE
begin/end of the description of a single lane
Definition: SUMOXMLDefinitions.h:49
SUMOTime
long long int SUMOTime
Definition: SUMOTime.h:34
SUMO_ATTR_EDGE
@ SUMO_ATTR_EDGE
Definition: SUMOXMLDefinitions.h:423
GNECalibrator::splitEdgeGeometry
void splitEdgeGeometry(const double splitPosition, const GNENetElement *originalElement, const GNENetElement *newElement, GNEUndoList *undoList)
split geometry
Definition: GNECalibrator.cpp:117
GNEHierarchicalParentElements::getParentLanes
const std::vector< GNELane * > & getParentLanes() const
get parent lanes
Definition: GNEHierarchicalParentElements.cpp:235
GNEViewNet
Definition: GNEViewNet.h:42
GNECalibrator::setAttribute
void setAttribute(SumoXMLAttr key, const std::string &value, GNEUndoList *undoList)
method for setting the attribute and letting the object perform additional changes
Definition: GNECalibrator.cpp:210
SUMO_ATTR_ID
@ SUMO_ATTR_ID
Definition: SUMOXMLDefinitions.h:378
PositionVector::length
double length() const
Returns the length.
Definition: PositionVector.cpp:484
GNECalibrator::~GNECalibrator
~GNECalibrator()
Destructor.
Definition: GNECalibrator.cpp:58
GLHelper.h
SUMO_ATTR_LANE
@ SUMO_ATTR_LANE
Definition: SUMOXMLDefinitions.h:637
GNECalibrator::getPositionInView
Position getPositionInView() const
Returns position of additional in view.
Definition: GNECalibrator.cpp:98
SUMO_ATTR_ROUTEPROBE
@ SUMO_ATTR_ROUTEPROBE
Definition: SUMOXMLDefinitions.h:670
GNEAdditional::changeAdditionalID
void changeAdditionalID(const std::string &newID)
change ID of additional
Definition: GNEAdditional.cpp:502
PositionVector
A list of positions.
Definition: PositionVector.h:45
GNEAdditional::unselectAttributeCarrier
void unselectAttributeCarrier(bool changeFlag=true)
unselect attribute carrier using GUIGlobalSelection
Definition: GNEAdditional.cpp:532
GNECalibrator::openAdditionalDialog
void openAdditionalDialog()
open Calibrator Dialog
Definition: GNECalibrator.cpp:168
GLHelper::setColor
static void setColor(const RGBColor &c)
Sets the gl-color to this value.
Definition: GLHelper.cpp:621
PositionVector::getBoxBoundary
Boundary getBoxBoundary() const
Returns a boundary enclosing this list of lines.
Definition: PositionVector.cpp:390
GNEAttributeCarrier::TagProperties::getTag
SumoXMLTag getTag() const
get Tag vinculated with this attribute Property
Definition: GNEAttributeCarrier.cpp:523
GNEAdditional::myViewNet
GNEViewNet * myViewNet
The GNEViewNet this additional element belongs.
Definition: GNEAdditional.h:335
GNECalibrator::myEdgeCalibratorGeometries
std::vector< GNEGeometry::Geometry > myEdgeCalibratorGeometries
extra calibrator geometries
Definition: GNECalibrator.h:172
GNEEdge
A road/street connecting two junctions (netedit-version)
Definition: GNEEdge.h:51
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
GNECalibrator::GNECalibrator
GNECalibrator(const std::string &id, GNEViewNet *viewNet, GNEEdge *edge, double pos, SUMOTime frequency, const std::string &name, const std::string &output, const std::string &routeprobe)
Constructor using edge.
Definition: GNECalibrator.cpp:38
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
GLHelper::drawText
static void drawText(const std::string &text, const Position &pos, const double layer, const double size, const RGBColor &col=RGBColor::BLACK, const double angle=0, int align=0, double width=-1)
Definition: GLHelper.cpp:673
RGBColor
Definition: RGBColor.h:39
GNECalibratorDialog.h
GUIVisualizationSettings::addName
GUIVisualizationTextSettings addName
Definition: GUIVisualizationSettings.h:591
GNECalibrator::myOutput
std::string myOutput
output of calibrator
Definition: GNECalibrator.h:166
GUIVisualizationSettings::detailSettings
GUIVisualizationDetailSettings detailSettings
detail settings
Definition: GUIVisualizationSettings.h:683
GNEAttributeCarrier::getTagProperty
const TagProperties & getTagProperty() const
get Tag Property assigned to this object
Definition: GNEAttributeCarrier.cpp:1273
GNECalibrator::isValid
bool isValid(SumoXMLAttr key, const std::string &value)
method for checking if the key and their conrrespond attribute are valids
Definition: GNECalibrator.cpp:235
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
GUIVisualizationDetailSettings::calibratorText
static const double calibratorText
details for calibrator text
Definition: GUIVisualizationSettings.h:310
GNEAdditional::selectAttributeCarrier
void selectAttributeCarrier(bool changeFlag=true)
Definition: GNEAdditional.cpp:517
GNEViewNet.h
PositionVector::positionAtOffset
Position positionAtOffset(double pos, double lateralOffset=0) const
Returns the position at the given length.
Definition: PositionVector.cpp:248
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
GNEHierarchicalParentElements::replaceParentLanes
void replaceParentLanes(GNEShape *elementChild, const std::string &newLaneIDs)
replace the parent edges of a shape
Definition: GNEHierarchicalParentElements.cpp:469
GNE_ATTR_PARAMETERS
@ GNE_ATTR_PARAMETERS
parameters "key1=value1|key2=value2|...|keyN=valueN"
Definition: SUMOXMLDefinitions.h:989
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
ProcessError
Definition: UtilExceptions.h:39
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
GNEGeometry::Geometry
struct for pack all variables related with geometry of stop
Definition: GNEGeometry.h:56
GNENetElement
Definition: GNENetElement.h:43
GNELane.h
SUMO_ATTR_FREQUENCY
@ SUMO_ATTR_FREQUENCY
Definition: SUMOXMLDefinitions.h:662
SUMO_ATTR_POSITION
@ SUMO_ATTR_POSITION
Definition: SUMOXMLDefinitions.h:660
GNEGeometry::Geometry::getPosition
const Position & getPosition() const
get Position
Definition: GNEGeometry.cpp:127
GNECalibrator::myPositionOverLane
double myPositionOverLane
position over Lane
Definition: GNECalibrator.h:160
GUIVisualizationColorSettings::calibrator
static const RGBColor calibrator
color for Calibrators
Definition: GUIVisualizationSettings.h:222
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
GNECalibrator::drawCalibratorSymbol
void drawCalibratorSymbol(const GUIVisualizationSettings &s, const double exaggeration, const Position &pos, const double rot) const
draw calibrator symbol
Definition: GNECalibrator.cpp:303
Position::y
double y() const
Returns the y-position.
Definition: Position.h:61
GNECalibratorDialog
Dialog for edit calibrators.
Definition: GNECalibratorDialog.h:45
SUMO_ATTR_OUTPUT
@ SUMO_ATTR_OUTPUT
Definition: SUMOXMLDefinitions.h:788
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
GNECalibrator::getParentName
std::string getParentName() const
Returns the name of the parent object.
Definition: GNECalibrator.cpp:132
GNECalibrator::getCenteringBoundary
Boundary getCenteringBoundary() const
Returns the boundary to which the view shall be centered in order to show the object.
Definition: GNECalibrator.cpp:111
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
GNECalibrator.h
GLO_CALIBRATOR
@ GLO_CALIBRATOR
a Calibrator
Definition: GUIGlObjectTypes.h:91
GNECalibrator::updateGeometry
void updateGeometry()
update pre-computed geometry information
Definition: GNECalibrator.cpp:74
GNENet::retrieveEdge
GNEEdge * retrieveEdge(const std::string &id, bool failHard=true)
get edge by id
Definition: GNENet.cpp:1069
GNENet::retrieveLane
GNELane * retrieveLane(const std::string &id, bool failHard=true, bool checkVolatileChange=false)
get lane by id
Definition: GNENet.cpp:1228
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
GNECalibrator::getHierarchyName
std::string getHierarchyName() const
get Hierarchy Name (Used in AC Hierarchy)
Definition: GNECalibrator.cpp:295
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
GNECalibrator::moveGeometry
void moveGeometry(const Position &offset)
change the position of the element geometry without saving in undoList
Definition: GNECalibrator.cpp:62
GNECalibrator::drawGL
void drawGL(const GUIVisualizationSettings &s) const
Draws the object.
Definition: GNECalibrator.cpp:145
SUMO_TAG_CALIBRATOR
@ SUMO_TAG_CALIBRATOR
A calibrator placed over edge.
Definition: SUMOXMLDefinitions.h:91
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
GNELane
This lane is powered by an underlying GNEEdge and basically knows how to draw itself.
Definition: GNELane.h:45
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
GNECalibrator::getPopUpID
std::string getPopUpID() const
get PopPup ID (Used in AC Hierarchy)
Definition: GNECalibrator.cpp:289
GNEUndoList.h