45myCreationIndex(myNet->getAttributeCarriers()->getStopIndex()) {
57 myTagProperty.isWaypoint() ? parametersSet |=
STOP_SPEED_SET : parametersSet &= ~STOP_SPEED_SET;
65myCreationIndex(myNet->getAttributeCarriers()->getStopIndex()) {
77 stopParameter.onDemand ? parametersSet |=
STOP_ONDEMAND_SET : parametersSet &= ~STOP_ONDEMAND_SET;
79 myTagProperty.isWaypoint() ? parametersSet |=
STOP_SPEED_SET : parametersSet &= ~STOP_SPEED_SET;
87myCreationIndex(myNet->getAttributeCarriers()->getStopIndex()) {
95 stopParameter.onDemand ? parametersSet |=
STOP_ONDEMAND_SET : parametersSet &= ~STOP_ONDEMAND_SET;
97 myTagProperty.isWaypoint() ? parametersSet |=
STOP_SPEED_SET : parametersSet &= ~STOP_SPEED_SET;
105myCreationIndex(myNet->getAttributeCarriers()->getStopIndex()) {
120 stopParameter.onDemand ? parametersSet |=
STOP_ONDEMAND_SET : parametersSet &= ~STOP_ONDEMAND_SET;
122 myTagProperty.isWaypoint() ? parametersSet |=
STOP_SPEED_SET : parametersSet &= ~STOP_SPEED_SET;
215 write(device,
true,
false);
230 }
else if (firstLane !=
nullptr) {
236 if ((endPosFixed <=
getParentEdges().front()->getNBEdge()->getFinalLength()) && (endPosFixed > 0)) {
253 double laneLength =
getParentLanes().front()->getParentEdge()->getNBEdge()->getFinalLength() *
getParentLanes().front()->getLengthGeometryFactor();
256 double endPosCopy =
endPos;
258 if (startPosCopy < 0) {
259 startPosCopy += laneLength;
261 if (endPosCopy < 0) {
262 endPosCopy += laneLength;
265 if ((startPosCopy >= 0) && (endPosCopy <=
getParentLanes().front()->getParentEdge()->getNBEdge()->getFinalLength()) && ((endPosCopy - startPosCopy) >= POSITION_EPS)) {
282 const double laneLength =
getParentEdges().front()->getNBEdge()->getFinalLength();
286 if (endPosFixed < 0) {
288 }
else if (endPosFixed >
getParentEdges().front()->getNBEdge()->getFinalLength()) {
297 double endPosCopy =
endPos;
299 double laneLength =
getParentLanes().front()->getParentEdge()->getNBEdge()->getFinalLength();
301 if (startPosCopy < 0) {
302 startPosCopy += laneLength;
304 if (endPosCopy < 0) {
305 endPosCopy += laneLength;
308 std::string errorStart, separator, errorEnd;
310 if (startPosCopy < 0) {
312 }
else if (startPosCopy >
getParentLanes().front()->getParentEdge()->getNBEdge()->getFinalLength()) {
315 if (endPosCopy < 0) {
317 }
else if (endPosCopy >
getParentLanes().front()->getParentEdge()->getNBEdge()->getFinalLength()) {
321 if ((errorStart.size() > 0) && (errorEnd.size() > 0)) {
324 return errorStart + separator + errorEnd;
349 if ((AC->getTagProperty().isRoute() || AC->getTagProperty().isVehicle()) && (AC !=
getParentDemandElements().front())) {
483 bool drawStop =
false;
649 std::vector<GNEDemandElement*> stops;
651 if (parent->getTagProperty().isStop()) {
652 stops.push_back(parent);
656 for (
int i = 0; i < (int)stops.size(); i++) {
657 if (stops.at(i) ==
this) {
661 return "invalid index";
689 std::vector<GNEDemandElement*> stops, filteredStops;
691 if (parent->getTagProperty().isStop()) {
692 stops.push_back(parent);
696 for (
const auto& stop : stops) {
698 filteredStops.push_back(stop);
702 for (
int i = 0; i < (int)filteredStops.size(); i++) {
703 if (filteredStops.at(i) ==
this) {
728 return laneShape.front();
730 return laneShape.back();
779 if (nextPersonPlan) {
794 if (nextPersonPlan) {
814 if (nextPersonPlan) {
862 if (canParse<SUMOTime>(value)) {
863 return parse<SUMOTime>(value) >= 0;
871 const std::set<std::string> expectedValues = {
"true",
"false",
"person",
"container",
"join"};
872 const std::vector<std::string> triggeredValues = parse<std::vector<std::string> >(value);
873 for (
const auto& triggeredValue : triggeredValues) {
874 if (expectedValues.find(triggeredValue) == expectedValues.end()) {
884 const std::vector<std::string> expectedValues = parse<std::vector<std::string> >(value);
885 for (
const auto& expectedValue : expectedValues) {
893 const std::vector<std::string> expectedValues = parse<std::vector<std::string> >(value);
894 for (
const auto& expectedValue : expectedValues) {
902 if (value ==
"opportunistic") {
905 return canParse<bool>(value);
914 return canParse<bool>(value);
917 if (canParse<double>(value)) {
918 return (parse<double>(value) >= 0);
946 if (canParse<double>(value)) {
953 return canParse<double>(value) && fabs(parse<double>(value)) <
getParentEdges().front()->getNBEdge()->getFinalLength();
954 }
else if (canParse<double>(value)) {
960 return canParse<bool>(value);
965 return canParse<double>(value);
969 return canParse<bool>(value);
1083 const double len =
getParentLanes().front()->getParentEdge()->getNBEdge()->getFinalLength();
1087 return fixedPos *
getParentLanes().front()->getLengthGeometryFactor();
1093 double fixedPos =
endPos;
1094 const double len =
getParentLanes().front()->getParentEdge()->getNBEdge()->getFinalLength();
1098 return fixedPos *
getParentLanes().front()->getLengthGeometryFactor();
1111 if (pLane->allowPedestrians()) {
1149 const double width = stopLane ? stopLane->getParentEdge()->getNBEdge()->getLaneWidth(stopLane->getIndex()) * 0.5 : exaggeration * 0.8;
1164 exaggeration * 0.1, 0, width);
1168 exaggeration * 0.1, 0, width * -1);
1178 glTranslated(0, exaggeration * 0.5, 0);
1182 glTranslated(0, 1, 0.1);
1191 glTranslated(0, 1.4, 0);
1197 glTranslated(-2.1, -2.4, 0);
1198 glRotated(-90, 0, 0, 1);
1221 glTranslated(-1.4, exaggeration * 0.5, 0.1);
1222 glRotated(-90, 0, 0, 1);
1240 width, exaggeration,
true,
true);
1245 width, exaggeration,
true,
true);
1250 width, exaggeration,
true,
true);
1255 width, exaggeration,
true,
true);
1277 glTranslated(0, 0, .1);
1293 glRotated(180, 0, 0, 1);
1302 glRotated(22.5, 0, 0, 1);
1306 glTranslated(0, 0, 0);
1366 glRotated(-90, 0, 0, 1);
1375 glRotated(22.5, 0, 0, 1);
1379 glTranslated(0, 0, 0);
1392 exaggeration,
true,
true);
1397 exaggeration,
true,
true);
1402 exaggeration,
true,
true);
1407 exaggeration,
true,
true);
1419 }
else if (stopFrame->shown() && (stopFrame->getStopParentSelector()->getCurrentDemandElement() ==
getParentDemandElements().front())) {
1434 if (value.empty()) {
1442 if (value.empty()) {
1450 if (value.empty()) {
1469 if (value ==
"person") {
1475 }
else if (value ==
"container") {
1482 }
else if (value ==
"join") {
1505 if (value.empty()) {
1509 permitted = parse<std::set<std::string> >(value);
1532 if (parse<bool>(value)) {
1542 speed = parse<double>(value);
1577 endPos = parse<double>(value);
1584 if (value.empty()) {
1588 posLat = parse<double>(value);
1594 if (parse<bool>(value)) {
1740 glTranslated(0, 0, 0.1);
@ DEMAND_MOVE
mode for moving demand elements
GUIIcon
An enumeration of icons used by the gui applications.
std::string time2string(SUMOTime t)
convert SUMOTime to string
SUMOTime string2time(const std::string &r)
convert string to SUMOTime
SUMOVehicleClass
Definition of vehicle classes to differ between different lane usage and authority types.
@ SVC_PEDESTRIAN
pedestrian
const int STOP_DURATION_SET
const int STOP_POSLAT_SET
const int STOP_EXPECTED_SET
const int STOP_PARKING_SET
const int STOP_TRIP_ID_SET
const int STOP_PERMITTED_SET
const int STOP_CONTAINER_TRIGGER_SET
const int STOP_EXTENSION_SET
const int STOP_TRIGGER_SET
const int STOP_ONDEMAND_SET
const int STOP_EXPECTED_CONTAINERS_SET
SumoXMLTag
Numbers representing SUMO-XML - element names.
@ GNE_TAG_WAYPOINT_PARKINGAREA
waypoint placed over a parking area (used in netedit)
@ SUMO_TAG_CHARGING_STATION
A Charging Station.
@ SUMO_TAG_CONTAINER_STOP
A container stop.
@ SUMO_TAG_STOP_LANE
stop placed over a lane (used in netedit)
@ GNE_TAG_STOPCONTAINER_EDGE
@ SUMO_TAG_BUS_STOP
A bus stop.
@ SUMO_TAG_STOP
stop for vehicles
@ GNE_TAG_FLOW_WITHROUTE
description of a vehicle with an embedded route (used in NETEDIT)
@ SUMO_TAG_PARKING_AREA
A parking area.
@ GNE_TAG_VEHICLE_WITHROUTE
description of a vehicle with an embedded route (used in NETEDIT)
@ GNE_TAG_WAYPOINT_LANE
waypoint placed over a lane (used in netedit)
@ SUMO_TAG_STOP_PARKINGAREA
stop placed over a parking area (used in netedit)
@ GNE_TAG_STOPPERSON_EDGE
SumoXMLAttr
Numbers representing SUMO-XML - attributes.
@ SUMO_ATTR_CONTAINER_STOP
@ GNE_ATTR_PARENT
parent of an additional element
@ GNE_ATTR_SELECTED
element is selected
@ SUMO_ATTR_CHARGING_STATION
@ GNE_ATTR_STOPINDEX
stop index
@ SUMO_ATTR_EXPECTED_CONTAINERS
const double INVALID_DOUBLE
std::string toString(const T &t, std::streamsize accuracy=gPrecision)
A class that stores a 2D geometrical boundary.
void add(double x, double y, double z=0)
Makes the boundary include the given coordinate.
bool isInitialised() const
check if Boundary is Initialised
Boundary & grow(double by)
extends the boundary by the given amount
GNEDemandElement * getCurrentDemandElement() const
get current demand element
static void setColor(const RGBColor &c)
Sets the gl-color to this value.
static void drawFilledCircle(double width, int steps=8)
Draws a filled circle around (0,0)
static void pushName(unsigned int name)
push Name
static void popMatrix()
pop matrix
static void drawBoxLines(const PositionVector &geom, const std::vector< double > &rots, const std::vector< double > &lengths, double width, int cornerDetail=0, double offset=0)
Draws thick lines.
static void drawBoxLine(const Position &beg, double rot, double visLength, double width, double offset=0)
Draws a thick line.
static void popName()
pop Name
static void pushMatrix()
push matrix
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, const int align=0, double width=-1)
An Element which don't belong to GNENet but has influence in the simulation.
const std::string getID() const
get ID (all Attribute Carriers have one)
bool isAttributeCarrierSelected() const
check if attribute carrier is selected
friend class GNEChange_EnableAttribute
friend class GNEChange_Attribute
declare friend class
const std::string & getTagStr() const
get tag assigned to this object in string format
const GNETagProperties & getTagProperty() const
get tagProperty associated with this Attribute Carrier
void unselectAttributeCarrier(const bool changeFlag=true)
unselect attribute carrier using GUIGlobalSelection
bool drawUsingSelectColor() const
check if attribute carrier must be drawn using selecting color.
GNENet * myNet
pointer to net
void selectAttributeCarrier(const bool changeFlag=true)
select attribute carrier using GUIGlobalSelection
const GNETagProperties & myTagProperty
reference to tagProperty associated with this attribute carrier
An Element which don't belong to GNENet but has influence in the simulation.
void replaceDemandParentEdges(const std::string &value)
replace demand parent edges
void replaceDemandElementParent(SumoXMLTag tag, const std::string &value, const int parentIndex)
replace demand element parent
Problem isPersonPlanValid() const
check if person plan is valid
GUIGeometry myDemandElementGeometry
demand element geometry (also called "stacked geometry")
bool drawContainerPlan() const
check if container plan can be drawn
std::string getPersonPlanProblem() const
get person plan problem
void replaceDemandParentLanes(const std::string &value)
replace demand parent lanes
virtual void setAttribute(SumoXMLAttr key, const std::string &value, GNEUndoList *undoList)=0
method for setting the attribute and letting the object perform demand element changes
void replaceAdditionalParent(SumoXMLTag tag, const std::string &value)
replace additional parent
Problem
enum class for demandElement problems
bool drawPersonPlan() const
A road/street connecting two junctions (netedit-version)
const std::vector< GNEDemandElement * > & getChildDemandElements() const
return child demand elements
const std::vector< GNEDemandElement * > & getParentDemandElements() const
get parent demand elements
const std::vector< GNEAdditional * > & getParentAdditionals() const
get parent additionals
const std::vector< GNEEdge * > & getParentEdges() const
get parent edges
const std::vector< GNELane * > & getParentLanes() const
get parent lanes
const double halfWidth
Draw as a normal lane, and reduce width to make sure that a selected edge can still be seen.
This lane is powered by an underlying GNEEdge and basically knows how to draw itself.
const PositionVector & getLaneShape() const
get elements shape
double getLengthGeometryFactor() const
get length geometry factor
double myMoveElementLateralOffset
move element lateral offset (used by elements placed over lanes
bool getAllowChangeLane() const
allow change lane
bool getLeaveStopPersonsConnected() const
check if leave stopPersonConnected is enabled
DemandModeOptions * getDemandModeOptions() const
get demand mode options
CommonModeOptions * getCommonModeOptions() const
get common mode options
const GNELane * newFirstLane
new first Lane
double newFirstPos
new first position
const GNEMoveOperation::OperationType operationType
move operation
double firstLaneOffset
lane offset
double newSecondPos
new second position
GNELane * retrieveLane(const std::string &id, bool hardFail=true, bool checkVolatileChange=false) const
get lane by id
GNEAdditional * retrieveAdditional(SumoXMLTag type, const std::string &id, bool hardFail=true) const
Returns the named additional.
GNEEdge * retrieveEdge(const std::string &id, bool hardFail=true) const
get edge by id
GNEDemandElement * retrieveDemandElement(SumoXMLTag type, const std::string &id, bool hardFail=true) const
Returns the named demand element.
A NBNetBuilder extended by visualisation and editing capabilities.
GNENetHelper::AttributeCarriers * getAttributeCarriers() const
get all attribute carriers used in this net
GNEViewNet * getViewNet() const
get view net
DemandElementSelector * getStopParentSelector() const
get stop parent selector
const RGBColor & getColor() const
get color
bool isValid(SumoXMLAttr key, const std::string &value)
method for checking if the key and their conrrespond attribute are valids
std::string getBegin() const
get begin time of demand element
SUMOVehicleClass getVClass() const
void disableAttribute(SumoXMLAttr key, GNEUndoList *undoList)
GNEStop(SumoXMLTag tag, GNENet *net)
default constructor
bool drawIndex() const
draw index
GNELane * getFirstPathLane() const
get first path lane
Position getAttributePosition(SumoXMLAttr key) const
std::string getPopUpID() const
get PopPup ID (Used in AC Hierarchy)
Position getPositionInView() const
Returns position of demand element in view.
void splitEdgeGeometry(const double splitPosition, const GNENetworkElement *originalElement, const GNENetworkElement *newElement, GNEUndoList *undoList)
split geometry
bool isAttributeEnabled(SumoXMLAttr key) const
void drawPartialGL(const GUIVisualizationSettings &s, const GNELane *lane, const GNEPathManager::Segment *segment, const double offsetFront) const
Draws partial object.
GNELane * getLastPathLane() const
get last path lane
void writeDemandElement(OutputDevice &device) const
write demand element element into a xml file
GNEMoveOperation * getMoveOperation()
get move operation
std::string getHierarchyName() const
get Hierarchy Name (Used in AC Hierarchy)
Boundary myMovingGeometryBoundary
boundary used during moving of elements (to avoid insertion in RTREE)
std::string getParentName() const
Returns the name of the parent object.
void drawStopPersonOverBusStop(const GUIVisualizationSettings &s, const double exaggeration) const
draw stopPerson over busStop
void enableAttribute(SumoXMLAttr key, GNEUndoList *undoList)
double getAttributeDouble(SumoXMLAttr key) const
std::string getAttribute(SumoXMLAttr key) const
inherited from GNEAttributeCarrier
void commitMoveShape(const GNEMoveResult &moveResult, GNEUndoList *undoList)
commit move shape
void drawGeometryPoints(const GUIVisualizationSettings &s, const RGBColor &baseColor) const
draw geometry points
Problem isDemandElementValid() const
check if current demand element is valid to be writed into XML (by default true, can be reimplemented...
void computePathElement()
compute pathElement
Boundary getCenteringBoundary() const
Returns the boundary to which the view shall be centered in order to show the object.
void drawGL(const GUIVisualizationSettings &s) const
Draws the object.
void setAttribute(SumoXMLAttr key, const std::string &value, GNEUndoList *undoList)
method for setting the attribute and letting the object perform demand element changes
void drawStopPersonOverEdge(const GUIVisualizationSettings &s, const double exaggeration) const
draw stopPerson over lane
void setMoveShape(const GNEMoveResult &moveResult)
set move shape
void fixDemandElementProblem()
fix demand element problem (by default throw an exception, has to be reimplemented in children)
double getExaggeration(const GUIVisualizationSettings &s) const
return exaggeration associated with this GLObject
const int myCreationIndex
creation index (using for saving sorted)
void drawVehicleStop(const GUIVisualizationSettings &s, const double exaggeration) const
draw vehicle stop
double getStartGeometryPositionOverLane() const
get start position over lane that is applicable to the shape
const Parameterised::Map & getACParametersMap() const
get parameters map
bool canDrawVehicleStop() const
check if vehicle stop can be draw
void updateGeometry()
update pre-computed geometry information
double getEndGeometryPositionOverLane() const
get end position over lane that is applicable to the shape
void toggleAttribute(SumoXMLAttr key, const bool value)
method for enable or disable the attribute and nothing else (used in GNEChange_EnableAttribute)
std::string getDemandElementProblem() const
return a string with the current demand element problem (by default empty, can be reimplemented in ch...
const GNELane * getFirstAllowedLane() const
get first valid lane
GUIIcon getGUIIcon() const
get GUI icon associated to this Tag
SumoXMLTag getTag() const
get Tag vinculated with this attribute Property
bool isWaypoint() const
return true if tag correspond to a waypoint element
bool isStopPerson() const
return true if tag correspond to a person stop element
bool isStopContainer() const
return true if tag correspond to a container stop element
bool hasAttribute(SumoXMLAttr attr) const
check if current TagProperties owns the attribute "attr"
void end()
End undo command sub-group. If the sub-group is still empty, it will be deleted; otherwise,...
void begin(GUIIcon icon, const std::string &description)
Begin undo command sub-group with current supermode. This begins a new group of commands that are tre...
void add(GNEChange *command, bool doit=false, bool merge=true)
Add new command, executing it if desired. The new command will be merged with the previous command if...
void changeAttribute(GNEChange_Attribute *change)
special method for change attributes, avoid empty changes, always execute
const GNEAttributeCarrier * getFrontAttributeCarrier() const
get front attributeCarrier
const GNEViewNetHelper::EditModes & getEditModes() const
get edit modes
const GNEViewNetHelper::MouseButtonKeyPressed & getMouseButtonKeyPressed() const
get Key Pressed module
bool drawSelectContour(const GUIGlObject *GLObject, const GNEAttributeCarrier *AC) const
check if draw select contour
bool drawDeleteContour(const GUIGlObject *GLObject, const GNEAttributeCarrier *AC) const
check if draw delete contour
void drawTranslateFrontAttributeCarrier(const GNEAttributeCarrier *AC, double typeOrLayer, const double extraOffset=0)
draw front attributeCarrier
GNEViewParent * getViewParent() const
get the net object
const std::vector< GNEAttributeCarrier * > & getInspectedAttributeCarriers() const
get inspected attribute carriers
bool isAttributeCarrierInspected(const GNEAttributeCarrier *AC) const
check if attribute carrier is being inspected
const GNEViewNetHelper::DemandViewOptions & getDemandViewOptions() const
get demand view options
GNEStopFrame * getStopFrame() const
get frame for DEMAND_STOP
GNEMoveFrame * getMoveFrame() const
get frame for move elements
static void drawDottedContourShape(const GUIVisualizationSettings &s, const DottedContourType type, const PositionVector &shape, const double width, const double exaggeration, const bool drawFirstExtrem, const bool drawLastExtrem)
draw dotted contour for the given shape (used by additionals)
static void rotateOverLane(const double rot)
rotate over lane (used by Lock icons, detector logos, etc.)
const std::vector< double > & getShapeRotations() const
The rotations of the single shape parts.
static void drawGeometry(const GUIVisualizationSettings &s, const Position &mousePos, const GUIGeometry &geometry, const double width, double offset=0)
draw geometry
const PositionVector & getShape() const
The shape of the additional element.
void updateGeometry(const PositionVector &shape)
update entire geometry
const std::vector< double > & getShapeLengths() const
The lengths of the single shape parts.
const std::string & getMicrosimID() const
Returns the id of the object as known to microsim.
void mouseWithinGeometry(const Position center, const double radius) const
check if mouse is within elements geometry (for circles)
GUIGlObjectType getType() const
Returns the type of the object as coded in GUIGlObjectType.
GUIGlID getGlID() const
Returns the numerical id of the object.
void drawName(const Position &pos, const double scale, const GUIVisualizationTextSettings &settings, const double angle=0, bool forceShow=false) const
draw name of item
const GUIVisualizationSettings & getVisualisationSettings() const
get visualization settings (read only)
virtual Position getPositionInformation() const
Returns the cursor's x/y position within the network.
static GUIGlID getTexture(GUITexture which)
returns a texture previously defined in the enum GUITexture
static void drawTexturedBox(int which, double size)
Draws a named texture as a box with the given size.
Stores the information about how to visualize structures.
GUIVisualizationTextSettings addName
bool drawForRectangleSelection
whether drawing is performed for the purpose of selecting objects using a rectangle
GUIVisualizationDetailSettings detailSettings
detail settings
GUIVisualizationSizeSettings addSize
GUIVisualizationColorSettings colorSettings
color settings
double scale
information about a lane's width (temporary, used for a single view)
GUIVisualizationStoppingPlaceSettings stoppingPlaceSettings
StoppingPlace settings.
bool drawDetail(const double detail, const double exaggeration) const
check if details can be drawn for the given GUIVisualizationDetailSettings and current scale and exxa...
GUIVisualizationAdditionalSettings additionalSettings
Additional settings.
int getCircleResolution() const
function to calculate circle resolution for all circles drawn in drawGL(...) functions
GUIVisualizationNeteditSizeSettings neteditSizeSettings
netedit size settings
Static storage of an output device and its base (abstract) implementation.
OutputDevice & writeAttr(const SumoXMLAttr attr, const T &val)
writes a named attribute
OutputDevice & openTag(const std::string &xmlElement)
Opens an XML tag.
std::map< std::string, std::string > Map
parameters map
const Parameterised::Map & getParametersMap() const
Returns the inner key/value map.
A point in 2D or 3D with translation and scaling methods.
double x() const
Returns the x-position.
double y() const
Returns the y-position.
double length2D() const
Returns the length.
double distance2D(const Position &p, bool perpendicular=false) const
closest 2D-distance to point p (or -1 if perpendicular is true and the point is beyond this vector)
Boundary getBoxBoundary() const
Returns a boundary enclosing this list of lines.
Position getLineCenter() const
get line center
Position positionAtOffset2D(double pos, double lateralOffset=0) const
Returns the position at the given length.
static const RGBColor WHITE
static const RGBColor GREY
RGBColor changedBrightness(int change, int toChange=3) const
Returns a new color with altered brightness.
static bool isStopPosValid(const double startPos, const double endPos, const double laneLength, const double minLength, const bool friendlyPos)
check if start and end position of a stop is valid
Definition of vehicle stop (position and duration)
std::string edge
The edge to stop at (used only in NETEDIT)
ParkingType parking
whether the vehicle is removed from the net while stopping
SUMOTime extension
The maximum time extension for boarding / loading.
bool friendlyPos
enable or disable friendly position (used by NETEDIT)
double speed
the speed at which this stop counts as reached (waypoint mode)
double startPos
The stopping position start.
std::string line
the new line id of the trip within a cyclical public transport route
double posLat
the lateral offset when stopping
bool onDemand
whether the stop may be skipped
std::set< std::string > permitted
IDs of persons or containers that may board/load at this stop.
int parametersSet
Information for the output which parameter were set.
SUMOTime until
The time at which the vehicle may continue its journey.
std::string actType
act Type (only used by Persons) (used by NETEDIT)
bool triggered
whether an arriving person lets the vehicle continue
void write(OutputDevice &dev, const bool close=true, const bool writeTagAndParents=true) const
Writes the stop as XML.
double endPos
The stopping position end.
std::set< std::string > awaitedPersons
IDs of persons the vehicle has to wait for until departing.
std::set< std::string > awaitedContainers
IDs of containers the vehicle has to wait for until departing.
bool joinTriggered
whether an joined vehicle lets this vehicle continue
std::string tripId
id of the trip within a cyclical public transport route
bool containerTriggered
whether an arriving container lets the vehicle continue
SUMOTime duration
The stopping duration.
static ParkingType parseParkingType(const std::string &value)
parses parking type value
static bool isValidVehicleID(const std::string &value)
whether the given string is a valid id for a vehicle or flow
bool showAllTrips() const
check if trips has to be drawn
DemandEditMode demandEditMode
the current Demand edit mode
bool isCurrentSupermodeDemand() const
@check if current supermode is Demand
static void drawLockIcon(const GNEAttributeCarrier *AC, GUIGlObjectType type, const Position viewPosition, const double exaggeration, const double size=0.5, const double offsetx=0, const double offsety=0)
draw lock icon
static const double vaporizerSize
Vaporizer size.
RGBColor selectedPersonPlanColor
person plan selection color (Rides, Walks, stopPersons...)
RGBColor stopPersonColor
color for stopPersons
RGBColor selectedRouteColor
route selection color (used for routes and vehicle stops)
RGBColor waypointColor
color for Waypoints
RGBColor stopColor
color for Stops
static const double laneTextures
details for lane textures
static const double stopsText
details for stop texts
static const double stopsDetails
details for stops
static const double additionalGeometryPointRadius
moving additional geometry point radius
double getExaggeration(const GUIVisualizationSettings &s, const GUIGlObject *o, double factor=20) const
return the drawing size including exaggeration and constantSize values
static const double busStopWidth
busStop width