Eclipse SUMO - Simulation of Urban MObility
GNEDetectorEntryExit.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>
27 #include <utils/gui/div/GLHelper.h>
29 
30 #include "GNEDetectorEntryExit.h"
31 #include "GNEAdditionalHandler.h"
32 
33 
34 // ===========================================================================
35 // member method definitions
36 // ===========================================================================
37 
38 GNEDetectorEntryExit::GNEDetectorEntryExit(SumoXMLTag entryExitTag, GNEViewNet* viewNet, GNEAdditional* parent, GNELane* lane, double pos, bool friendlyPos, bool blockMovement) :
39  GNEDetector(parent, viewNet, GLO_DET_ENTRY, entryExitTag, pos, 0, "", "", friendlyPos, blockMovement, {
40  lane
41 }) {
42  //check that this is a TAZ Source OR a TAZ Sink
43  if ((entryExitTag != SUMO_TAG_DET_ENTRY) && (entryExitTag != SUMO_TAG_DET_EXIT)) {
44  throw InvalidArgument("Invalid E3 Child Tag");
45  }
46 }
47 
48 
50 
51 
52 bool
54  // with friendly position enabled position are "always fixed"
55  if (myFriendlyPosition) {
56  return true;
57  } else {
58  return fabs(myPositionOverLane) <= getParentLanes().front()->getParentEdge()->getNBEdge()->getFinalLength();
59  }
60 }
61 
62 
63 std::string
65  // declare variable for error position
66  std::string errorPosition;
67  const double len = getParentLanes().front()->getParentEdge()->getNBEdge()->getFinalLength();
68  // check positions over lane
69  if (myPositionOverLane < -len) {
70  errorPosition = (toString(SUMO_ATTR_POSITION) + " < 0");
71  }
72  if (myPositionOverLane > len) {
73  errorPosition = (toString(SUMO_ATTR_POSITION) + " > lanes's length");
74  }
75  return errorPosition;
76 }
77 
78 
79 void
81  // declare new position
82  double newPositionOverLane = myPositionOverLane;
83  // fix pos and length checkAndFixDetectorPosition
84  GNEAdditionalHandler::checkAndFixDetectorPosition(newPositionOverLane, getParentLanes().front()->getParentEdge()->getNBEdge()->getFinalLength(), true);
85  // set new position
87 }
88 
89 
90 void
92  // Calculate new position using old position
93  Position newPosition = myMove.originalViewPosition;
94  newPosition.add(offset);
95  // filtern position using snap to active grid
96  newPosition = myViewNet->snapToActiveGrid(newPosition);
97  const bool storeNegative = myPositionOverLane < 0;
98  myPositionOverLane = getParentLanes().front()->getLaneShape().nearest_offset_to_point2D(newPosition, false);
99  if (storeNegative) {
100  myPositionOverLane -= getParentLanes().front()->getParentEdge()->getNBEdge()->getFinalLength();
101  }
102  // Update geometry
103  updateGeometry();
104 }
105 
106 
107 void
109  // commit new position allowing undo/redo
110  undoList->p_begin("position of " + getTagStr());
112  undoList->p_end();
113 }
114 
115 
116 void
118  // update geometry
120 
121  // Set block icon position
123 
124  // Set offset of the block icon
125  myBlockIcon.offset = Position(-1, 0);
126 
127  // Set block icon rotation, and using their rotation for logo
129 
130  // update E3 parent children
131  getParentAdditionals().at(0)->updateChildConnections();
132 }
133 
134 
135 void
137  // Set initial values
138  const double exaggeration = s.addSize.getExaggeration(s, this);
139  // first check if additional has to be drawn
140  if (s.drawAdditionals(exaggeration)) {
141  // Start drawing adding gl identificator
142  glPushName(getGlID());
143  // Push detector matrix
144  glPushMatrix();
145  glTranslated(0, 0, getType());
146  // Set color
147  if (drawUsingSelectColor()) {
149  } else if (myTagProperty.getTag() == SUMO_TAG_DET_ENTRY) {
151  } else if (myTagProperty.getTag() == SUMO_TAG_DET_EXIT) {
153  }
154  glPolygonMode(GL_FRONT_AND_BACK, GL_FILL);
155  // Push polygon matrix
156  glPushMatrix();
158  glRotated(myAdditionalGeometry.getRotation(), 0, 0, 1);
159  glScaled(exaggeration, exaggeration, 1);
160  // draw details if isn't being drawn for selecting
161  if (!s.drawForRectangleSelection) {
162  // Draw polygon
163  glBegin(GL_LINES);
164  glVertex2d(1.7, 0);
165  glVertex2d(-1.7, 0);
166  glEnd();
167  glBegin(GL_QUADS);
168  glVertex2d(-1.7, .5);
169  glVertex2d(-1.7, -.5);
170  glVertex2d(1.7, -.5);
171  glVertex2d(1.7, .5);
172  glEnd();
173  // first Arrow
174  glTranslated(1.5, 0, 0);
175  GLHelper::drawBoxLine(Position(0, 4), 0, 2, .05);
176  GLHelper::drawTriangleAtEnd(Position(0, 4), Position(0, 1), (double) 1, (double) .25);
177  // second Arrow
178  glTranslated(-3, 0, 0);
179  GLHelper::drawBoxLine(Position(0, 4), 0, 2, .05);
180  GLHelper::drawTriangleAtEnd(Position(0, 4), Position(0, 1), (double) 1, (double) .25);
181  } else {
182  // Draw square in drawy for selecting mode
183  glBegin(GL_QUADS);
184  glVertex2d(-1.7, 4.3);
185  glVertex2d(-1.7, -.5);
186  glVertex2d(1.7, -.5);
187  glVertex2d(1.7, 4.3);
188  glEnd();
189  }
190  // Pop polygon matrix
191  glPopMatrix();
192  // Pop detector matrix
193  glPopMatrix();
194  // Check if the distance is enought to draw details
196  // Push matrix
197  glPushMatrix();
198  // Traslate to center of detector
200  // Rotate depending of myBlockIcon.rotation
201  glRotated(myBlockIcon.rotation, 0, 0, -1);
202  //move to logo position
203  glTranslated(1.9, 0, 0);
204  // scale
205  glScaled(exaggeration, exaggeration, 1);
206  // draw Entry or Exit logo if isn't being drawn for selecting
209  GLHelper::drawBoxLine(Position(0, 1), 0, 2, 1);
210  } else if (drawUsingSelectColor()) {
212  } else if (myTagProperty.getTag() == SUMO_TAG_DET_ENTRY) {
213  GLHelper::drawText("E3", Position(), .1, 2.8, s.colorSettings.E3Entry);
214  } else if (myTagProperty.getTag() == SUMO_TAG_DET_EXIT) {
215  GLHelper::drawText("E3", Position(), .1, 2.8, s.colorSettings.E3Exit);
216  }
217  //move to logo position
218  glTranslated(1.7, 0, 0);
219  // Rotate depending of myBlockIcon.rotation
220  glRotated(90, 0, 0, 1);
221  // draw Entry or Exit text if isn't being drawn for selecting
224  GLHelper::drawBoxLine(Position(0, 1), 0, 2, 1);
225  } else if (drawUsingSelectColor()) {
228  } else if (myTagProperty.getTag() == SUMO_TAG_DET_EXIT) {
230  }
231  } else {
233  GLHelper::drawText("Entry", Position(), .1, 1, s.colorSettings.E3Entry);
234  } else if (myTagProperty.getTag() == SUMO_TAG_DET_EXIT) {
235  GLHelper::drawText("Exit", Position(), .1, 1, s.colorSettings.E3Exit);
236  }
237  }
238  // pop matrix
239  glPopMatrix();
240  // draw lock icon
241  myBlockIcon.drawIcon(s, exaggeration, 0.4);
242  }
243  // Draw name if isn't being drawn for selecting
244  if (!s.drawForRectangleSelection) {
246  }
247  // check if dotted contour has to be drawn
248  if (myViewNet->getDottedAC() == this) {
250  }
251  // pop gl identificator
252  glPopName();
253  }
254 }
255 
256 
257 std::string
259  switch (key) {
260  case SUMO_ATTR_ID:
261  return getAdditionalID();
262  case SUMO_ATTR_LANE:
263  return getParentLanes().front()->getID();
264  case SUMO_ATTR_POSITION:
269  return toString(myBlockMovement);
270  case GNE_ATTR_PARENT:
271  return getParentAdditionals().at(0)->getID();
272  case GNE_ATTR_SELECTED:
274  case GNE_ATTR_PARAMETERS:
275  return getParametersStr();
276  default:
277  throw InvalidArgument(getTagStr() + " doesn't have an attribute of type '" + toString(key) + "'");
278  }
279 }
280 
281 
282 void
283 GNEDetectorEntryExit::setAttribute(SumoXMLAttr key, const std::string& value, GNEUndoList* undoList) {
284  if (value == getAttribute(key)) {
285  return; //avoid needless changes, later logic relies on the fact that attributes have changed
286  }
287  switch (key) {
288  case SUMO_ATTR_ID:
289  case SUMO_ATTR_LANE:
290  case SUMO_ATTR_POSITION:
293  case GNE_ATTR_PARENT:
294  case GNE_ATTR_SELECTED:
295  case GNE_ATTR_PARAMETERS:
296  undoList->p_add(new GNEChange_Attribute(this, myViewNet->getNet(), key, value));
297  break;
298  default:
299  throw InvalidArgument(getTagStr() + " doesn't have an attribute of type '" + toString(key) + "'");
300  }
301 }
302 
303 
304 bool
305 GNEDetectorEntryExit::isValid(SumoXMLAttr key, const std::string& value) {
306  switch (key) {
307  case SUMO_ATTR_ID:
308  return isValidAdditionalID(value);
309  case SUMO_ATTR_LANE:
310  return (myViewNet->getNet()->retrieveLane(value, false) != nullptr);
311  case SUMO_ATTR_POSITION:
312  return canParse<double>(value) && fabs(parse<double>(value)) < getParentLanes().front()->getParentEdge()->getNBEdge()->getFinalLength();
314  return canParse<bool>(value);
316  return canParse<bool>(value);
317  case GNE_ATTR_PARENT:
318  return (myViewNet->getNet()->retrieveAdditional(SUMO_TAG_E3DETECTOR, value, false) != nullptr);
319  case GNE_ATTR_SELECTED:
320  return canParse<bool>(value);
321  case GNE_ATTR_PARAMETERS:
322  return Parameterised::areParametersValid(value);
323  default:
324  throw InvalidArgument(getTagStr() + " doesn't have an attribute of type '" + toString(key) + "'");
325  }
326 }
327 
328 
329 bool
331  return true;
332 }
333 
334 
335 void
336 GNEDetectorEntryExit::setAttribute(SumoXMLAttr key, const std::string& value) {
337  switch (key) {
338  case SUMO_ATTR_ID:
339  changeAdditionalID(value);
340  break;
341  case SUMO_ATTR_LANE:
342  replaceParentLanes(this, value);
343  break;
344  case SUMO_ATTR_POSITION:
345  myPositionOverLane = parse<double>(value);
346  break;
348  myFriendlyPosition = parse<bool>(value);
349  break;
351  myBlockMovement = parse<bool>(value);
352  break;
353  case GNE_ATTR_PARENT:
354  replaceParentAdditional(this, value, 0);
355  break;
356  case GNE_ATTR_SELECTED:
357  if (parse<bool>(value)) {
359  } else {
361  }
362  break;
363  case GNE_ATTR_PARAMETERS:
364  setParametersStr(value);
365  break;
366  default:
367  throw InvalidArgument(getTagStr() + " doesn't have an attribute of type '" + toString(key) + "'");
368  }
369 }
370 
371 /****************************************************************************/
GLO_DET_ENTRY
a DetEntry detector
Definition: GUIGlObjectTypes.h:81
GUIGlObject::getType
GUIGlObjectType getType() const
Returns the type of the object as coded in GUIGlObjectType.
Definition: GUIGlObject.cpp:180
GNEAdditional::BlockIcon::position
Position position
position of the block icon
Definition: GNEAdditional.h:318
GNENet::retrieveAdditional
GNEAdditional * retrieveAdditional(SumoXMLTag type, const std::string &id, bool hardFail=true) const
Returns the named additional.
Definition: GNENet.cpp:2183
GNEDetectorEntryExit.h
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
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
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
GNEGeometry::Geometry::updateGeometryPosition
void updateGeometryPosition(const GNELane *lane, const double posOverLane)
update position and rotation
Definition: GNEGeometry.cpp:100
GNEDetector::getPositionInView
Position getPositionInView() const
Returns position of additional in view.
Definition: GNEDetector.cpp:72
GNEHierarchicalParentElements::getParentLanes
const std::vector< GNELane * > & getParentLanes() const
get parent lanes
Definition: GNEHierarchicalParentElements.cpp:235
GNEViewNet
Definition: GNEViewNet.h:42
SUMO_ATTR_ID
Definition: SUMOXMLDefinitions.h:378
SUMO_TAG_DET_ENTRY
an e3 entry point
Definition: SUMOXMLDefinitions.h:81
GLHelper.h
SUMO_ATTR_LANE
Definition: SUMOXMLDefinitions.h:637
GNEAdditional::changeAdditionalID
void changeAdditionalID(const std::string &newID)
change ID of additional
Definition: GNEAdditional.cpp:502
GNEDetector::myPositionOverLane
double myPositionOverLane
position of detector over Lane
Definition: GNEDetector.h:174
GNEAdditional::unselectAttributeCarrier
void unselectAttributeCarrier(bool changeFlag=true)
unselect attribute carrier using GUIGlobalSelection
Definition: GNEAdditional.cpp:532
GNEDetectorEntryExit::moveGeometry
void moveGeometry(const Position &offset)
change the position of the element geometry without saving in undoList
Definition: GNEDetectorEntryExit.cpp:91
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
GNEDetector::myFriendlyPosition
bool myFriendlyPosition
Flag for friendly position.
Definition: GNEDetector.h:186
SumoXMLTag
SumoXMLTag
Numbers representing SUMO-XML - element names.
Definition: SUMOXMLDefinitions.h:41
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
GUIVisualizationDetailSettings::detectorDetails
static const double detectorDetails
details for detectors
Definition: GUIVisualizationSettings.h:304
GNEAttributeCarrier::TagProperties::getTag
SumoXMLTag getTag() const
get Tag vinculated with this attribute Property
Definition: GNEAttributeCarrier.cpp:523
GNEAdditional::myMove
AdditionalMove myMove
variable AdditionalMove
Definition: GNEAdditional.h:344
GNEAdditional::myViewNet
GNEViewNet * myViewNet
The GNEViewNet this additional element belongs.
Definition: GNEAdditional.h:335
GNEDetector::getGeometryPositionOverLane
double getGeometryPositionOverLane() const
get position over lane that is applicable to the shape
Definition: GNEDetector.cpp:110
GNEDetectorEntryExit::GNEDetectorEntryExit
GNEDetectorEntryExit(SumoXMLTag entryExitTag, GNEViewNet *viewNet, GNEAdditional *parent, GNELane *lane, double pos, bool friendlyPos, bool blockMovement)
Constructor.
Definition: GNEDetectorEntryExit.cpp:38
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
GNEHierarchicalParentElements::getParentAdditionals
const std::vector< GNEAdditional * > & getParentAdditionals() const
get parent additionals
Definition: GNEHierarchicalParentElements.cpp:85
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
GUIVisualizationSettings::addName
GUIVisualizationTextSettings addName
Definition: GUIVisualizationSettings.h:591
GUIVisualizationSettings::detailSettings
GUIVisualizationDetailSettings detailSettings
detail settings
Definition: GUIVisualizationSettings.h:683
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
GNEDetectorEntryExit::isAdditionalValid
bool isAdditionalValid() const
check if current additional is valid to be writed into XML (by default true, can be reimplemented in ...
Definition: GNEDetectorEntryExit.cpp:53
GNEDetectorEntryExit::fixAdditionalProblem
void fixAdditionalProblem()
fix additional problem
Definition: GNEDetectorEntryExit.cpp:80
GNEAdditional::selectAttributeCarrier
void selectAttributeCarrier(bool changeFlag=true)
Definition: GNEAdditional.cpp:517
GNEViewNet.h
GUIVisualizationColorSettings::E3Entry
static const RGBColor E3Entry
color for Entrys
Definition: GUIVisualizationSettings.h:216
GNEAdditionalHandler.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
GNEHierarchicalParentElements::replaceParentLanes
void replaceParentLanes(GNEShape *elementChild, const std::string &newLaneIDs)
replace the parent edges of a shape
Definition: GNEHierarchicalParentElements.cpp:469
GNEDetectorEntryExit::getAdditionalProblem
std::string getAdditionalProblem() const
return a string with the current additional problem
Definition: GNEDetectorEntryExit.cpp:64
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
GNEDetector
Definition: GNEDetector.h:33
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
GNEAttributeCarrier::myTagProperty
const TagProperties & myTagProperty
the xml tag to which this attribute carrier corresponds
Definition: GNEAttributeCarrier.h:785
GNEViewNet::getUndoList
GNEUndoList * getUndoList() const
get the undoList object
Definition: GNEViewNet.cpp:1020
GNEAdditional::myAdditionalGeometry
GNEGeometry::Geometry myAdditionalGeometry
geometry to be precomputed in updateGeometry(...)
Definition: GNEAdditional.h:338
GNEDetectorEntryExit::getAttribute
std::string getAttribute(SumoXMLAttr key) const
Definition: GNEDetectorEntryExit.cpp:258
GNEAdditional::myBlockMovement
bool myBlockMovement
boolean to check if additional element is blocked (i.e. cannot be moved with mouse)
Definition: GNEAdditional.h:350
GNEAdditional::BlockIcon::rotation
double rotation
The rotation of the block icon.
Definition: GNEAdditional.h:324
GNEDetectorEntryExit::drawGL
void drawGL(const GUIVisualizationSettings &s) const
Draws the object.
Definition: GNEDetectorEntryExit.cpp:136
SUMO_ATTR_FRIENDLY_POS
Definition: SUMOXMLDefinitions.h:765
GNELane.h
GNEHierarchicalParentElements::replaceParentAdditional
void replaceParentAdditional(GNEShape *shapeTobeChanged, const std::string &newParentAdditionalID, int additionalParentIndex)
replace the parent additional of a shape
Definition: GNEHierarchicalParentElements.cpp:489
SUMO_ATTR_POSITION
Definition: SUMOXMLDefinitions.h:660
GNEGeometry::Geometry::getPosition
const Position & getPosition() const
get Position
Definition: GNEGeometry.cpp:127
GUIVisualizationSettings::colorSettings
GUIVisualizationColorSettings colorSettings
color settings
Definition: GUIVisualizationSettings.h:677
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
GNEDetectorEntryExit::isAttributeEnabled
bool isAttributeEnabled(SumoXMLAttr key) const
Definition: GNEDetectorEntryExit.cpp:330
GLIncludes.h
GUIVisualizationColorSettings::E3Exit
static const RGBColor E3Exit
color for Exits
Definition: GUIVisualizationSettings.h:219
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
Position::y
double y() const
Returns the y-position.
Definition: Position.h:61
GNEDetectorEntryExit::updateGeometry
void updateGeometry()
update pre-computed geometry information
Definition: GNEDetectorEntryExit.cpp:117
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
GNE_ATTR_BLOCK_MOVEMENT
block movement of a graphic element
Definition: SUMOXMLDefinitions.h:981
GNEDetectorEntryExit::isValid
bool isValid(SumoXMLAttr key, const std::string &value)
method for checking if the key and their conrrespond attribute are valids
Definition: GNEDetectorEntryExit.cpp:305
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
GNEDetectorEntryExit::setAttribute
void setAttribute(SumoXMLAttr key, const std::string &value, GNEUndoList *undoList)
method for setting the attribute and letting the object perform additional changes
Definition: GNEDetectorEntryExit.cpp:283
GNENet::retrieveLane
GNELane * retrieveLane(const std::string &id, bool failHard=true, bool checkVolatileChange=false)
get lane by id
Definition: GNENet.cpp:1228
SUMO_TAG_E3DETECTOR
an e3 detector
Definition: SUMOXMLDefinitions.h:73
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
GNE_ATTR_SELECTED
element is selected
Definition: SUMOXMLDefinitions.h:971
GNEDetectorEntryExit::~GNEDetectorEntryExit
~GNEDetectorEntryExit()
destructor
Definition: GNEDetectorEntryExit.cpp:49
GNEDetectorEntryExit::commitGeometryMoving
void commitGeometryMoving(GNEUndoList *undoList)
commit geometry changes in the attributes of an element after use of moveGeometry(....
Definition: GNEDetectorEntryExit.cpp:108
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
GNEAttributeCarrier::getTagStr
const std::string & getTagStr() const
get tag assigned to this object in string format
Definition: GNEAttributeCarrier.cpp:1267
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
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
GNEAdditional::AdditionalMove::firstOriginalLanePosition
std::string firstOriginalLanePosition
value for saving first original position over lane before moving
Definition: GNEAdditional.h:294
SUMO_TAG_DET_EXIT
an e3 exit point
Definition: SUMOXMLDefinitions.h:83
GNELane
This lane is powered by an underlying GNEEdge and basically knows how to draw itself.
Definition: GNELane.h:45
GNEAdditionalHandler::checkAndFixDetectorPosition
static bool checkAndFixDetectorPosition(double &pos, const double laneLength, const bool friendlyPos)
check if the position of a detector over a lane is valid
Definition: GNEAdditionalHandler.cpp:987
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
GNEAdditional::BlockIcon::offset
Position offset
The offSet of the block icon.
Definition: GNEAdditional.h:321
GNEUndoList.h
GNE_ATTR_PARENT
parent of an additional element
Definition: SUMOXMLDefinitions.h:987
GLHelper::drawTriangleAtEnd
static void drawTriangleAtEnd(const Position &p1, const Position &p2, double tLength, double tWidth)
Draws a triangle at the end of the given line.
Definition: GLHelper.cpp:440