Eclipse SUMO - Simulation of Urban MObility
GUIParkingArea.cpp
Go to the documentation of this file.
1 /****************************************************************************/
2 // Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.org/sumo
3 // Copyright (C) 2001-2019 German Aerospace Center (DLR) and others.
4 // This program and the accompanying materials
5 // are made available under the terms of the Eclipse Public License v2.0
6 // which accompanies this distribution, and is available at
7 // http://www.eclipse.org/legal/epl-v20.html
8 // SPDX-License-Identifier: EPL-2.0
9 /****************************************************************************/
16 // A area where vehicles can park next to the road (gui version)
17 /****************************************************************************/
18 
19 
20 // ===========================================================================
21 // included modules
22 // ===========================================================================
23 #include <config.h>
24 
25 #include <string>
28 #include <utils/geom/Boundary.h>
29 #include <utils/gui/div/GLHelper.h>
30 #include <utils/common/ToString.h>
31 #include <microsim/MSNet.h>
32 #include <microsim/MSLane.h>
33 #include <microsim/MSEdge.h>
34 #include "GUINet.h"
35 #include "GUIEdge.h"
36 #include "GUIContainer.h"
37 #include "GUIParkingArea.h"
40 #include <gui/GUIGlobals.h>
45 #include <utils/geom/GeomHelper.h>
46 #include <guisim/GUIParkingArea.h>
47 #include <guisim/GUIVehicle.h>
50 
51 
52 
53 // ===========================================================================
54 // method definitions
55 // ===========================================================================
56 GUIParkingArea::GUIParkingArea(const std::string& id, const std::vector<std::string>& lines, MSLane& lane,
57  double frompos, double topos, unsigned int capacity,
58  double width, double length, double angle, const std::string& name,
59  bool onRoad) :
60  MSParkingArea(id, lines, lane, frompos, topos, capacity, width, length, angle, name, onRoad),
62  const double offsetSign = MSNet::getInstance()->lefthand() ? -1 : 1;
63  myShapeRotations.reserve(myShape.size() - 1);
64  myShapeLengths.reserve(myShape.size() - 1);
65  int e = (int) myShape.size() - 1;
66  for (int i = 0; i < e; ++i) {
67  const Position& f = myShape[i];
68  const Position& s = myShape[i + 1];
69  myShapeLengths.push_back(f.distanceTo(s));
70  myShapeRotations.push_back((double) atan2((s.x() - f.x()), (f.y() - s.y())) * (double) 180.0 / (double) M_PI);
71  }
72  PositionVector tmp = myShape;
73  tmp.move2side((lane.getWidth() + myWidth) * offsetSign);
74  mySignPos = tmp.getLineCenter();
75  mySignRot = 0;
76  if (tmp.length() != 0) {
78  mySignRot -= 90;
79  }
81  myBoundary.grow(20);
82 }
83 
85 
86 
89  GUISUMOAbstractView& parent) {
90  GUIGLObjectPopupMenu* ret = new GUIGLObjectPopupMenu(app, parent, *this);
91  buildPopupHeader(ret, app);
96  buildPositionCopyEntry(ret, false);
97  return ret;
98 }
99 
100 
105  new GUIParameterTableWindow(app, *this, 6);
106  // add items
107  ret->mkItem("name", false, getMyName());
108  ret->mkItem("begin position [m]", false, myBegPos);
109  ret->mkItem("end position [m]", false, myEndPos);
110  ret->mkItem("occupancy [#]", true, getOccupancy());
111  ret->mkItem("capacity [#]", false, getCapacity());
112  ret->mkItem("alternatives [#]", false, getNumAlternatives());
113  // close building
114  ret->closeBuilding();
115  return ret;
116 }
117 
118 
119 void
121  glPushName(getGlID());
122  glPushMatrix();
123  RGBColor grey(177, 184, 186, 171);
124  RGBColor blue(83, 89, 172, 255);
125  RGBColor red(255, 0, 0, 255);
126  RGBColor green(0, 255, 0, 255);
127  // draw the area
128  glTranslated(0, 0, getType());
129  GLHelper::setColor(blue);
131  // draw details unless zoomed out to far
132  const double exaggeration = s.addSize.getExaggeration(s, this);
133  if (s.scale * exaggeration >= 1) {
134  // draw the lots
135  glTranslated(0, 0, .1);
136  for (const auto& lsd : mySpaceOccupancies) {
137  glPushMatrix();
138  glTranslated(lsd.myPosition.x(), lsd.myPosition.y(), lsd.myPosition.z());
139  glRotated(lsd.myRotation, 0, 0, 1);
140  Position pos = lsd.myPosition;
141  PositionVector geom;
142  double w = lsd.myWidth / 2. - 0.1 * exaggeration;
143  double h = lsd.myLength;
144  geom.push_back(Position(- w, + 0, 0.));
145  geom.push_back(Position(+ w, + 0, 0.));
146  geom.push_back(Position(+ w, + h, 0.));
147  geom.push_back(Position(- w, + h, 0.));
148  geom.push_back(Position(- w, + 0, 0.));
149  /*
150  geom.push_back(Position(pos.x(), pos.y(), pos.z()));
151  geom.push_back(Position(pos.x() + (*l).second.myWidth, pos.y(), pos.z()));
152  geom.push_back(Position(pos.x() + (*l).second.myWidth, pos.y() - (*l).second.myLength, pos.z()));
153  geom.push_back(Position(pos.x(), pos.y() - (*l).second.myLength, pos.z()));
154  geom.push_back(Position(pos.x(), pos.y(), pos.z()));
155  */
156  GLHelper::setColor(lsd.vehicle == nullptr ? green : red);
157  GLHelper::drawBoxLines(geom, 0.1 * exaggeration);
158  glPopMatrix();
159  }
160  GLHelper::setColor(blue);
161  // draw the lines
162  for (size_t i = 0; i != myLines.size(); ++i) {
163  // push a new matrix for every line
164  glPushMatrix();
165  // traslate and rotate
166  glTranslated(mySignPos.x(), mySignPos.y(), 0);
167  glRotated(180, 1, 0, 0);
168  glRotated(mySignRot, 0, 0, 1);
169  // draw line
170  GLHelper::drawText(myLines[i].c_str(), Position(1.2, (double)i), .1, 1.f, RGBColor(76, 170, 50), 0, FONS_ALIGN_LEFT);
171  // pop matrix for every line
172  glPopMatrix();
173 
174  }
175  // draw the sign
176  glTranslated(mySignPos.x(), mySignPos.y(), 0);
177  int noPoints = 9;
178  if (s.scale * exaggeration > 25) {
179  noPoints = MIN2((int)(9.0 + (s.scale * exaggeration) / 10.0), 36);
180  }
181  glScaled(exaggeration, exaggeration, 1);
182  GLHelper::drawFilledCircle((double) 1.1, noPoints);
183  glTranslated(0, 0, .1);
184  GLHelper::setColor(grey);
185  GLHelper::drawFilledCircle((double) 0.9, noPoints);
186  if (s.drawDetail(s.detailSettings.stoppingPlaceText, exaggeration)) {
187  GLHelper::drawText("P", Position(), .1, 1.6, blue, mySignRot);
188  }
189  }
190  glPopMatrix();
191  if (s.addFullName.show && getMyName() != "") {
193  }
194  glPopName();
195  drawName(getCenteringBoundary().getCenter(), s.scale, s.addName, s.angle);
196  // draw parking vehicles (their lane might not be within drawing range. if it is, they are drawn twice)
198  for (std::set<const MSVehicle*>::const_iterator v = myLane.getParkingVehicles().begin(); v != myLane.getParkingVehicles().end(); ++v) {
199  static_cast<const GUIVehicle* const>(*v)->drawGL(s);
200  }
202 
203 }
204 
205 void
206 GUIParkingArea::addLotEntry(double x, double y, double z,
207  double width, double length, double angle) {
208  MSParkingArea::addLotEntry(x, y, z, width, length, angle);
209  Boundary b;
210  b.add(Position(x, y));
211  b.grow(MAX2(width, length) + 5);
212  myBoundary.add(b);
213 }
214 
215 Boundary
217  return myBoundary;
218 }
219 
220 
221 const std::string
223  return myName;
224 }
225 
226 /****************************************************************************/
227 
MSLane::releaseVehicles
virtual void releaseVehicles() const
Allows to use the container for microsimulation again.
Definition: MSLane.h:458
GUIGlObject::getType
GUIGlObjectType getType() const
Returns the type of the object as coded in GUIGlObjectType.
Definition: GUIGlObject.cpp:181
Boundary.h
GLO_MAX
empty max
Definition: GUIGlObjectTypes.h:166
MSLane::getVehiclesSecure
virtual const VehCont & getVehiclesSecure() const
Returns the vehicles container; locks it for microsimulation.
Definition: MSLane.h:428
ToString.h
GLHelper::drawTextSettings
static void drawTextSettings(const GUIVisualizationTextSettings &settings, const std::string &text, const Position &pos, const double scale, const double angle=0, const double layer=2048)
Definition: GLHelper.cpp:701
MIN2
T MIN2(T a, T b)
Definition: StdDefs.h:74
GUIParameterTableWindow
A window containing a gl-object's parameter.
Definition: GUIParameterTableWindow.h:63
MSStoppingPlace::myLines
std::vector< std::string > myLines
The list of lines that are assigned to this stop.
Definition: MSStoppingPlace.h:217
MSParkingArea
A lane area vehicles can halt at.
Definition: MSParkingArea.h:59
GUIParkingArea::getPopUpMenu
GUIGLObjectPopupMenu * getPopUpMenu(GUIMainWindow &app, GUISUMOAbstractView &parent)
Returns an own popup-menu.
Definition: GUIParkingArea.cpp:88
GUIVehicle.h
GUIContainer.h
GUISUMOAbstractView
Definition: GUISUMOAbstractView.h:73
MSNet.h
MSLane
Representation of a lane in the micro simulation.
Definition: MSLane.h:83
GUIVisualizationSettings::getTextAngle
double getTextAngle(double objectAngle) const
return an angle that is suitable for reading text aligned with the given angle (degrees)
Definition: GUIVisualizationSettings.cpp:1605
GUIParameterTableWindow.h
GUIGlObject::drawName
void drawName(const Position &pos, const double scale, const GUIVisualizationTextSettings &settings, const double angle=0) const
draw name of item
Definition: GUIGlObject.cpp:355
GUIVisualizationSettings::angle
double angle
The current view rotation angle.
Definition: GUIVisualizationSettings.h:403
GUIGlObject::buildSelectionPopupEntry
void buildSelectionPopupEntry(GUIGLObjectPopupMenu *ret, bool addSeparator=true)
Builds an entry which allows to (de)select the object.
Definition: GUIGlObject.cpp:236
GLHelper::drawBoxLines
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.
Definition: GLHelper.cpp:182
MsgHandler.h
GUIGLObjectPopupMenu.h
MSParkingArea::getNumAlternatives
int getNumAlternatives() const
Definition: MSParkingArea.h:215
GUIGlobalSelection.h
FONS_ALIGN_LEFT
Definition: fontstash.h:42
PositionVector::length
double length() const
Returns the length.
Definition: PositionVector.cpp:476
MSEdge.h
GLHelper.h
GUIParkingArea::addLotEntry
void addLotEntry(double x, double y, double z, double width, double length, double angle)
extend boundary
Definition: GUIParkingArea.cpp:206
GUIGlObject_AbstractAdd
Definition: GUIGlObject_AbstractAdd.h:40
GUINet.h
PositionVector
A list of positions.
Definition: PositionVector.h:46
GUIGLObjectPopupMenu
The popup menu of a globject.
Definition: GUIGLObjectPopupMenu.h:48
GLHelper::setColor
static void setColor(const RGBColor &c)
Sets the gl-color to this value.
Definition: GLHelper.cpp:616
PositionVector::getBoxBoundary
Boundary getBoxBoundary() const
Returns a boundary enclosing this list of lines.
Definition: PositionVector.cpp:382
GUIParameterTableWindow::closeBuilding
void closeBuilding(const Parameterised *p=0)
Closes the building of the table.
Definition: GUIParameterTableWindow.cpp:220
GUIAppEnum.h
MSStoppingPlace::myBegPos
const double myBegPos
The begin position this bus stop is located at.
Definition: MSStoppingPlace.h:226
MAX2
T MAX2(T a, T b)
Definition: StdDefs.h:80
GLHelper::drawFilledCircle
static void drawFilledCircle(double width, int steps=8)
Draws a filled circle around (0,0)
Definition: GLHelper.cpp:348
GLHelper::drawText
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)
Definition: GLHelper.cpp:668
RGBColor
Definition: RGBColor.h:40
GUIParkingArea::~GUIParkingArea
~GUIParkingArea()
Destructor.
Definition: GUIParkingArea.cpp:84
GUIVisualizationSettings::addName
GUIVisualizationTextSettings addName
Definition: GUIVisualizationSettings.h:582
MSLane::getParkingVehicles
const std::set< const MSVehicle * > & getParkingVehicles() const
retrieve the parking vehicles (see GUIParkingArea)
Definition: MSLane.h:1124
GUIParkingArea::myShapeLengths
std::vector< double > myShapeLengths
The lengths of the shape parts.
Definition: GUIParkingArea.h:142
GUIVisualizationSettings::detailSettings
GUIVisualizationDetailSettings detailSettings
detail settings
Definition: GUIVisualizationSettings.h:655
MSStoppingPlace::myName
const std::string myName
The name of the stopping place.
Definition: MSStoppingPlace.h:235
GUIGlObject::buildNameCopyPopupEntry
void buildNameCopyPopupEntry(GUIGLObjectPopupMenu *ret, bool addSeparator=true)
Builds entries which allow to copy the name / typed name into the clipboard.
Definition: GUIGlObject.cpp:226
MSNet::lefthand
bool lefthand() const
return whether the network was built for lefthand traffic
Definition: MSNet.h:662
MSStoppingPlace::myEndPos
const double myEndPos
The end position this bus stop is located at.
Definition: MSStoppingPlace.h:229
Position::distanceTo
double distanceTo(const Position &p2) const
returns the euclidean distance in 3 dimension
Definition: Position.h:234
GUIParameterTableWindow::mkItem
void mkItem(const char *name, bool dynamic, ValueSource< T > *src)
Adds a row which obtains its value from a ValueSource.
Definition: GUIParameterTableWindow.h:109
MSParkingArea::myShape
PositionVector myShape
The roadside shape of this parkingArea.
Definition: MSParkingArea.h:273
MSParkingArea::getCapacity
int getCapacity() const
Returns the area capacity.
Definition: MSParkingArea.cpp:288
GUIGlobals.h
PositionVector::rotationDegreeAtOffset
double rotationDegreeAtOffset(double pos) const
Returns the rotation at the given length.
Definition: PositionVector.cpp:311
GUIGlObject::getGlID
GUIGlID getGlID() const
Returns the numerical id of the object.
Definition: GUIGlObject.cpp:150
Boundary
A class that stores a 2D geometrical boundary.
Definition: Boundary.h:42
MSParkingArea::mySpaceOccupancies
std::vector< LotSpaceDefinition > mySpaceOccupancies
All the spaces in this parking area.
Definition: MSParkingArea.h:270
GUIVisualizationSettings::scale
double scale
information about a lane's width (temporary, used for a single view)
Definition: GUIVisualizationSettings.h:623
GUIApplicationWindow.h
Position
A point in 2D or 3D with translation and scaling methods.
Definition: Position.h:39
Position::x
double x() const
Returns the x-position.
Definition: Position.h:57
Boundary::add
void add(double x, double y, double z=0)
Makes the boundary include the given coordinate.
Definition: Boundary.cpp:79
GUIParkingArea::mySignPos
Position mySignPos
The position of the sign.
Definition: GUIParkingArea.h:145
GUIVisualizationSettings::addFullName
GUIVisualizationTextSettings addFullName
Definition: GUIVisualizationSettings.h:584
GUIVisualizationTextSettings::show
bool show
flag show
Definition: GUIVisualizationSettings.h:69
MSParkingArea::addLotEntry
virtual void addLotEntry(double x, double y, double z, double width, double length, double angle)
Add a lot entry to parking area.
Definition: MSParkingArea.cpp:94
GUIParkingArea::drawGL
void drawGL(const GUIVisualizationSettings &s) const
Draws the object.
Definition: GUIParkingArea.cpp:120
GUIParkingArea::getParameterWindow
GUIParameterTableWindow * getParameterWindow(GUIMainWindow &app, GUISUMOAbstractView &parent)
Returns an own parameter window.
Definition: GUIParkingArea.cpp:102
GUIParkingArea.h
GUIGlObject::buildPopupHeader
void buildPopupHeader(GUIGLObjectPopupMenu *ret, GUIMainWindow &app, bool addSeparator=true)
Builds the header.
Definition: GUIGlObject.cpp:208
MSStoppingPlace::getMyName
const std::string & getMyName() const
Definition: MSStoppingPlace.cpp:266
GLO_PARKING_AREA
a ParkingArea
Definition: GUIGlObjectTypes.h:68
GUIParkingArea::mySignRot
double mySignRot
The rotation of the sign.
Definition: GUIParkingArea.h:148
GLIncludes.h
MSParkingArea::getOccupancy
int getOccupancy() const
Returns the area occupancy.
Definition: MSParkingArea.cpp:294
FunctionBinding.h
MSNet::getInstance
static MSNet * getInstance()
Returns the pointer to the unique instance of MSNet (singleton).
Definition: MSNet.cpp:168
GUIMainWindow
Definition: GUIMainWindow.h:47
Position::y
double y() const
Returns the y-position.
Definition: Position.h:62
GUIParkingArea::myBoundary
Boundary myBoundary
the centering boundary
Definition: GUIParkingArea.h:151
M_PI
#define M_PI
Definition: odrSpiral.cpp:40
GUIParkingArea::getCenteringBoundary
Boundary getCenteringBoundary() const
Returns the boundary to which the view shall be centered in order to show the object.
Definition: GUIParkingArea.cpp:216
GUIEdge.h
GUIGlObject::buildShowParamsPopupEntry
void buildShowParamsPopupEntry(GUIGLObjectPopupMenu *ret, bool addSeparator=true)
Builds an entry which allows to open the parameter window.
Definition: GUIGlObject.cpp:249
GUIVisualizationDetailSettings::stoppingPlaceText
static const double stoppingPlaceText
details for stopping place texts
Definition: GUIVisualizationSettings.h:302
GUIGlObject::buildCenterPopupEntry
void buildCenterPopupEntry(GUIGLObjectPopupMenu *ret, bool addSeparator=true)
Builds an entry which allows to center to the object.
Definition: GUIGlObject.cpp:217
GUIGlObject::buildPositionCopyEntry
void buildPositionCopyEntry(GUIGLObjectPopupMenu *ret, bool addSeparator=true)
Builds an entry which allows to copy the cursor position if geo projection is used,...
Definition: GUIGlObject.cpp:267
GUIParkingArea::GUIParkingArea
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, const std::string &name, bool onRoad)
Constructor.
Definition: GUIParkingArea.cpp:56
MSLane::getWidth
double getWidth() const
Returns the lane's width.
Definition: MSLane.h:557
config.h
GUIVisualizationSettings::addSize
GUIVisualizationSizeSettings addSize
Definition: GUIVisualizationSettings.h:580
GUIParkingArea::getOptionalName
const std::string getOptionalName() const
Returns the stopping place name.
Definition: GUIParkingArea.cpp:222
GeomHelper.h
Boundary::grow
Boundary & grow(double by)
extends the boundary by the given amount
Definition: Boundary.cpp:301
GUIVisualizationSettings::drawDetail
bool drawDetail(const double detail, const double exaggeration) const
check if details can be drawn for the given GUIVisualizationDetailSettings and current scale and exxa...
Definition: GUIVisualizationSettings.cpp:1621
MSLane.h
GUIVisualizationSettings
Stores the information about how to visualize structures.
Definition: GUIVisualizationSettings.h:346
PositionVector::getLineCenter
Position getLineCenter() const
get line center
Definition: PositionVector.cpp:466
GUIParkingArea::myShapeRotations
std::vector< double > myShapeRotations
The rotations of the shape parts.
Definition: GUIParkingArea.h:139
PositionVector.h
MSStoppingPlace::myLane
const MSLane & myLane
The lane this bus stop is located at.
Definition: MSStoppingPlace.h:223
GUIVisualizationSizeSettings::getExaggeration
double getExaggeration(const GUIVisualizationSettings &s, const GUIGlObject *o, double factor=20) const
return the drawing size including exaggeration and constantSize values
Definition: GUIVisualizationSettings.cpp:212
PositionVector::move2side
void move2side(double amount, double maxExtension=100)
move position vector to side using certain ammount
Definition: PositionVector.cpp:1086
MSParkingArea::myWidth
double myWidth
The default width of each parking space.
Definition: MSParkingArea.h:260
fontstash.h