41 GNERerouter::GNERerouter(
const std::string&
id,
GNEViewNet* viewNet,
const Position& pos,
const std::vector<GNEEdge*>& edges,
const std::string& name,
const std::string& filename,
double probability,
bool off,
double timeThreshold,
const std::string& vTypes,
bool blockMovement) :
45 myProbability(probability),
47 myTimeThreshold(timeThreshold),
143 glRotated(180, 0, 0, 1);
163 if (s.
scale * exaggeration >= 3) {
167 glTranslated(i.first.x(), i.first.y(),
getType());
168 glRotated(-1 * i.second, 0, 0, 1);
169 glScaled(exaggeration, exaggeration, 1);
170 glPolygonMode(GL_FRONT_AND_BACK, GL_FILL);
172 glBegin(GL_TRIANGLES);
173 glColor3d(1, .8f, 0);
175 glVertex2d(0 - 1.4, 0);
176 glVertex2d(0 - 1.4, 6);
177 glVertex2d(0 + 1.4, 6);
178 glVertex2d(0 + 1.4, 0);
179 glVertex2d(0 - 1.4, 0);
180 glVertex2d(0 + 1.4, 6);
293 return canParse<std::vector<GNEEdge*> >(
myViewNet->
getNet(), value,
false);
296 return canParse<Position>(value);
302 return canParse<double>(value) && (parse<double>(value) >= 0) && (parse<double>(value) <= 1);
304 return canParse<double>(value) && (parse<double>(value) >= 0);
312 return canParse<bool>(value);
314 return canParse<bool>(value);
316 return canParse<bool>(value);
349 i->removeAdditionalParent(
this);
352 myEdgeChilds = parse<std::vector<GNEEdge*> >(
myViewNet->
getNet(), value);
354 for (
auto i : myEdgeChilds) {
355 i->addAdditionalParent(
this);
378 myOff = parse<bool>(value);
384 if (parse<bool>(value)) {
static void drawTexturedBox(int which, double size)
Draws a named texture as a box with the given size.
double scale
information about a lane's width (temporary, used for a single view)
~GNERerouter()
Destructor.
static bool isValidAttribute(const std::string &value)
whether the given string is a valid attribute for a certain key (for example, a name) ...
static bool isValidListOfTypeID(const std::string &value)
whether the given string is a valid list of ids for an edge or vehicle type (empty aren't allowed) ...
GUIVisualizationTextSettings addName
void add(const Position &pos)
Adds the given position to this one.
void setGenericParametersStr(const std::string &value)
set generic parameters in string format
const std::string & getAdditionalID() const
returns Additional ID
static GUIGlID getTexture(GUITexture which)
returns a texture previously defined in the enum GUITexture
Stores the information about how to visualize structures.
Position offset
The offSet of the block icon.
Position snapToActiveGrid(const Position &pos) const
Returns a position that is mapped to the closest grid point if the grid is active.
std::string getAttribute(SumoXMLAttr key) const
Position getPositionInView() const
Returns position of additional in view.
static std::string parseIDs(const std::vector< T > &ACs)
parses a list of specific Attribute Carriers into a string of IDs
Position myPosition
position of rerouter in view
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)
std::string getPopUpID() const
get PopPup ID (Used in AC Hierarchy)
void unselectAttributeCarrier(bool changeFlag=true)
unselect attribute carrier using GUIGlobalSelection
Position position
position of the block icon
bool myOff
attribute to enable or disable inactive initially
BlockIcon myBlockIcon
variable BlockIcon
Position originalViewPosition
value for saving first original position over lane before moving
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...
SumoXMLAttr
Numbers representing SUMO-XML - attributes.
GNERerouter(const std::string &id, GNEViewNet *viewNet, const Position &pos, const std::vector< GNEEdge *> &edges, const std::string &name, const std::string &filename, double probability, bool off, double timeThreshold, const std::string &vTypes, bool blockMovement)
Constructor.
static const RGBColor BLACK
double myProbability
probability of rerouter
bool isAttributeCarrierSelected() const
check if attribute carrier is selected
void changeAdditionalID(const std::string &newID)
change ID of additional
std::vector< std::pair< Position, double > > symbolsPositionAndRotation
position and rotation of every symbol over lane
void commitGeometryMoving(GNEUndoList *undoList)
commit geometry changes in the attributes of an element after use of moveGeometry(...)
Boundary getCenteringBoundary() const
Returns the boundary to which the view shall be centered in order to show the object.
GNEViewNet * myViewNet
The GNEViewNet this additional element belongs.
AdditionalMove myMove
variable AdditionalMove
void p_add(GNEChange_Attribute *cmd)
special method, avoid empty changes, always execute
void setAttribute(SumoXMLAttr key, const std::string &value, GNEUndoList *undoList)
method for setting the attribute and letting the object perform additional changes ...
void moveGeometry(const Position &offset)
change the position of the element geometry without saving in undoList
GUIVisualizationSizeSettings addSize
Dialog for edit rerouters.
bool isValid(SumoXMLAttr key, const std::string &value)
method for checking if the key and their conrrespond attribute are valids
void draw() const
draw connections between Parent and childrens
GUIGlObjectType getType() const
Returns the type of the object as coded in GUIGlObjectType.
std::string toString(const T &t, std::streamsize accuracy=gPrecision)
static void setColor(const RGBColor &c)
Sets the gl-color to this value.
std::string myFilename
filename of rerouter
void p_end()
End undo command sub-group. If the sub-group is still empty, it will be deleted; otherwise, the sub-group will be added as a new command into parent group. A matching begin() must have been called previously.
A point in 2D or 3D with translation and scaling methods.
PositionVector shape
The shape of the additional element.
std::string myAdditionalName
name of additional
std::vector< PositionVector > connectionPositions
Matrix with the Vertex's positions of connections between parents an their childs.
static bool isGenericParametersValid(const std::string &value)
check if given string can be parsed to a map/list of generic parameters
void removeGLObjectFromGrid(GUIGlObject *o)
add GL Object into net
friend class GNEChange_Attribute
declare friend class
void selectAttributeCarrier(bool changeFlag=true)
block movement of a graphic element
void drawName(const Position &pos, const double scale, const GUIVisualizationTextSettings &settings, const double angle=0) const
draw name of item
ChildConnections myChildConnections
variable ChildConnections
virtual const std::string & getMicrosimID() const
Returns the id of the object as known to microsim.
const std::string getID() const
function to support debugging
bool myBlockMovement
boolean to check if additional element is blocked (i.e. cannot be moved with mouse) ...
std::vector< GNEAdditional * > myAdditionalChilds
vector with the Additional childs
std::string myVTypes
optional vehicle types for restricting the rerouter
static const RGBColor RED
named colors
void drawGL(const GUIVisualizationSettings &s) const
Draws the object.
static void drawShapeDottedContour(const int type, const PositionVector &shape, const double width)
draw a dotted contour around the given Non closed shape with certain width
An Element which don't belongs to GNENet but has influency in the simulation.
const GNEAttributeCarrier * getDottedAC() const
get AttributeCarrier under cursor
AdditionalGeometry myGeometry
geometry to be precomputed in updateGeometry(...)
const std::string & getTagStr() const
get tag assigned to this object in string format
void updateGeometry(bool updateGrid)
update pre-computed geometry information
std::string getGenericParametersStr() const
return generic parameters in string format
std::string getParentName() const
Returns the name of the parent object (if any)
GNENet * getNet() const
get the net object
std::string generateAdditionalChildID(SumoXMLTag childTag)
gererate a new ID for an additional child
GUIGlID getGlID() const
Returns the numerical id of the object.
an aggreagated-output interval
void update()
update Connection's geometry
double myTimeThreshold
attribute to configure activation time threshold
bool isValidAdditionalID(const std::string &newID) const
check if a new additional ID is valid
static void drawBoxLine(const Position &beg, double rot, double visLength, double width, double offset=0)
Draws a thick line.
bool drawForSelecting
whether drawing is performed for the purpose of selecting objects
double getExaggeration(const GUIVisualizationSettings &s, const GUIGlObject *o, double factor=20) const
return the drawing size including exaggeration and constantSize values
void addGLObjectIntoGrid(GUIGlObject *o)
add GL Object into net
static bool isValidFilename(const std::string &value)
whether the given string is a valid attribute for a filename (for example, a name) ...
std::string getHierarchyName() const
get Hierarchy Name (Used in AC Hierarchy)
void setRotation(GNELane *additionalLane=nullptr)
set Rotation of block Icon (must be called in updateGeometry(bool updateGrid) function) ...
void openAdditionalDialog()
open GNERerouterDialog
void draw(double size=0.5) const
draw lock icon
std::vector< GNEEdge * > myEdgeChilds
vector with the edge childs of this additional