45 if (myMinMaxValue.count(attribute) == 0) {
46 myMinMaxValue[attribute] = std::make_pair(value, value);
49 if (value < myMinMaxValue.at(attribute).first) {
50 myMinMaxValue.at(attribute).first = value;
53 if (value > myMinMaxValue.at(attribute).second) {
54 myMinMaxValue.at(attribute).second = value;
63 for (
const auto& attributeColor : attributeColors.
myMinMaxValue) {
64 if (myMinMaxValue.count(attributeColor.first) == 0) {
65 myMinMaxValue[attributeColor.first] = attributeColor.second;
68 if (attributeColor.second.first < myMinMaxValue.at(attributeColor.first).first) {
69 myMinMaxValue.at(attributeColor.first).first = attributeColor.second.first;
72 if (attributeColor.second.second > myMinMaxValue.at(attributeColor.first).second) {
73 myMinMaxValue.at(attributeColor.first).second = attributeColor.second.second;
82 return (myMinMaxValue.count(attribute) > 0);
88 return myMinMaxValue.at(attribute).first;
94 return myMinMaxValue.at(attribute).second;
100 myMinMaxValue.clear();
138 interval.second->updateAttributeColors();
149 for (
const auto& specificAttributeColor : interval.second->getSpecificAttributeColors()) {
162const std::map<SumoXMLTag, GNEDataSet::AttributeColors>&
193 for (
const auto& genericData : interval.second->getGenericDataChildren()) {
195 genericData->writeGenericData(device);
277 throw ProcessError(
TL(
"DataInterval wasn't previously inserted"));
285 if (interval.second == dataInterval) {
301 throw ProcessError(
TL(
"DataInterval wasn't previously inserted"));
315 std::map<const double, GNEDataInterval*> copyOfDataIntervalMap;
317 if (element.second != dataInterval) {
318 copyOfDataIntervalMap.insert(element);
337const std::map<const double, GNEDataInterval*>&
413 interval.second->updateGenericDataIDs();
427 if (dataIntervalMap.empty()) {
431 const auto itFirstElement = dataIntervalMap.begin();
432 const auto itLastElement = dataIntervalMap.rbegin();
433 if (newBegin > newEnd) {
435 }
else if (dataIntervalMap.count(newBegin) == 1) {
437 }
else if (newBegin < itFirstElement->first) {
438 return (newEnd <= itFirstElement->first);
439 }
else if (newBegin > itLastElement->first) {
440 return (newBegin >= itLastElement->second->getAttributeDouble(
SUMO_ATTR_END));
443 for (
auto it = itFirstElement; it != dataIntervalMap.end(); it++) {
444 if (newBegin < it->first) {
446 auto itPrevious = it;
449 if (itPrevious->second->getAttributeDouble(
SUMO_ATTR_END) < newBegin) {
@ SUMO_TAG_INTERVAL
an aggreagated-output interval
SumoXMLAttr
Numbers representing SUMO-XML - attributes.
@ SUMO_ATTR_BEGIN
weights: time range begin
@ SUMO_ATTR_END
weights: time range end
std::string toString(const T &t, std::streamsize accuracy=gPrecision)
const std::string getID() const
get ID (all Attribute Carriers have one)
std::string getCommonAttribute(const Parameterised *parameterised, SumoXMLAttr key) const
void setCommonAttribute(SumoXMLAttr key, const std::string &value, GNEUndoList *undoList)
const std::string & getTagStr() const
get tag assigned to this object in string format
GNENet * myNet
pointer to net
bool isCommonValid(SumoXMLAttr key, const std::string &value) const
static void changeAttribute(GNEAttributeCarrier *AC, SumoXMLAttr key, const std::string &value, GNEUndoList *undoList, const bool force=false)
change attribute
double getAttributeDouble(SumoXMLAttr key) const
std::map< std::string, std::pair< double, double > > myMinMaxValue
map with the minimum and maximum value
void updateAllValues(const AttributeColors &attributeColors)
update value for all attributes
bool exist(const std::string &attribute) const
check if given attribute exist (needed for non-double attributes)
double getMaxValue(const std::string &attribute) const
get maximum value
AttributeColors()
default constructor
double getMinValue(const std::string &attribute) const
get minimum value
void clear()
clear AttributeColors
void updateValues(const std::string &attribute, const double value)
update value for an specific attribute
void setAttribute(SumoXMLAttr key, const std::string &value, GNEUndoList *undoList)
method for setting the attribute and letting the object perform data element changes
bool isValid(SumoXMLAttr key, const std::string &value)
method for checking if the key and their conrrespond attribute are valids
Position getPositionInView() const
Returns element position in view.
GUIGlObject * getGUIGlObject()
get GUIGlObject associated with this AttributeCarrier
void writeDataSet(OutputDevice &device) const
write data set
std::string myDataSetID
dataSet ID
bool dataIntervalChildrenExist(GNEDataInterval *dataInterval) const
check if given data interval exist
std::string getAttribute(SumoXMLAttr key) const
std::map< const double, GNEDataInterval * > myDataIntervalChildren
map with dataIntervals children sorted by begin
void removeDataIntervalChild(GNEDataInterval *dataInterval)
add data interval child
std::string getPopUpID() const
get PopPup ID (Used in AC Hierarchy)
GNEDataInterval * retrieveInterval(const double begin, const double end) const
return interval
GNEHierarchicalElement * getHierarchicalElement()
get GNEHierarchicalElement associated with this AttributeCarrier
std::string getHierarchyName() const
get Hierarchy Name (Used in AC Hierarchy)
bool checkDrawDeleteContourSmall() const
check if draw delete contour small (pink/white)
bool checkDrawMoveContour() const
check if draw move contour (red)
bool checkDrawOverContour() const
check if draw over contour (orange)
bool checkDrawFromContour() const
check if draw from contour (green)
const Parameterised::Map & getACParametersMap() const
get parameters map
const GNEDataSet::AttributeColors & getAllAttributeColors() const
all attribute colors
void updateAttributeColors()
update attribute colors deprecated
double getAttributeDouble(SumoXMLAttr key) const
bool checkDrawRelatedContour() const
check if draw related contour (cyan)
std::map< SumoXMLTag, GNEDataSet::AttributeColors > mySpecificAttributeColors
specific attribute colors
bool checkDrawSelectContour() const
check if draw select contour (blue)
bool checkNewBeginEnd(const GNEDataInterval *dataInterval, const double newBegin, const double newEnd)
check if new begin or end for given GNEDataInterval is given
GNEDataSet::AttributeColors myAllAttributeColors
all attribute colors
const std::map< SumoXMLTag, GNEDataSet::AttributeColors > & getSpecificAttributeColors() const
specific attribute colors
bool checkDrawToContour() const
check if draw from contour (magenta)
bool checkDrawDeleteContour() const
check if draw delete contour (pink/white)
const std::map< const double, GNEDataInterval * > & getDataIntervalChildren() const
get data interval children
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
void updateGeometry()
update pre-computed geometry information
void addDataIntervalChild(GNEDataInterval *dataInterval)
add data interval child
GNEDataSet(const std::string &dataSetID, GNENet *net, const std::string &filename)
Constructor.
void updateDataIntervalBegin(const double oldBegin)
update data interval begin
void removeCurrentEditedAttributeCarrier(const GNEAttributeCarrier *HE)
if given AttributeCarrier is the same of myHE, set it as nullptr
GNEElementTree * getHierarchicalElementTree() const
get GNEElementTree modul
void insertDataInterval(const GNEAttributeCarrier *AC, GNEDataInterval *dataInterval)
insert data interval in container
GNEDataSet * retrieveDataSet(const std::string &id, bool hardFail=true) const
Returns the named data set.
void deleteDataInterval(GNEDataInterval *dataInterval)
delete data interval of container
A NBNetBuilder extended by visualisation and editing capabilities.
GNENetHelper::AttributeCarriers * getAttributeCarriers() const
get all attribute carriers used in this net
GNEViewNet * getViewNet() const
get view net
void uninspectAC(GNEAttributeCarrier *AC)
uninspect AC
GNEViewNetHelper::InspectedElements & getInspectedElements()
get inspected elements
GNEViewNetHelper::IntervalBar & getIntervalBar()
get interval bar
GNEViewParent * getViewParent() const
get the net object
GNEInspectorFrame * getInspectorFrame() const
get frame for inspect elements
Static storage of an output device and its base (abstract) implementation.
OutputDevice & writeAttr(const SumoXMLAttr attr, const T &val)
writes a named attribute
OutputDevice & openTag(const std::string &xmlElement)
Opens an XML tag.
bool closeTag(const std::string &comment="")
Closes the most recently opened tag and optionally adds a comment.
std::map< std::string, std::string > Map
parameters map
const Parameterised::Map & getParametersMap() const
Returns the inner key/value map.
A point in 2D or 3D with translation and scaling methods.
static bool isValidNetID(const std::string &value)
whether the given string is a valid id for a network element