62 double frompos,
double topos,
unsigned int capacity,
63 double width,
double length,
double angle)
64 :
MSParkingArea(id, lines, lane, frompos, topos, capacity, width, length, angle),
69 int e = (int)
myShape.size() - 1;
70 for (
int i = 0; i < e; ++i) {
74 myShapeRotations.push_back((
double) atan2((s.
x() - f.
x()), (f.
y() - s.
y())) * (double) 180.0 / (
double)
PI);
133 if (s.
scale * exaggeration >= 10) {
135 glTranslated(0, 0, .1);
136 std::map<unsigned int, LotSpaceDefinition >::const_iterator i;
139 glTranslated((*i).second.myPosition.x(), (*i).second.myPosition.y(), (*i).second.myPosition.z());
140 glRotated((*i).second.myRotation, 0, 0, 1);
141 Position pos = (*i).second.myPosition;
143 double w = (*i).second.myWidth / 2.;
144 double h = (*i).second.myLength;
145 geom.push_back(
Position(- w, + 0, 0.));
146 geom.push_back(
Position(+ w, + 0, 0.));
147 geom.push_back(
Position(+ w, + h, 0.));
148 geom.push_back(
Position(- w, + h, 0.));
149 geom.push_back(
Position(- w, + 0, 0.));
163 for (
size_t i = 0; i !=
myLines.size(); ++i) {
166 glRotated(180, 1, 0, 0);
168 glPolygonMode(GL_FRONT_AND_BACK, GL_FILL);
171 glScaled(exaggeration, exaggeration, 1);
172 glTranslated(1.2, -(
double)i, 0);
179 if (s.
scale * exaggeration > 25) {
180 noPoints =
MIN2((
int)(9.0 + (s.
scale * exaggeration) / 10.0), 36);
182 glScaled(exaggeration, exaggeration, 1);
184 glTranslated(0, 0, .1);
187 if (s.
scale * exaggeration >= 4.5) {
195 glTranslated(0, 1, 0);
A lane area vehicles can halt at.
int pfDrawString(const char *c)
double rotationDegreeAtOffset(double pos) const
Returns the rotation at the given length.
double scale
information about a lane's width (temporary, used for a single view)
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.
GUIVisualizationTextSettings addName
std::vector< MSTransportable * > myWaitingTransportables
Persons waiting at this stop.
void buildNameCopyPopupEntry(GUIGLObjectPopupMenu *ret, bool addSeparator=true)
Builds entries which allow to copy the name / typed name into the clipboard.
void pfSetScale(double s)
const double myEndPos
The end position this bus stop is located at.
Stores the information about how to visualize structures.
GUIParkingArea(const std::string &id, const std::vector< std::string > &lines, MSLane &lane, double frompos, double topos, unsigned int capacity, double width, double length, double angle)
Constructor.
double y() const
Returns the y-position.
double x() const
Returns the x-position.
void buildCenterPopupEntry(GUIGLObjectPopupMenu *ret, bool addSeparator=true)
Builds an entry which allows to center to the object.
void pfSetPosition(double x, double y)
void buildShowParamsPopupEntry(GUIGLObjectPopupMenu *ret, bool addSeparator=true)
Builds an entry which allows to open the parameter window.
static void drawFilledCircle(double width, int steps=8)
Draws a filled circle around (0,0)
void buildPositionCopyEntry(GUIGLObjectPopupMenu *ret, bool addSeparator=true)
Builds an entry which allows to copy the cursor position if geo projection is used, also builds an entry for copying the geo-position.
double getWidth() const
Returns the lane's width.
A class that stores a 2D geometrical boundary.
Position getLineCenter() const
get line center
GUIVisualizationSizeSettings addSize
std::vector< double > myShapeLengths
The lengths of the shape parts.
GUIGlObjectType getType() const
Returns the type of the object as coded in GUIGlObjectType.
static void setColor(const RGBColor &c)
Sets the gl-color to this value.
A point in 2D or 3D with translation and scaling methods.
GUIGLObjectPopupMenu * getPopUpMenu(GUIMainWindow &app, GUISUMOAbstractView &parent)
Returns an own popup-menu.
std::vector< double > myShapeRotations
The rotations of the shape parts.
PositionVector myShape
The roadside shape of this parkingArea.
int getCapacity() const
Returns the area capacity.
void drawName(const Position &pos, const double scale, const GUIVisualizationTextSettings &settings, const double angle=0) const
draw name of item
void drawGL(const GUIVisualizationSettings &s) const
Draws the object.
Boundary & grow(double by)
extends the boundary by the given amount
int getOccupancy() const
Returns the area occupancy.
void move2side(double amount)
move position vector to side using certain ammount
const double myBegPos
The begin position this bus stop is located at.
double length() const
Returns the length.
void drawGL(const GUIVisualizationSettings &s) const
Draws the object.
void buildSelectionPopupEntry(GUIGLObjectPopupMenu *ret, bool addSeparator=true)
Builds an entry which allows to (de)select the 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
double distanceTo(const Position &p2) const
returns the euclidean distance in 3 dimension
Boundary getBoxBoundary() const
Returns a boundary enclosing this list of lines.
~GUIParkingArea()
Destructor.
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)
draw Text with given parameters
std::map< unsigned int, LotSpaceDefinition > mySpaceOccupancies
A map from objects (vehicles) to the areas they acquire after entering the stop.
std::vector< std::string > myLines
The list of lines that are assigned to this stop.
void mkItem(const char *name, bool dynamic, ValueSource< unsigned > *src)
Adds a row which obtains its value from an unsigned-ValueSource.
double myWidth
The default width of each parking space.
void closeBuilding()
Closes the building of the table.
GUIParameterTableWindow * getParameterWindow(GUIMainWindow &app, GUISUMOAbstractView &parent)
Returns an own parameter window.
Representation of a lane in the micro simulation.
A window containing a gl-object's parameter.
Position mySignPos
The position of the sign.
Boundary getCenteringBoundary() const
Returns the boundary to which the view shall be centered in order to show the object.
double mySignRot
The rotation of the sign.
void buildPopupHeader(GUIGLObjectPopupMenu *ret, GUIMainWindow &app, bool addSeparator=true)
Builds the header.