67 myStartTime(startTime),
109 Position s =
myShape[0] + Position(1, 0);
134 return Position((A.
x() + B.
x()) / 2, (A.
y() + B.
y()) / 2);
196 double width = (double) 2.0 * s.
scale;
201 glColor3ub(120, 216, 0);
206 glScaled(exaggeration, exaggeration, 1);
207 glTranslated(-1.6, -1.6, 0);
210 glVertex2d(0, -0.25);
214 glTranslated(0, 0, .01);
216 glVertex2d(0, 0.25 - .1);
217 glVertex2d(0, -0.25 + .1);
221 if (width * exaggeration > 1) {
222 glRotated(90, 0, 0, -1);
239 glRotated(-90, 0, 0, 1);
252 if (s.
scale * exaggeration >= 10) {
315 if (canParse<double>(value) && (parse<double>(value) >= 0)) {
316 double startTime = parse<double>(value);
317 if (startTime <=
myEnd) {
326 if (canParse<double>(value) && (parse<double>(value) >= 0)) {
327 double end = parse<double>(value);
355 myEnd = parse<double>(value);
static void drawTexturedBox(int which, double size)
Draws a named texture as a box with the given size.
double myStartTime
start time of vaporizer
OutputDevice & writeAttr(const SumoXMLAttr attr, const T &val)
writes a named attribute
double rotationDegreeAtOffset(double pos) const
Returns the rotation at the given length.
GNEEdge * retrieveEdge(const std::string &id, bool failHard=true)
get edge by id
double scale
information about a lane's width (temporary, used for a single view)
void setEndTime(double end)
set end
void commmitAdditionalGeometryMoved(double, double, GNEUndoList *)
updated geometry changes in the attributes of additional
GUIVisualizationTextSettings addName
const std::string & getAdditionalID() const
returns the ID of additional
void setStartTime(double startTime)
set start time
static GUIGlID getTexture(GUITexture which)
returns a texture previously defined in the enum GUITexture
GNEAdditional * getAdditional(SumoXMLTag type, const std::string &id) const
Returns the named additional.
Stores the information about how to visualize structures.
double y() const
Returns the y-position.
void writeAdditional(OutputDevice &device) const
writte additional element into a xml file
void drawGL(const GUIVisualizationSettings &s) const
Draws the object.
double x() const
Returns the x-position.
This lane is powered by an underlying GNEEdge and basically knows how to draw itself.
SumoXMLAttr
Numbers representing SUMO-XML - attributes.
std::vector< double > myShapeRotations
Position getLineCenter() const
get line center
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.
void p_add(GNEChange_Attribute *cmd)
special method, avoid empty changes, always execute
GUIVisualizationSizeSettings addSize
GUIGlObjectType getType() const
Returns the type of the object as coded in GUIGlObjectType.
void drawLockIcon(double size=0.5) const
draw lock icon
std::string toString(const T &t, std::streamsize accuracy=gPrecision)
void changeEdge(const std::string &edgeID)
change edge of additional
bool myMovable
boolean to check if additional element is movable (with the mouse). By default true ...
const std::string & getParentName() const
Returns the name of the parent object (if any)
void refreshAdditional(GNEAdditional *additional)
refreshes boundary information of an additional after a geometry update
PositionVector myShape
The shape of the additional element.
bool isValid(SumoXMLAttr key, const std::string &value)
method for checking if the key and their conrrespond attribute are valids
A point in 2D or 3D with translation and scaling methods.
void setBlockIconRotation(GNELane *lane=NULL)
set Rotation of block Icon
friend class GNEChange_Attribute
declare friend class
virtual void centerTo(GUIGlID id, bool applyZoom, double zoomDist=20)
centers to the chosen artifact
std::vector< double > myShapeLengths
The lengths of the shape parts.
void drawName(const Position &pos, const double scale, const GUIVisualizationTextSettings &settings, const double angle=0) const
draw name of item
void setAdditionalID(const std::string &id)
set the ID of additional
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
std::string getAttribute(SumoXMLAttr key) const
int getVaporizerRelativePosition(GNEVaporizer *vaporizer) const
obtain relative positions of Vaporizer
Position myBlockIconOffset
The offSet of the block icon.
A road/street connecting two junctions (netedit-version)
Position getPositionInView() const
Returns position of Vaporizer in view.
const PositionVector & getShape() const
returns the shape of the lane
const std::vector< GNELane * > & getLanes()
returns a reference to the lane vector
double getEnd() const
get end
void setAttribute(SumoXMLAttr key, const std::string &value, GNEUndoList *undoList)
method for setting the attribute and letting the object perform additional changes ...
An Element which don't belongs to GNENet but has influency in the simulation.
double myEnd
end time in which this vaporizer is placed
GNENet * getNet() const
get the net object
GUIGlID getGlID() const
Returns the numerical id of the object.
double getExaggeration(const GUIVisualizationSettings &s, double factor=20) const
return the drawing size including exaggeration and constantSize values
int myRelativePosition
relative position regarding to other route probes
double getStartTime() const
get start time
Static storage of an output device and its base (abstract) implementation.
Position myPosition
The position in which this additional element is located.
bool closeTag()
Closes the most recently opened tag.
GNEVaporizer(GNEViewNet *viewNet, GNEEdge *edge, double startTime, double end)
Constructor.
bool isAdditionalSelected() const
void moveAdditionalGeometry(double, double)
change the position of the RouteProbe geometry
int myNumberOfLanes
number of lanes of edge (To improve efficiency)
GNEEdge * myEdge
The edge this additional belongs.
~GNEVaporizer()
Destructor.
Position positionAtOffset(double pos, double lateralOffset=0) const
Returns the position at the given length.
void updateGeometry()
update pre-computed geometry information
OutputDevice & openTag(const std::string &xmlElement)
Opens an XML tag.
Position myBlockIconPosition
position of the block icon
SumoXMLTag getTag() const
get XML Tag assigned to this object