Eclipse SUMO - Simulation of Urban MObility
GNEDataSet.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-2024 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 // A abstract class for data elements
19 /****************************************************************************/
20 #pragma once
21 #include <config.h>
22 
23 
24 // ===========================================================================
25 // included modules
26 // ===========================================================================
27 #include <config.h>
28 
31 
32 // ===========================================================================
33 // class declarations
34 // ===========================================================================
35 
36 class GNENet;
37 class GNEDataInterval;
38 
39 // ===========================================================================
40 // class definitions
41 // ===========================================================================
42 
44 
45 public:
48 
49  public:
52 
54  void updateValues(const std::string& attribute, const double value);
55 
57  void updateAllValues(const AttributeColors& attributeColors);
58 
60  bool exist(const std::string& attribute) const;
61 
63  double getMinValue(const std::string& attribute) const;
64 
66  double getMaxValue(const std::string& attribute) const;
67 
69  void clear();
70 
71  private:
73  std::map<std::string, std::pair<double, double> > myMinMaxValue;
74 
77  };
78 
82  GNEDataSet(GNENet* net, const std::string dataSetID);
83 
85  ~GNEDataSet();
86 
89 
92 
94  const GUIGlObject* getGUIGlObject() const;
95 
97  void updateAttributeColors();
98 
101 
103  const std::map<SumoXMLTag, GNEDataSet::AttributeColors>& getSpecificAttributeColors() const;
104 
106  void updateGeometry();
107 
109  Position getPositionInView() const;
110 
112  void writeDataSet(OutputDevice& device) const;
113 
116 
118  bool checkDrawFromContour() const;
119 
121  bool checkDrawToContour() const;
122 
124  bool checkDrawRelatedContour() const;
125 
127  bool checkDrawOverContour() const;
128 
130  bool checkDrawDeleteContour() const;
131 
133  bool checkDrawSelectContour() const;
134 
136  bool checkDrawMoveContour() const;
137 
139 
142 
144  void addDataIntervalChild(GNEDataInterval* dataInterval);
145 
147  void removeDataIntervalChild(GNEDataInterval* dataInterval);
148 
150  bool dataIntervalChildrenExist(GNEDataInterval* dataInterval) const;
151 
153  void updateDataIntervalBegin(const double oldBegin);
154 
156  bool checkNewInterval(const double newBegin, const double newEnd);
157 
159  bool checkNewBeginEnd(const GNEDataInterval* dataInterval, const double newBegin, const double newEnd);
160 
162  GNEDataInterval* retrieveInterval(const double begin, const double end) const;
163 
165  const std::map<const double, GNEDataInterval*>& getDataIntervalChildren() const;
166 
168 
171  /* @brief method for getting the Attribute of an XML key
172  * @param[in] key The attribute key
173  * @return string with the value associated to key
174  */
175  std::string getAttribute(SumoXMLAttr key) const;
176 
177  /* @brief method for getting the Attribute of an XML key in double format (to avoid unnecessary parse<double>(...) for certain attributes)
178  * @param[in] key The attribute key
179  * @return double with the value associated to key
180  */
181  double getAttributeDouble(SumoXMLAttr key) const;
182 
188  void setAttribute(SumoXMLAttr key, const std::string& value, GNEUndoList* undoList);
189 
195  bool isValid(SumoXMLAttr key, const std::string& value);
196 
198  std::string getPopUpID() const;
199 
201  std::string getHierarchyName() const;
203 
205  const Parameterised::Map& getACParametersMap() const;
206 
207 protected:
209  std::string myDataSetID;
210 
212  std::map<const double, GNEDataInterval*> myDataIntervalChildren;
213 
216 
218  std::map<SumoXMLTag, GNEDataSet::AttributeColors> mySpecificAttributeColors;
219 
220 private:
222  void setAttribute(SumoXMLAttr key, const std::string& value);
223 
225  static bool checkNewInterval(const std::map<const double, GNEDataInterval*>& dataIntervalMap, const double newBegin, const double newEnd);
226 
228  GNEDataSet(const GNEDataSet&) = delete;
229 
231  GNEDataSet& operator=(const GNEDataSet&) = delete;
232 };
233 
234 /****************************************************************************/
SumoXMLAttr
Numbers representing SUMO-XML - attributes.
An Element which don't belong to GNENet but has influence in the simulation.
attribute colors
Definition: GNEDataSet.h:47
std::map< std::string, std::pair< double, double > > myMinMaxValue
map with the minimum and maximum value
Definition: GNEDataSet.h:73
void updateAllValues(const AttributeColors &attributeColors)
update value for all attributes
Definition: GNEDataSet.cpp:69
bool exist(const std::string &attribute) const
check if given attribute exist (needed for non-double attributes)
Definition: GNEDataSet.cpp:89
double getMaxValue(const std::string &attribute) const
get maximum value
Definition: GNEDataSet.cpp:101
AttributeColors & operator=(const AttributeColors &)=delete
Invalidated assignment operator.
AttributeColors()
default constructor
Definition: GNEDataSet.cpp:46
double getMinValue(const std::string &attribute) const
get minimum value
Definition: GNEDataSet.cpp:95
void clear()
clear AttributeColors
Definition: GNEDataSet.cpp:107
void updateValues(const std::string &attribute, const double value)
update value for an specific attribute
Definition: GNEDataSet.cpp:51
void setAttribute(SumoXMLAttr key, const std::string &value, GNEUndoList *undoList)
method for setting the attribute and letting the object perform data element changes
Definition: GNEDataSet.cpp:363
bool isValid(SumoXMLAttr key, const std::string &value)
method for checking if the key and their conrrespond attribute are valids
Definition: GNEDataSet.cpp:375
Position getPositionInView() const
Returns element position in view.
Definition: GNEDataSet.cpp:183
GUIGlObject * getGUIGlObject()
get GUIGlObject associated with this AttributeCarrier
Definition: GNEDataSet.cpp:131
void writeDataSet(OutputDevice &device) const
write data set
Definition: GNEDataSet.cpp:189
std::string myDataSetID
dataSet ID
Definition: GNEDataSet.h:209
bool dataIntervalChildrenExist(GNEDataInterval *dataInterval) const
check if given data interval exist
Definition: GNEDataSet.cpp:285
std::string getAttribute(SumoXMLAttr key) const
Definition: GNEDataSet.cpp:346
std::map< const double, GNEDataInterval * > myDataIntervalChildren
map with dataIntervals children sorted by begin
Definition: GNEDataSet.h:212
void removeDataIntervalChild(GNEDataInterval *dataInterval)
add data interval child
Definition: GNEDataSet.cpp:268
std::string getPopUpID() const
get PopPup ID (Used in AC Hierarchy)
Definition: GNEDataSet.cpp:390
GNEDataInterval * retrieveInterval(const double begin, const double end) const
return interval
Definition: GNEDataSet.cpp:328
GNEHierarchicalElement * getHierarchicalElement()
get GNEHierarchicalElement associated with this AttributeCarrier
Definition: GNEDataSet.cpp:125
std::string getHierarchyName() const
get Hierarchy Name (Used in AC Hierarchy)
Definition: GNEDataSet.cpp:396
bool checkDrawMoveContour() const
check if draw move contour (red)
Definition: GNEDataSet.cpp:248
bool checkDrawOverContour() const
check if draw over contour (orange)
Definition: GNEDataSet.cpp:230
bool checkDrawFromContour() const
check if draw from contour (green)
Definition: GNEDataSet.cpp:212
~GNEDataSet()
Destructor.
Definition: GNEDataSet.cpp:121
const Parameterised::Map & getACParametersMap() const
get parameters map
Definition: GNEDataSet.cpp:402
const GNEDataSet::AttributeColors & getAllAttributeColors() const
all attribute colors
Definition: GNEDataSet.cpp:165
void updateAttributeColors()
update attribute colors deprecated
Definition: GNEDataSet.cpp:143
double getAttributeDouble(SumoXMLAttr key) const
Definition: GNEDataSet.cpp:357
bool checkDrawRelatedContour() const
check if draw related contour (cyan)
Definition: GNEDataSet.cpp:224
std::map< SumoXMLTag, GNEDataSet::AttributeColors > mySpecificAttributeColors
specific attribute colors
Definition: GNEDataSet.h:218
GNEDataSet(const GNEDataSet &)=delete
Invalidated copy constructor.
bool checkDrawSelectContour() const
check if draw select contour (blue)
Definition: GNEDataSet.cpp:242
bool checkNewBeginEnd(const GNEDataInterval *dataInterval, const double newBegin, const double newEnd)
check if new begin or end for given GNEDataInterval is given
Definition: GNEDataSet.cpp:315
GNEDataSet::AttributeColors myAllAttributeColors
all attribute colors
Definition: GNEDataSet.h:215
GNEDataSet & operator=(const GNEDataSet &)=delete
Invalidated assignment operator.
GNEDataSet(GNENet *net, const std::string dataSetID)
Constructor.
Definition: GNEDataSet.cpp:115
const std::map< SumoXMLTag, GNEDataSet::AttributeColors > & getSpecificAttributeColors() const
specific attribute colors
Definition: GNEDataSet.cpp:171
bool checkDrawToContour() const
check if draw from contour (magenta)
Definition: GNEDataSet.cpp:218
bool checkDrawDeleteContour() const
check if draw delete contour (pink/white)
Definition: GNEDataSet.cpp:236
const std::map< const double, GNEDataInterval * > & getDataIntervalChildren() const
get data interval children
Definition: GNEDataSet.cpp:340
bool checkNewInterval(const double newBegin, const double newEnd)
check if a new GNEDataInterval with the given begin and end can be inserted in current GNEDataSet
Definition: GNEDataSet.cpp:309
void updateGeometry()
update pre-computed geometry information
Definition: GNEDataSet.cpp:177
void addDataIntervalChild(GNEDataInterval *dataInterval)
add data interval child
Definition: GNEDataSet.cpp:254
void updateDataIntervalBegin(const double oldBegin)
update data interval begin
Definition: GNEDataSet.cpp:295
A NBNetBuilder extended by visualisation and editing capabilities.
Definition: GNENet.h:42
Static storage of an output device and its base (abstract) implementation.
Definition: OutputDevice.h:61
An upper class for objects with additional parameters.
Definition: Parameterised.h:41
std::map< std::string, std::string > Map
parameters map
Definition: Parameterised.h:45
A point in 2D or 3D with translation and scaling methods.
Definition: Position.h:37