63 double frompos,
double topos,
unsigned int capacity,
64 double width,
double length,
double angle) :
65 MSParkingArea(id, lines, lane, frompos, topos, capacity, width, length, angle),
70 int e = (int)
myShape.size() - 1;
71 for (
int i = 0; i < e; ++i) {
134 if (s.
scale * exaggeration >= 1) {
136 glTranslated(0, 0, .1);
137 std::map<unsigned int, LotSpaceDefinition >::const_iterator i;
140 glTranslated((*i).second.myPosition.x(), (*i).second.myPosition.y(), (*i).second.myPosition.z());
141 glRotated((*i).second.myRotation, 0, 0, 1);
142 Position pos = (*i).second.myPosition;
144 double w = (*i).second.myWidth / 2. - 0.1 * exaggeration;
145 double h = (*i).second.myLength;
146 geom.push_back(
Position(- w, + 0, 0.));
147 geom.push_back(
Position(+ w, + 0, 0.));
148 geom.push_back(
Position(+ w, + h, 0.));
149 geom.push_back(
Position(- w, + h, 0.));
150 geom.push_back(
Position(- w, + 0, 0.));
164 for (
size_t i = 0; i !=
myLines.size(); ++i) {
169 glRotated(180, 1, 0, 0);
180 if (s.
scale * exaggeration > 25) {
181 noPoints =
MIN2((
int)(9.0 + (s.
scale * exaggeration) / 10.0), 36);
183 glScaled(exaggeration, exaggeration, 1);
185 glTranslated(0, 0, .1);
188 if (s.
scale * exaggeration >= 4.5) {
196 glTranslated(0, 1, 0);
213 b.
add((*i).second.myPosition);
A lane area vehicles can halt at.
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)
void closeBuilding(const Parameterised *p=0)
Closes the building of the table.
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.
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.
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)
static MSNet * getInstance()
Returns the pointer to the unique instance of MSNet (singleton).
virtual const VehCont & getVehiclesSecure() const
Returns the vehicles container; locks it for microsimulation.
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
const MSLane & myLane
The lane this bus stop is located at.
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 drawGL(const GUIVisualizationSettings &s) const
Draws the object.
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
bool lefthand() const
return whether the network was built for lefthand traffic
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.
const std::set< const MSVehicle * > & getParkingVehicles() const
retrieve the parking vehicles (see GUIParkingArea)
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.
void add(double x, double y, double z=0)
Makes the boundary include the given coordinate.
std::map< unsigned int, LotSpaceDefinition > mySpaceOccupancies
A map from objects (vehicles) to the areas they acquire after entering the stop.
virtual void releaseVehicles() const
Allows to use the container for microsimulation again.
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.
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.
A MSVehicle extended by some values for usage within the gui.