Eclipse SUMO - Simulation of Urban MObility
GNEParkingSpace.h
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 /****************************************************************************/
14 // A class for visualizing ParkingSpace geometry (adapted from GUILaneWrapper)
15 /****************************************************************************/
16 #ifndef GNEParkingSpace_h
17 #define GNEParkingSpace_h
18 
19 // ===========================================================================
20 // included modules
21 // ===========================================================================
22 
23 #include "GNEAdditional.h"
24 
25 // ===========================================================================
26 // class declarations
27 // ===========================================================================
28 class GNEParkingArea;
29 
30 // ===========================================================================
31 // class definitions
32 // ===========================================================================
33 
39 
40 public:
50  GNEParkingSpace(GNEViewNet* viewNet, GNEAdditional* parkingAreaParent, const Position& pos, double width, double length, double angle, bool blockMovement);
51 
54 
57 
60  void moveGeometry(const Position& offset);
61 
65  void commitGeometryMoving(GNEUndoList* undoList);
66 
68  void updateGeometry();
69 
72 
75 
77  void splitEdgeGeometry(const double splitPosition, const GNENetElement* originalElement, const GNENetElement* newElement, GNEUndoList* undoList);
79 
84  std::string getParentName() const;
85 
90  void drawGL(const GUIVisualizationSettings& s) const;
92 
95  /* @brief method for getting the Attribute of an XML key
96  * @param[in] key The attribute key
97  * @return string with the value associated to key
98  */
99  std::string getAttribute(SumoXMLAttr key) const;
100 
101  /* @brief method for getting the Attribute of an XML key in double format (to avoid unnecessary parse<double>(...) for certain attributes)
102  * @param[in] key The attribute key
103  * @return double with the value associated to key
104  */
105  double getAttributeDouble(SumoXMLAttr key) const;
106 
107  /* @brief method for setting the attribute and letting the object perform additional changes
108  * @param[in] key The attribute key
109  * @param[in] value The new value
110  * @param[in] undoList The undoList on which to register changes
111  */
112  void setAttribute(SumoXMLAttr key, const std::string& value, GNEUndoList* undoList);
113 
114  /* @brief method for checking if the key and their correspond attribute are valids
115  * @param[in] key The attribute key
116  * @param[in] value The value asociated to key key
117  * @return true if the value is valid, false in other case
118  */
119  bool isValid(SumoXMLAttr key, const std::string& value);
120 
121  /* @brief method for check if the value for certain attribute is set
122  * @param[in] key The attribute key
123  */
124  bool isAttributeEnabled(SumoXMLAttr key) const;
125 
127  std::string getPopUpID() const;
128 
130  std::string getHierarchyName() const;
132 
133 protected:
136 
138  double myWidth;
139 
141  double myLength;
142 
144  double myAngle;
145 
146 private:
148  void setAttribute(SumoXMLAttr key, const std::string& value);
149 
152 
155 };
156 
157 
158 #endif
GNEParkingSpace::myPosition
Position myPosition
position of Parking Space in view
Definition: GNEParkingSpace.h:135
GNEParkingSpace::getPositionInView
Position getPositionInView() const
Returns position of additional in view.
Definition: GNEParkingSpace.cpp:74
GNEAdditional
An Element which don't belongs to GNENet but has influency in the simulation.
Definition: GNEAdditional.h:48
GNEAdditional.h
GNEParkingSpace::splitEdgeGeometry
void splitEdgeGeometry(const double splitPosition, const GNENetElement *originalElement, const GNENetElement *newElement, GNEUndoList *undoList)
split geometry
Definition: GNEParkingSpace.cpp:103
GNEParkingSpace::~GNEParkingSpace
~GNEParkingSpace()
Destructor.
Definition: GNEParkingSpace.cpp:44
GNEParkingSpace::commitGeometryMoving
void commitGeometryMoving(GNEUndoList *undoList)
commit geometry changes in the attributes of an element after use of moveGeometry(....
Definition: GNEParkingSpace.cpp:59
GNEParkingSpace::GNEParkingSpace
GNEParkingSpace(GNEViewNet *viewNet, GNEAdditional *parkingAreaParent, const Position &pos, double width, double length, double angle, bool blockMovement)
Constructor.
Definition: GNEParkingSpace.cpp:35
GNEViewNet
Definition: GNEViewNet.h:42
GNEParkingSpace::operator=
GNEParkingSpace & operator=(const GNEParkingSpace &)=delete
Invalidated assignment operator.
GNEParkingSpace::getPopUpID
std::string getPopUpID() const
get PopPup ID (Used in AC Hierarchy)
Definition: GNEParkingSpace.cpp:254
GNEParkingArea
A lane area vehicles can park at (netedit-version)
Definition: GNEParkingArea.h:34
GNEParkingSpace::GNEParkingSpace
GNEParkingSpace(const GNEParkingSpace &)=delete
Invalidated copy constructor.
GNEParkingSpace::myWidth
double myWidth
width of Parking Space
Definition: GNEParkingSpace.h:138
Boundary
A class that stores a 2D geometrical boundary.
Definition: Boundary.h:41
GNEParkingSpace::updateGeometry
void updateGeometry()
update pre-computed geometry information
Definition: GNEParkingSpace.cpp:68
Position
A point in 2D or 3D with translation and scaling methods.
Definition: Position.h:38
GNEParkingSpace::myLength
double myLength
Length of Parking Space.
Definition: GNEParkingSpace.h:141
GNENetElement
Definition: GNENetElement.h:43
GNEParkingSpace
vehicle space used by GNEParkingAreas
Definition: GNEParkingSpace.h:38
GNEParkingSpace::setAttribute
void setAttribute(SumoXMLAttr key, const std::string &value, GNEUndoList *undoList)
method for setting the attribute and letting the object perform additional changes
Definition: GNEParkingSpace.cpp:198
GNEParkingSpace::drawGL
void drawGL(const GUIVisualizationSettings &s) const
Draws the object.
Definition: GNEParkingSpace.cpp:115
GNEParkingSpace::myAngle
double myAngle
Angle of Parking Space.
Definition: GNEParkingSpace.h:144
GNEParkingSpace::getAttribute
std::string getAttribute(SumoXMLAttr key) const
Definition: GNEParkingSpace.cpp:165
GNEParkingSpace::getCenteringBoundary
Boundary getCenteringBoundary() const
Returns the boundary to which the view shall be centered in order to show the object.
Definition: GNEParkingSpace.cpp:80
GNEParkingSpace::getParentName
std::string getParentName() const
Returns the name of the parent object (if any)
Definition: GNEParkingSpace.cpp:109
GNEParkingSpace::isAttributeEnabled
bool isAttributeEnabled(SumoXMLAttr key) const
Definition: GNEParkingSpace.cpp:248
GNEUndoList
Definition: GNEUndoList.h:48
GUIVisualizationSettings
Stores the information about how to visualize structures.
Definition: GUIVisualizationSettings.h:345
SumoXMLAttr
SumoXMLAttr
Numbers representing SUMO-XML - attributes.
Definition: SUMOXMLDefinitions.h:372
GNEParkingSpace::getAttributeDouble
double getAttributeDouble(SumoXMLAttr key) const
Definition: GNEParkingSpace.cpp:192
GNEParkingSpace::isValid
bool isValid(SumoXMLAttr key, const std::string &value)
method for checking if the key and their conrrespond attribute are valids
Definition: GNEParkingSpace.cpp:221
GNEParkingSpace::moveGeometry
void moveGeometry(const Position &offset)
change the position of the element geometry without saving in undoList
Definition: GNEParkingSpace.cpp:48
GNEParkingSpace::getHierarchyName
std::string getHierarchyName() const
get Hierarchy Name (Used in AC Hierarchy)
Definition: GNEParkingSpace.cpp:260