Eclipse SUMO - Simulation of Urban MObility
All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Modules Pages
GNETAZ.h
Go to the documentation of this file.
1/****************************************************************************/
2// Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo
3// Copyright (C) 2001-2025 German Aerospace Center (DLR) and others.
4// This program and the accompanying materials are made available under the
5// terms of the Eclipse Public License 2.0 which is available at
6// https://www.eclipse.org/legal/epl-2.0/
7// This Source Code may also be made available under the following Secondary
8// Licenses when the conditions for such availability set forth in the Eclipse
9// Public License 2.0 are satisfied: GNU General Public License, version 2
10// or later which is available at
11// https://www.gnu.org/licenses/old-licenses/gpl-2.0-standalone.html
12// SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-or-later
13/****************************************************************************/
18//
19/****************************************************************************/
20#pragma once
21#include <config.h>
22
24
25#include "GNEAdditional.h"
26
27// ===========================================================================
28// class definitions
29// ===========================================================================
30
31class GNETAZ : public GNEAdditional, public TesselatedPolygon {
32
33public:
36
38 GNETAZ(GNENet* net);
39
51 GNETAZ(const std::string& id, GNENet* net, const std::string& filename, const PositionVector& shape, const Position& TAZ,
52 const bool fill, const RGBColor& color, const std::string& name, const Parameterised::Map& parameters);
53
55 ~GNETAZ();
56
61
67 int getVertexIndex(Position pos, bool snapToGrid);
68
70 void removeGeometryPoint(const Position clickedPosition, GNEUndoList* undoList);
71
74
78 void writeAdditional(OutputDevice& device) const;
79
81 bool isAdditionalValid() const;
82
84 std::string getAdditionalProblem() const;
85
88
90
93
95 bool checkDrawMoveContour() const;
96
98
101
103 void updateGeometry();
104
107
109 double getExaggeration(const GUIVisualizationSettings& s) const;
110
112 void updateCenteringBoundary(const bool updateGrid);
113
115 void splitEdgeGeometry(const double splitPosition, const GNENetworkElement* originalElement, const GNENetworkElement* newElement, GNEUndoList* undoList);
116
118
121
124 std::string getParentName() const;
125
134
139 void drawGL(const GUIVisualizationSettings& s) const;
140
142
145
146 /* @brief method for getting the Attribute of an XML key
147 * @param[in] key The attribute key
148 * @return string with the value associated to key
149 */
150 std::string getAttribute(SumoXMLAttr key) const;
151
152 /* @brief method for getting the Attribute of an XML key in double format (to avoid unnecessary parse<double>(...) for certain attributes)
153 * @param[in] key The attribute key
154 * @return double with the value associated to key
155 */
156 double getAttributeDouble(SumoXMLAttr key) const;
157
158 /* @brief method for getting the Attribute of an XML key in position format (to avoid unnecessary parse<position>(...) for certain attributes)
159 * @param[in] key The attribute key
160 * @return double with the value associated to key
161 */
163
166
167 /* @brief method for setting the attribute and letting the object perform additional changes
168 * @param[in] key The attribute key
169 * @param[in] value The new value
170 * @param[in] undoList The undoList on which to register changes
171 */
172 void setAttribute(SumoXMLAttr key, const std::string& value, GNEUndoList* undoList);
173
174 /* @brief method for checking if the key and their corresponding attribute are valid
175 * @param[in] key The attribute key
176 * @param[in] value The value associated to key key
177 * @return true if the value is valid, false in other case
178 */
179 bool isValid(SumoXMLAttr key, const std::string& value);
180
182 std::string getPopUpID() const;
183
185 std::string getHierarchyName() const;
186
188
190 void updateTAZStatistic();
191
192protected:
195
198
200 bool myEdgesWithin = false;
201
202private:
204 static const double myHintSize;
205
207 static const double myHintSizeSquared;
208
211
214
217
219 double myMaxWeightSink = 0;
220
222 double myMinWeightSink = 0;
223
226
228 void setAttribute(SumoXMLAttr key, const std::string& value);
229
231 void setMoveShape(const GNEMoveResult& moveResult);
232
234 void commitMoveShape(const GNEMoveResult& moveResult, GNEUndoList* undoList);
235
237 GNETAZ(const GNETAZ&) = delete;
238
240 GNETAZ& operator=(const GNETAZ&) = delete;
241};
SumoXMLAttr
Numbers representing SUMO-XML - attributes.
const std::string getID() const
get ID (all Attribute Carriers have one)
move operation
move result
A NBNetBuilder extended by visualisation and editing capabilities.
Definition GNENet.h:42
Position getPositionInView() const
Returns position of additional in view.
Definition GNETAZ.cpp:222
void updateCenteringBoundary(const bool updateGrid)
update centering boundary (implies change in RTREE)
Definition GNETAZ.cpp:234
std::string getAdditionalProblem() const
return a string with the current additional problem (must be reimplemented in all detector children)
Definition GNETAZ.cpp:178
double myMaxWeightSink
Max Sink weight.
Definition GNETAZ.h:219
Position myTAZCenter
TAZ center.
Definition GNETAZ.h:194
static const double myHintSize
hint size of vertex
Definition GNETAZ.h:204
void drawGL(const GUIVisualizationSettings &s) const
Draws the object.
Definition GNETAZ.cpp:294
std::string getPopUpID() const
get PopPup ID (Used in AC Hierarchy)
Definition GNETAZ.cpp:580
GNEContour myTAZCenterContour
TAZ center contour.
Definition GNETAZ.h:197
bool myEdgesWithin
use edges whithin during creation (only in edit mode)
Definition GNETAZ.h:200
bool isAdditionalValid() const
check if current additional is valid to be written into XML (must be reimplemented in all detector ch...
Definition GNETAZ.cpp:172
double getExaggeration(const GUIVisualizationSettings &s) const
return exaggeration associated with this GLObject
Definition GNETAZ.cpp:228
void splitEdgeGeometry(const double splitPosition, const GNENetworkElement *originalElement, const GNENetworkElement *newElement, GNEUndoList *undoList)
split geometry
Definition GNETAZ.cpp:262
Position getAttributePosition(SumoXMLAttr key) const
Definition GNETAZ.cpp:501
~GNETAZ()
GNETAZ Destructor.
Definition GNETAZ.cpp:67
double myAverageWeightSource
Average source weight.
Definition GNETAZ.h:216
void setMoveShape(const GNEMoveResult &moveResult)
set move shape
Definition GNETAZ.cpp:713
void updateGeometry()
update pre-computed geometry information
Definition GNETAZ.cpp:206
bool isValid(SumoXMLAttr key, const std::string &value)
method for checking if the key and their correspondent attribute are valids
Definition GNETAZ.cpp:543
double myMinWeightSink
Min Sink weight.
Definition GNETAZ.h:222
GNEMoveOperation * getMoveOperation()
get move operation
Definition GNETAZ.cpp:71
double myAverageWeightSink
Average Sink weight.
Definition GNETAZ.h:225
std::string getHierarchyName() const
get Hierarchy Name (Used in AC Hierarchy)
Definition GNETAZ.cpp:586
std::string getParentName() const
Returns the name of the parent object.
Definition GNETAZ.cpp:268
void fixAdditionalProblem()
fix additional problem (must be reimplemented in all detector children)
Definition GNETAZ.cpp:184
void writeAdditional(OutputDevice &device) const
write additional element into a xml file
Definition GNETAZ.cpp:139
void removeGeometryPoint(const Position clickedPosition, GNEUndoList *undoList)
remove geometry point in the clicked position
Definition GNETAZ.cpp:105
std::string getAttribute(SumoXMLAttr key) const
Definition GNETAZ.cpp:410
GUIGLObjectPopupMenu * getPopUpMenu(GUIMainWindow &app, GUISUMOAbstractView &parent)
Returns an own popup-menu.
Definition GNETAZ.cpp:274
void setAttribute(SumoXMLAttr key, const std::string &value, GNEUndoList *undoList)
method for setting the attribute and letting the object perform additional changes
Definition GNETAZ.cpp:520
static const double myHintSizeSquared
squaredhint size of vertex
Definition GNETAZ.h:207
void updateTAZStatistic()
update TAZ Statistic
Definition GNETAZ.cpp:592
double myMinWeightSource
Min source weight.
Definition GNETAZ.h:213
int getVertexIndex(Position pos, bool snapToGrid)
return index of a vertex of shape, or of a new vertex if position is over an shape's edge
Definition GNETAZ.cpp:89
void commitMoveShape(const GNEMoveResult &moveResult, GNEUndoList *undoList)
commit move shape
Definition GNETAZ.cpp:743
const Parameterised::Map & getACParametersMap() const
get parameters map
Definition GNETAZ.cpp:514
double getAttributeDouble(SumoXMLAttr key) const
Definition GNETAZ.cpp:480
double myMaxWeightSource
Max source weight.
Definition GNETAZ.h:210
GNETAZ & operator=(const GNETAZ &)=delete
Invalidated assignment operator.
GNETAZ(const GNETAZ &)=delete
Invalidated copy constructor.
bool checkDrawMoveContour() const
check if draw move contour (red)
Definition GNETAZ.cpp:190
The popup menu of a globject.
Stores the information about how to visualize structures.
Static storage of an output device and its base (abstract) implementation.
std::map< std::string, std::string > Map
parameters map
A point in 2D or 3D with translation and scaling methods.
Definition Position.h:37
A list of positions.