Eclipse SUMO - Simulation of Urban MObility
GNEEdgeData.cpp
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 // class for edge data
19 /****************************************************************************/
20 
21 
22 // ===========================================================================
23 // included modules
24 // ===========================================================================
25 #include <config.h>
26 
27 #include <netedit/GNEUndoList.h>
28 #include <netedit/GNENet.h>
29 #include <netedit/GNEViewNet.h>
30 #include <netedit/GNEViewParent.h>
33 #include <utils/gui/div/GLHelper.h>
35 
36 #include "GNEEdgeData.h"
37 #include "GNEDataInterval.h"
38 
39 
40 // ===========================================================================
41 // member method definitions
42 // ===========================================================================
43 
44 // ---------------------------------------------------------------------------
45 // GNEEdgeData - methods
46 // ---------------------------------------------------------------------------
47 
48 GNEEdgeData::GNEEdgeData(GNEDataInterval* dataIntervalParent, GNEEdge* edgeParent, const Parameterised::Map& parameters) :
49  GNEGenericData(GNE_TAG_EDGEREL_SINGLE, GUIIconSubSys::getIcon(GUIIcon::EDGEDATA), GLO_EDGEDATA, dataIntervalParent, parameters,
50 {}, {edgeParent}, {}, {}, {}, {}) {
51 }
52 
53 
55 
56 
59  // set default color
60  RGBColor col = RGBColor::RED;
64  // user defined rainbow
65  const double val = getColorValue(s, s.dataColorer.getActive());
66  col = s.dataColorer.getScheme().getColor(val);
68  // get selected data interval and filtered attribute
70  const std::string filteredAttribute = myNet->getViewNet()->getViewParent()->getEdgeDataFrame()->getAttributeSelector()->getFilteredAttribute();
71  // continue if there is a selected data interval and filtered attribute
72  if (dataInterval && (filteredAttribute.size() > 0)) {
73  if (dataInterval->getSpecificAttributeColors().at(myTagProperty.getTag()).exist(filteredAttribute)) {
74  // obtain minimum and maximum value
75  const double minValue = dataInterval->getSpecificAttributeColors().at(myTagProperty.getTag()).getMinValue(filteredAttribute);
76  const double maxValue = dataInterval->getSpecificAttributeColors().at(myTagProperty.getTag()).getMaxValue(filteredAttribute);
77  // get value
78  const double value = parse<double>(getParameter(filteredAttribute, "0"));
79  // return color
80  col = GNEViewNetHelper::getRainbowScaledColor(minValue, maxValue, value);
81  }
82  }
83  }
84  return col;
85 }
86 
87 
88 double
89 GNEEdgeData::getColorValue(const GUIVisualizationSettings& s, int activeScheme) const {
90  switch (activeScheme) {
91  case 0:
92  return 0;
93  case 1:
95  case 2:
96  return 0; // setfunctional color const GNEAdditional* TAZA = getParentAdditionals().front();
97  case 3:
98  return 0; // setfunctional color const GNEAdditional* TAZA = getParentAdditionals().back();
99  case 4:
100  // by numerical attribute value
101  try {
102  if (hasParameter(s.relDataAttr)) {
104  } else {
106  }
107  } catch (NumberFormatException&) {
109  }
110  }
111  return 0;
112 }
113 
114 
115 bool
117  // get current data edit mode
119  // check if we have to filter generic data
120  if ((dataMode == DataEditMode::DATA_INSPECT) || (dataMode == DataEditMode::DATA_DELETE) || (dataMode == DataEditMode::DATA_SELECT)) {
122  } else if (myDataIntervalParent->getNet()->getViewNet()->getViewParent()->getEdgeDataFrame()->shown()) {
123  // get selected data interval and filtered attribute
125  const std::string filteredAttribute = myNet->getViewNet()->getViewParent()->getEdgeDataFrame()->getAttributeSelector()->getFilteredAttribute();
126  // check interval
127  if ((dataInterval != nullptr) && (dataInterval != myDataIntervalParent)) {
128  return false;
129  }
130  // check attribute
131  if ((filteredAttribute.size() > 0) && (getParametersMap().count(filteredAttribute) == 0)) {
132  return false;
133  }
134  // all checks ok, then return true
135  return true;
136  } else {
137  // GNEEdgeDataFrame hidden, then return false
138  return false;
139  }
140 }
141 
142 
143 void
145  // calculate path
147 }
148 
149 
150 Position
152  return getParentEdges().front()->getPositionInView();
153 }
154 
155 
156 void
158  // open device (don't use SUMO_TAG_MEANDATA_EDGE)
159  device.openTag(SUMO_TAG_EDGE);
160  // write edge ID
161  device.writeAttr(SUMO_ATTR_ID, getParentEdges().front()->getID());
162  // iterate over attributes
163  for (const auto& attribute : getParametersMap()) {
164  // write attribute (don't use writeParams)
165  device.writeAttr(attribute.first, attribute.second);
166  }
167  // close device
168  device.closeTag();
169 }
170 
171 
172 bool
174  return true;
175 }
176 
177 
178 std::string
180  return "";
181 }
182 
183 
184 void
186  throw InvalidArgument(getTagStr() + " cannot fix any problem");
187 }
188 
189 
190 void
192  // Nothing to draw
193 }
194 
195 
196 void
198  // nothing to compute
199 }
200 
201 
202 void
203 GNEEdgeData::drawLanePartialGL(const GUIVisualizationSettings& s, const GNEPathManager::Segment* segment, const double offsetFront) const {
204  // get color
205  const auto color = setColor(s);
206  if (segment->getLane() && (color.alpha() != 0) && myNet->getViewNet()->getEditModes().isCurrentSupermodeData()) {
207  // get detail level
208  const auto d = s.getDetailLevel(1);
209  // draw geometry only if we'rent in drawForObjectUnderCursor mode
210  if (!s.drawForViewObjectsHandler) {
211  // draw over all edge's lanes
212  for (const auto& laneEdge : segment->getLane()->getParentEdge()->getLanes()) {
213  // Add a draw matrix
215  // Start with the drawing of the area translating matrix to origin
218  // draw geometry
219  GUIGeometry::drawGeometry(laneEdge->getDrawingConstants()->getDetail(), laneEdge->getLaneGeometry(), laneEdge->getDrawingConstants()->getDrawingWidth());
220  // translate to top
221  glTranslated(0, 0, 0.01);
222  GLHelper::setColor(color);
223  // draw internal box lines
224  GUIGeometry::drawGeometry(laneEdge->getDrawingConstants()->getDetail(), laneEdge->getLaneGeometry(), (laneEdge->getDrawingConstants()->getDrawingWidth() - 0.1));
225  // Pop last matrix
227  // draw lock icon
229  // draw filtered attribute
230  if (getParentEdges().front()->getLanes().front() == laneEdge) {
231  drawFilteredAttribute(s, laneEdge->getLaneShape(),
234  }
235  }
236  // draw dotted contour
237  segment->getContour()->drawDottedContours(s, d, this, s.dottedContourSettings.segmentWidth, true);
238  }
239  // calculate contour and draw dotted geometry
240  segment->getContour()->calculateContourEdge(s, d, segment->getLane()->getParentEdge(), true, true);
241  }
242 }
243 
244 
245 void
246 GNEEdgeData::drawJunctionPartialGL(const GUIVisualizationSettings& /*s*/, const GNEPathManager::Segment* /*segment*/, const double /*offsetFront*/) const {
247  // EdgeDatas don't use drawJunctionPartialGL over junction
248 }
249 
250 
251 GNELane*
253  /* temporal */
254  return nullptr;
255 }
256 
257 
258 GNELane*
260  /* temporal */
261  return nullptr;
262 }
263 
264 
265 Boundary
267  return getParentEdges().front()->getCenteringBoundary();
268 }
269 
270 
271 std::string
273  switch (key) {
274  case SUMO_ATTR_ID:
275  return getPartialID() + getParentEdges().front()->getID();
276  case GNE_ATTR_DATASET:
278  case SUMO_ATTR_BEGIN:
280  case SUMO_ATTR_END:
282  case GNE_ATTR_SELECTED:
284  case GNE_ATTR_PARAMETERS:
285  return getParametersStr();
286  default:
287  throw InvalidArgument(getTagStr() + " doesn't have an attribute of type '" + toString(key) + "'");
288  }
289 }
290 
291 
292 double
294  throw InvalidArgument(getTagStr() + " doesn't have a double attribute of type '" + toString(key) + "'");
295 }
296 
297 
298 void
299 GNEEdgeData::setAttribute(SumoXMLAttr key, const std::string& value, GNEUndoList* undoList) {
300  if (value == getAttribute(key)) {
301  return; //avoid needless changes, later logic relies on the fact that attributes have changed
302  }
303  switch (key) {
304  case GNE_ATTR_SELECTED:
305  case GNE_ATTR_PARAMETERS:
306  GNEChange_Attribute::changeAttribute(this, key, value, undoList);
307  break;
308  default:
309  throw InvalidArgument(getTagStr() + " doesn't have an attribute of type '" + toString(key) + "'");
310  }
311 }
312 
313 
314 bool
315 GNEEdgeData::isValid(SumoXMLAttr key, const std::string& value) {
316  switch (key) {
317  case GNE_ATTR_SELECTED:
318  return canParse<bool>(value);
319  case GNE_ATTR_PARAMETERS:
320  return Parameterised::areAttributesValid(value, true);
321  default:
322  throw InvalidArgument(getTagStr() + " doesn't have an attribute of type '" + toString(key) + "'");
323  }
324 }
325 
326 
328  switch (key) {
329  case SUMO_ATTR_ID:
330  return false;
331  default:
332  return true;
333  }
334 }
335 
336 
337 std::string
339  return getTagStr();
340 }
341 
342 
343 std::string
345  return getTagStr() + ": " + getParentEdges().front()->getID();
346 }
347 
348 
349 void
350 GNEEdgeData::setAttribute(SumoXMLAttr key, const std::string& value) {
351  switch (key) {
352  case GNE_ATTR_SELECTED:
353  if (parse<bool>(value)) {
355  } else {
357  }
358  break;
359  case GNE_ATTR_PARAMETERS:
360  setParametersStr(value);
361  // update attribute colors
363  break;
364  default:
365  throw InvalidArgument(getTagStr() + " doesn't have an attribute of type '" + toString(key) + "'");
366  }
367 }
368 
369 /****************************************************************************/
DataEditMode
enum for data edit modes
@ DATA_SELECT
mode for selecting data elements
@ DATA_INSPECT
mode for inspecting data elements
@ DATA_EDGEDATA
mode for create edgeData elements
@ DATA_DELETE
mode for deleting data elements
@ GLO_EDGEDATA
edge data
GUIIcon
An enumeration of icons used by the gui applications.
Definition: GUIIcons.h:33
@ SVC_IGNORING
vehicles ignoring classes
@ GNE_TAG_EDGEREL_SINGLE
@ SUMO_TAG_EDGE
begin/end of the description of an edge
SumoXMLAttr
Numbers representing SUMO-XML - attributes.
@ GNE_ATTR_SELECTED
element is selected
@ SUMO_ATTR_BEGIN
weights: time range begin
@ GNE_ATTR_PARAMETERS
parameters "key1=value1|key2=value2|...|keyN=valueN"
@ SUMO_ATTR_END
weights: time range end
@ GNE_ATTR_DATASET
data set of a generic data
@ SUMO_ATTR_ID
std::string toString(const T &t, std::streamsize accuracy=gPrecision)
Definition: ToString.h:46
A class that stores a 2D geometrical boundary.
Definition: Boundary.h:39
static void setColor(const RGBColor &c)
Sets the gl-color to this value.
Definition: GLHelper.cpp:655
static void popMatrix()
pop matrix
Definition: GLHelper.cpp:130
static void pushMatrix()
push matrix
Definition: GLHelper.cpp:117
const std::string getID() const
get ID (all Attribute Carriers have one)
bool isAttributeCarrierSelected() const
check if attribute carrier is selected
const std::string & getTagStr() const
get tag assigned to this object in string format
void unselectAttributeCarrier(const bool changeFlag=true)
unselect attribute carrier using GUIGlobalSelection
GNENet * myNet
pointer to net
GNENet * getNet() const
get pointer to net
void selectAttributeCarrier(const bool changeFlag=true)
select attribute carrier using GUIGlobalSelection
const GNETagProperties & myTagProperty
reference to tagProperty associated with this attribute carrier
static void changeAttribute(GNEAttributeCarrier *AC, SumoXMLAttr key, const std::string &value, GNEUndoList *undoList, const bool force=false)
change attribute
void calculateContourEdge(const GUIVisualizationSettings &s, const GUIVisualizationSettings::Detail d, const GNEEdge *edge, const bool closeFirstExtrem, const bool closeLastExtrem) const
calculate contour edge
Definition: GNEContour.cpp:129
void drawDottedContours(const GUIVisualizationSettings &s, const GUIVisualizationSettings::Detail d, const GNEAttributeCarrier *AC, const double lineWidth, const bool addOffset) const
drawing contour functions
Definition: GNEContour.cpp:263
An Element which don't belong to GNENet but has influence in the simulation.
std::string getAttribute(SumoXMLAttr key) const
GNEDataSet * getDataSetParent() const
Returns a pointer to GNEDataSet parent.
const std::map< SumoXMLTag, GNEDataSet::AttributeColors > & getSpecificAttributeColors() const
specific attribute colors
void updateAttributeColors()
update attribute colors deprecated
Definition: GNEDataSet.cpp:143
bool isGenericDataVisible() const
check if current edge data is visible
GNEEdgeData(GNEDataInterval *dataIntervalParent, GNEEdge *edgeParent, const Parameterised::Map &parameters)
Constructor.
Definition: GNEEdgeData.cpp:48
std::string getAttribute(SumoXMLAttr key) const
void drawLanePartialGL(const GUIVisualizationSettings &s, const GNEPathManager::Segment *segment, const double offsetFront) const
Draws partial object over lane.
void writeGenericData(OutputDevice &device) const
write data set element into a xml file
bool isValid(SumoXMLAttr key, const std::string &value)
method for checking if the key and their conrrespond attribute are valids
void setAttribute(SumoXMLAttr key, const std::string &value, GNEUndoList *undoList)
method for setting the attribute and letting the object perform data set changes
GNELane * getFirstPathLane() const
get first path lane
GNELane * getLastPathLane() const
get last path lane
bool isAttributeEnabled(SumoXMLAttr key) const
std::string getHierarchyName() const
get Hierarchy Name (Used in AC Hierarchy)
double getAttributeDouble(SumoXMLAttr key) const
std::string getPopUpID() const
get PopPup ID (Used in AC Hierarchy)
double getColorValue(const GUIVisualizationSettings &s, int activeScheme) const
Definition: GNEEdgeData.cpp:89
Boundary getCenteringBoundary() const
~GNEEdgeData()
Destructor.
Definition: GNEEdgeData.cpp:54
RGBColor setColor(const GUIVisualizationSettings &s) const
get edge data color
Definition: GNEEdgeData.cpp:58
void computePathElement()
compute pathElement
std::string getGenericDataProblem() const
return a string with the current data set problem (by default empty, can be reimplemented in children...
void updateGeometry()
update pre-computed geometry information
void drawGL(const GUIVisualizationSettings &s) const
Draws the object.
bool isGenericDataValid() const
check if current data set is valid to be written into XML (by default true, can be reimplemented in c...
void drawJunctionPartialGL(const GUIVisualizationSettings &s, const GNEPathManager::Segment *segment, const double offsetFront) const
Draws partial object over junction.
void fixGenericDataProblem()
fix data set problem (by default throw an exception, has to be reimplemented in children)
Position getPositionInView() const
Returns element position in view.
A road/street connecting two junctions (netedit-version)
Definition: GNEEdge.h:53
const std::vector< GNELane * > & getLanes() const
returns a reference to the lane vector
Definition: GNEEdge.cpp:1047
std::string getFilteredAttribute() const
get filtered attribute
GNEDataInterval * getDataInterval() const
get current select data set ID
const AttributeSelector * getAttributeSelector() const
getattribute selector modul
const IntervalSelector * getIntervalSelector() const
get interval selector modul
An Element which don't belong to GNENet but has influence in the simulation.
GNEDataInterval * myDataIntervalParent
dataInterval Parent
std::string getPartialID() const
get partial ID
bool isVisibleInspectDeleteSelect() const
check if attribute is visible in inspect, delete or select mode
void drawFilteredAttribute(const GUIVisualizationSettings &s, const PositionVector &laneShape, const std::string &attribute, const GNEDataInterval *dataIntervalParent) const
draw filtered attribute
const std::vector< GNEEdge * > & getParentEdges() const
get parent edges
This lane is powered by an underlying GNEEdge and basically knows how to draw itself.
Definition: GNELane.h:46
GNEEdge * getParentEdge() const
get parent edge
Definition: GNELane.cpp:196
GNEPathManager * getPathManager()
get path manager
Definition: GNENet.cpp:133
GNEViewNet * getViewNet() const
get view net
Definition: GNENet.cpp:2022
GNEContour * getContour() const
getcontour associated with segment
const GNELane * getLane() const
get lane associated with this segment
void calculateConsecutivePathEdges(PathElement *pathElement, SUMOVehicleClass vClass, const std::vector< GNEEdge * > edges)
calculate consecutive path edges
SumoXMLTag getTag() const
get Tag vinculated with this attribute Property
const GNEViewNetHelper::EditModes & getEditModes() const
get edit modes
Definition: GNEViewNet.cpp:703
void drawTranslateFrontAttributeCarrier(const GNEAttributeCarrier *AC, double typeOrLayer, const double extraOffset=0)
draw front attributeCarrier
GNEViewParent * getViewParent() const
get the net object
GNEEdgeDataFrame * getEdgeDataFrame() const
get frame for DATA_EDGEDATA
static void drawGeometry(const GUIVisualizationSettings::Detail d, const GUIGeometry &geometry, const double width, double offset=0)
draw geometry
GUIGlObjectType getType() const
Returns the type of the object as coded in GUIGlObjectType.
Definition: GUIGlObject.h:156
T getColor(const double value) const
const std::string & getName() const
Stores the information about how to visualize structures.
static const std::string SCHEME_NAME_DATA_ATTRIBUTE_NUMERICAL
Detail getDetailLevel(const double exaggeration) const
return the detail level
GUIVisualizationColorSettings colorSettings
color settings
GUIVisualizationDottedContourSettings dottedContourSettings
dotted contour settings
bool drawForViewObjectsHandler
whether drawing is performed for the purpose of selecting objects in view using ViewObjectsHandler
std::string relDataAttr
key for coloring by edgeRelation / tazRelation attribute
Static storage of an output device and its base (abstract) implementation.
Definition: OutputDevice.h:61
OutputDevice & openTag(const std::string &xmlElement)
Opens an XML tag.
OutputDevice & writeAttr(const SumoXMLAttr attr, const T &val)
writes a named attribute
Definition: OutputDevice.h:254
bool closeTag(const std::string &comment="")
Closes the most recently opened tag and optionally adds a comment.
static bool areAttributesValid(const std::string &value, bool report=false, const std::string kvsep="=", const std::string sep="|")
check if given string can be parsed to an attributes map "key1=value1|key2=value2|....
bool hasParameter(const std::string &key) const
Returns whether the parameter is set.
std::map< std::string, std::string > Map
parameters map
Definition: Parameterised.h:45
void setParametersStr(const std::string &paramsString, const std::string kvsep="=", const std::string sep="|")
set the inner key/value map in string format "key1=value1|key2=value2|...|keyN=valueN"
virtual const std::string getParameter(const std::string &key, const std::string defaultValue="") const
Returns the value for a given key.
const Parameterised::Map & getParametersMap() const
Returns the inner key/value map.
std::string getParametersStr(const std::string kvsep="=", const std::string sep="|") const
Returns the inner key/value map in string format "key1=value1|key2=value2|...|keyN=valueN".
A point in 2D or 3D with translation and scaling methods.
Definition: Position.h:37
static const RGBColor BLACK
Definition: RGBColor.h:193
static const RGBColor RED
named colors
Definition: RGBColor.h:185
static double toDouble(const std::string &sData)
converts a string into the double value described by it by calling the char-type converter
DataEditMode dataEditMode
the current Data edit mode
bool isCurrentSupermodeData() const
@check if current supermode is Data
static void drawLockIcon(const GUIVisualizationSettings::Detail d, const GNEAttributeCarrier *AC, GUIGlObjectType type, const Position position, const double exaggeration, const double size=0.5, const double offsetx=0, const double offsety=0)
draw lock icon
static const RGBColor & getRainbowScaledColor(const double min, const double max, const double value)
get rainbow scaled color
RGBColor selectedEdgeDataColor
edge data selection color
static const double segmentWidth
width of dotted contour segments