45#pragma warning(disable: 4355)
172 for (
const auto& inspectedAC :
myNet->getViewNet()->getInspectedElements().getACs()) {
173 if (inspectedAC->getTagProperty()->vehicleRouteEmbedded()) {
175 if (demandElement && (demandElement->getChildDemandElements().size() > 0) &&
176 (demandElement->getChildDemandElements().at(0) ==
this)) {
183 if (
myNet->getViewNet()->getPopup()) {
184 return myNet->getViewNet()->getPopup()->getGLObject() ==
this;
193 const auto& modes =
myNet->getViewNet()->getEditModes();
195 const auto& personFramePlanSelector =
myNet->getViewNet()->getViewParent()->getPersonFrame()->getPlanSelector();
196 const auto& personPlanFramePlanSelector =
myNet->getViewNet()->getViewParent()->getPersonPlanFrame()->getPlanSelector();
197 const auto& containerFramePlanSelector =
myNet->getViewNet()->getViewParent()->getContainerFrame()->getPlanSelector();
198 const auto& containerPlanFramePlanSelector =
myNet->getViewNet()->getViewParent()->getContainerPlanFrame()->getPlanSelector();
202 const auto& vehicleFrame =
myNet->getViewNet()->getViewParent()->getVehicleFrame();
204 if (vehicleFrame->shown()) {
206 const auto& vehicleTemplate = vehicleFrame->getVehicleTagSelector()->getCurrentTemplateAC();
208 if (vehicleTemplate && vehicleTemplate->getTagProperty()->vehicleRoute()) {
209 return myNet->getViewNet()->getViewObjectsSelector().getGUIGlObjectFront() ==
this;
211 }
else if (modes.isCurrentSupermodeDemand()) {
217 return myNet->getViewNet()->getViewObjectsSelector().getGUIGlObjectFront() ==
this;
228 const auto& editModes =
myNet->getViewNet()->getEditModes();
241 const auto route =
myNet->getViewNet()->getViewObjectsSelector().getDemandElementFront();
242 if (route && (route ==
myNet->getViewNet()->getViewObjectsSelector().getAttributeCarrierFront())) {
246 const auto vehicle =
myNet->getViewNet()->getViewObjectsSelector().getDemandElementFront();
247 if (vehicle && (vehicle ==
myNet->getViewNet()->getViewObjectsSelector().getAttributeCarrierFront())) {
258 const auto& editModes =
myNet->getViewNet()->getEditModes();
271 const auto& editModes =
myNet->getViewNet()->getEditModes();
273 if (!
myNet->getViewNet()->isCurrentlyMovingElements() &&
274 editModes.isCurrentSupermodeDemand() &&
277 myNet->getViewNet()->getViewObjectsSelector().getGUIGlObjectFront() ==
this) {
313 new FXMenuSeparator(ret);
325 for (
const auto& attrProperty :
myTagProperty->getAttributeProperties()) {
327 if (attrProperty->isUnique()) {
328 ret->
mkItem(attrProperty->getAttrStr().c_str(),
false,
getAttribute(attrProperty->getAttr()));
330 ret->
mkItem(attrProperty->getAttrStr().c_str(),
true,
getAttribute(attrProperty->getAttr()));
341 if (
myNet->getViewNet()->getEditModes().isCurrentSupermodeDemand()) {
365 myNet->deleteDemandElement(
this,
myNet->getViewNet()->getUndoList());
371 myNet->deleteDemandElement(
this,
myNet->getViewNet()->getUndoList());
384 myNet->getViewNet()->getViewParent()->getSelectorFrame()->getSelectionInformation()->updateInformationLabel();
420 return (
myNet->getAttributeCarriers()->retrieveDemandElement(
myTagProperty->getTag(),
value,
false) ==
nullptr);
434 return (
myNet->getAttributeCarriers()->retrieveDemandElements(tags,
value,
false) ==
nullptr);
447 myNet->getAttributeCarriers()->updateDemandElementID(
this, newID);
453 childDemandElement->setDemandElementID(
getID());
462 throw InvalidArgument(
"This demand element doesn't have a type parent");
475 throw InvalidArgument(
"This demand element doesn't have a route parent");
485std::vector<GNEDemandElement*>
489 std::vector<GNEDemandElement*> invalidStops;
493 for (
const auto& edgeStop : edgeStopIndex) {
494 if (edgeStop.stopIndex == -1) {
495 for (
const auto& stop : edgeStop.stops) {
496 invalidStops.push_back(stop);
512 const double rot = ((double)atan2((posB.
x() - posA.
x()), (posA.
y() - posB.
y())) * (double) 180.0 / (
double)
M_PI);
529 const double width,
const double length,
const double exaggeration)
const {
531 const double contourWidth = (0.05 * exaggeration);
536 glRotated(rotation, 0, 0, -1);
537 glTranslated((width * exaggeration * 0.5) + (0.35 * exaggeration) + 0.05, 0, 0);
542 glTranslated(0, 0, 0.1);
561 auto newLane =
myNet->getAttributeCarriers()->retrieveLane(
value);
568 auto newJunction =
myNet->getAttributeCarriers()->retrieveJunction(
value);
575 auto newJunction =
myNet->getAttributeCarriers()->retrieveJunction(
value);
582 auto newEdge =
myNet->getAttributeCarriers()->retrieveEdge(
value);
589 auto newEdge =
myNet->getAttributeCarriers()->retrieveEdge(
value);
596 auto newAdditional =
myNet->getAttributeCarriers()->retrieveAdditional(tag,
value);
603 auto newAdditional =
myNet->getAttributeCarriers()->retrieveAdditional(tag,
value);
612 for (
auto it = tags.begin(); (it != tags.end()) && (newDemandElement ==
nullptr); it++) {
613 newDemandElement =
myNet->getAttributeCarriers()->retrieveDemandElement(*it,
value,
false);
615 if (newDemandElement) {
618 throw ProcessError(
"Attempted to replace with non-existant demand element " +
value);
630std::vector<GNEDemandElement::EdgeStopIndex>
632 std::vector<GNEDemandElement::EdgeStopIndex> edgeStopIndex;
636 std::vector<GNEEdge*> pathEdges;
641 pathEdges = parent->getParentEdges();
642 }
else if (parent->getTagProperty()->vehicleRoute()) {
644 if (parent->getParentDemandElements().size() > 1) {
645 pathEdges = parent->getParentDemandElements().at(1)->getParentEdges();
647 }
else if (parent->getTagProperty()->vehicleRouteEmbedded()) {
649 pathEdges = parent->getChildDemandElements().front()->getParentEdges();
652 const auto lastEdge = parent->getParentEdges().back();
654 const auto& pathElementSegments =
myNet->getDemandPathManager()->getPathElementSegments(parent);
656 for (
auto it = pathElementSegments.begin(); (it != pathElementSegments.end()) && !stop; it++) {
657 if ((*it)->getLane()) {
658 pathEdges.push_back((*it)->getLane()->getParentEdge());
660 if (pathEdges.back() == lastEdge) {
667 for (
const auto& demandElement : parent->getChildDemandElements()) {
668 if (demandElement->getTagProperty()->isVehicleStop()) {
671 if (demandElement->getParentAdditionals().size() > 0) {
672 edge = demandElement->
getParentAdditionals().front()->getParentLanes().front()->getParentEdge();
677 if ((edgeStopIndex.size() > 0) && (edgeStopIndex.back().edge == edge)) {
678 edgeStopIndex.back().stops.push_back(demandElement);
685 int currentEdgeStopIndex = 0;
686 for (
int i = 0; (i < (int)pathEdges.size()) && (currentEdgeStopIndex < (
int)edgeStopIndex.size()); i++) {
688 if (edgeStopIndex[currentEdgeStopIndex].edge == pathEdges.at(i)) {
689 edgeStopIndex[currentEdgeStopIndex].stopIndex = i;
690 currentEdgeStopIndex++;
694 for (
int j = (i + 1); j < (int)pathEdges.size(); j++) {
695 if (edgeStopIndex[currentEdgeStopIndex].edge == pathEdges.at(j)) {
701 currentEdgeStopIndex++;
707 for (
auto& edgeStop : edgeStopIndex) {
708 if (edgeStop.stops.size() > 1) {
710 std::map<double, std::vector<GNEDemandElement*> > sortedStops;
711 for (
const auto& stop : edgeStop.stops) {
719 edgeStop.stops.clear();
720 for (
const auto& sortedStop : sortedStops) {
721 edgeStop.stops.insert(edgeStop.stops.end(), sortedStop.second.begin(), sortedStop.second.end());
725 return edgeStopIndex;
751 return parameters->
color;
759 return parameters->
color;
782 double hue = 180. + atan2(center.
x() - p.
x(), center.
y() - p.
y()) * 180. /
M_PI;
790 double hue = 180. + atan2(center.
x() - p.
x(), center.
y() - p.
y()) * 180. /
M_PI;
798 double hue = 180. + atan2(pb.
x() - pe.
x(), pb.
y() - pe.
y()) * 180. /
M_PI;
805 std::hash<const GNEDemandElement*> ptr_hash;
806 const double hue = (double)(ptr_hash(
this) % 360);
807 const double sat = (double)((ptr_hash(
this) / 360) % 67) / 100. + 0.33;
819 std::vector<GNEEdge*> edges;
830 const auto path =
myNet->getDemandPathManager()->getPathCalculator()->calculateDijkstraPath(
getVClass(), edges);
832 if (path.size() > 0) {
834 for (
const auto& edge : path) {
835 length += edge->getNBEdge()->getFinalLength();
837 for (
int i = 0; i < ((int)path.size() - 1); i++) {
838 length += path.at(i)->getChildLanes().front()->getLane2laneConnections().getLane2laneGeometry(path.at(i + 1)->getChildLanes().front()).getShape().length();
848 FXMenuPane* transformOperation =
new FXMenuPane(ret);
850 auto reverseMenuCascade =
new FXMenuCascade(ret,
TL(
"reverse"),
nullptr, transformOperation);
856 reverseMenuCascade->enable();
858 reverseMenuCascade->disable();
@ DEMAND_PERSONPLAN
Mode for editing person plan.
@ DEMAND_CONTAINER
Mode for editing container.
@ DEMAND_DELETE
mode for deleting demand elements
@ DEMAND_PERSON
Mode for editing person.
@ DEMAND_SELECT
mode for selecting demand elements
@ DEMAND_MOVE
mode for moving demand elements
@ DEMAND_CONTAINERPLAN
Mode for editing container plan.
@ MID_GNE_ADDREVERSE
add reverse element
@ MID_GNE_REVERSE
reverse current element
@ MID_OPEN_ADDITIONAL_DIALOG
open additional dialog (used in netedit)
@ MID_COPY_NAME
Copy object name - popup entry.
@ GLO_VEHICLELABELS
stack and flow labels (used in netedit)
GUIPropertySchemeStorage< GUIColorScheme > GUIColorer
const std::string invalid_return< std::string >::value
const long long int VEHPARS_COLOR_SET
SumoXMLTag
Numbers representing SUMO-XML - element names.
@ SUMO_TAG_ROUTE
description of a route
@ GNE_TAG_ROUTE_EMBEDDED
embedded route
SumoXMLAttr
Numbers representing SUMO-XML - attributes.
@ SUMO_ATTR_EDGES
the edges of a route
@ SUMO_ATTR_COLOR
A color information.
std::string toString(const T &t, std::streamsize accuracy=gPrecision)
A class that stores a 2D geometrical boundary.
static void setColor(const RGBColor &c)
Sets the gl-color to this value.
static void popMatrix()
pop matrix
static void drawBoxLine(const Position &beg, double rot, double visLength, double width, double offset=0)
Draws a thick line.
static void pushMatrix()
push matrix
static void drawText(const std::string &text, const Position &pos, const double layer, const double size, const RGBColor &col=RGBColor::BLACK, const double angle=0, const int align=0, double width=-1)
bool isAttributeCarrierSelected() const
check if attribute carrier is selected
void markForDrawingFront()
mark for drawing front
void selectAttributeCarrier()
select attribute carrier using GUIGlobalSelection
FXIcon * getACIcon() const
get FXIcon associated to this AC
bool mySelected
boolean to check if this AC is selected (more quickly as checking GUIGlObjectStorage)
const std::string getID() const override
get ID (all Attribute Carriers have one)
static T parse(const std::string &string)
parses a value of type T from string (used for basic types: int, double, bool, etc....
PositionVector getCommonAttributePositionVector(SumoXMLAttr key) const
void unselectAttributeCarrier()
unselect attribute carrier using GUIGlobalSelection
virtual bool isAttributeEnabled(SumoXMLAttr key) const
const std::string & getTagStr() const
get tag assigned to this object in string format
bool isTemplate() const
check if this AC is template
void drawInLayer(const double typeOrLayer, const double extraOffset=0) const
draw element in the given layer, or in front if corresponding flag is enabled
Position getCommonAttributePosition(SumoXMLAttr key) const
const std::string & getFilename() const
get filename in which save this AC
const GNETagProperties * getTagProperty() const
get tagProperty associated with this Attribute Carrier
GNEAttributeCarrier(const SumoXMLTag tag, GNENet *net, const std::string &filename, const bool isTemplate)
Constructor.
GNENet * myNet
pointer to net
GNENet * getNet() const
get pointer to net
virtual void updateGeometry()=0
update pre-computed geometry information
virtual std::string getAttribute(SumoXMLAttr key) const =0
const GNETagProperties * myTagProperty
reference to tagProperty associated with this attribute carrier
void buildMenuCommandRouteLength(GUIGLObjectPopupMenu *ret) const
build menu command route length
bool checkDrawFromContour() const override
check if draw from contour (green)
bool isGLObjectLocked() const override
check if element is locked
Position getAttributePosition(SumoXMLAttr key) const override
std::vector< GNEDemandElement * > getInvalidStops() const
get invalid stops
virtual SUMOVehicleClass getVClass() const =0
obtain VClass related with this demand element
void updateDemandElementGeometry(const GNELane *lane, const double posOverLane)
update element stacked geometry (stacked)
void drawStackLabel(const int number, const std::string &element, const Position &position, const double rotation, const double width, const double length, const double exaggeration) const
draw stack label
GNEHierarchicalElement * getHierarchicalElement() override
methods to retrieve the elements linked to this GNEDemandElement
GUIGeometry myDemandElementGeometry
demand element geometry (also called "stacked geometry")
bool isValidDemandElementID(const std::string &value) const
check if a new demand element ID is valid
void selectGLObject() override
select element
GNEDemandElement * getNextChildDemandElement(const GNEDemandElement *demandElement) const
get next child demand element to the given demand element
void updateDemandElementStackLabel(const int stack)
update stack label
bool checkDrawDeleteContour() const override
check if draw delete contour (pink/white)
void replaceLastParentEdge(const std::string &value)
replace the last parent edge
void drawJunctionLine(const GNEDemandElement *element) const
draw line between junctions
virtual const RGBColor & getColor() const =0
get color
bool isPathElementSelected() const override
check if path element is selected
GNEDemandElement(const std::string &id, GNENet *net, const std::string &filename, SumoXMLTag tag, const GNEPathElement::Options pathOptions)
Constructor.
GUIParameterTableWindow * getParameterWindow(GUIMainWindow &app, GUISUMOAbstractView &parent) override
Returns an own parameter window.
void replaceFirstParentAdditional(SumoXMLTag tag, const std::string &value)
replace the first parent additional
GNEDemandElement * getRouteParent() const
get route parent (always the second parent demand element)
void setDemandElementID(const std::string &newID)
set demand element id
PositionVector getAttributePositionVector(SumoXMLAttr key) const override
bool checkDrawMoveContour() const override
check if draw move contour (red)
GUIGeometry mySpreadGeometry
demand element spread geometry (Only used by vehicles and pedestrians)
void buildMenuAddReverse(GUIGLObjectPopupMenu *ret) const
build menu command route length
void updateGLObject() override
update GLObject (geometry, ID, etc.)
void replaceFirstParentJunction(const std::string &value)
replace the first parent junction
std::vector< EdgeStopIndex > getEdgeStopIndex() const
get edgeStopIndex
bool checkDrawSelectContour() const override
check if draw select contour (blue)
GNEDemandElement * getTypeParent() const
get type parent (needed because first parent can be either type or typeDistribution)
void replaceDemandElementParent(const std::vector< SumoXMLTag > tags, const std::string &value, const int parentIndex)
replace demand element parent
void deleteGLObject() override
delete element
void replaceParentEdges(const std::string &value)
all edges
virtual GUIGLObjectPopupMenu * getPopUpMenu(GUIMainWindow &app, GUISUMOAbstractView &parent) override
Returns an own popup-menu.
void replaceFirstParentEdge(const std::string &value)
replace the first parent edge
int myStackedLabelNumber
stacked label number
void updateDemandElementSpreadGeometry(const GNELane *lane, const double posOverLane)
update element spread geometry
virtual Position getPositionInView() const =0
Returns position of demand element in view.
RGBColor getColorByScheme(const GUIColorer &c, const SUMOVehicleParameter *parameters) const
get color by scheme (used by vehicles, persons and containers)
const GUIGeometry & getDemandElementGeometry()
get demand element geometry (stacked)
virtual bool checkChildDemandElementRestriction() const
check restriction with the number of children
GUIGlObject * getGUIGlObject() override
get GUIGlObject associated with this GNEDemandElement
bool checkDrawRelatedContour() const override
check if draw related contour (cyan)
GNEDemandElement * getPreviousChildDemandElement(const GNEDemandElement *demandElement) const
get previous child demand element to the given demand element
void replaceFirstParentLane(const std::string &value)
replace the first parent lane
bool checkDrawDeleteContourSmall() const override
check if draw delete contour small (pink/white)
void replaceLastParentAdditional(SumoXMLTag tag, const std::string &value)
replace the last parent additional
virtual ~GNEDemandElement()
Destructor.
virtual void openDemandElementDialog()
open DemandElement Dialog
void replaceLastParentJunction(const std::string &value)
replace the last parent junction
bool checkDrawToContour() const override
check if draw from contour (magenta)
void markAsFrontElement() override
mark element as front element
bool checkDrawOverContour() const override
check if draw over contour (orange)
const GNEHierarchicalContainerParents< GNEAdditional * > & getParentAdditionals() const
get parent additionals
const GNEHierarchicalContainerParents< GNEDemandElement * > & getParentDemandElements() const
get parent demand elements
const GNEHierarchicalContainerParents< GNEEdge * > & getParentEdges() const
get parent edges
friend class GNEDemandElement
const GNEHierarchicalContainerParents< GNEJunction * > & getParentJunctions() const
get parent junctions
const GNEHierarchicalContainerParents< GNELane * > & getParentLanes() const
get parent lanes
static void updateParent(ElementType element, const int index, ParentType newParent)
update single parent element
const GNEHierarchicalContainerChildren< GNEDemandElement * > & getChildDemandElements() const
return child demand elements
static void updateParents(ElementType element, GNEHierarchicalContainerParents< ParentType > newParents)
update all parent elements
const PositionVector & getLaneShape() const
get elements shape
A NBNetBuilder extended by visualisation and editing capabilities.
GNEPathElement(const GNEPathElement::Options options)
constructor
bool isRoute() const
check if pathElement is a route
static bool canReverse(const GNEDemandElement *element)
reverse functions
static FXMenuCommand * buildFXMenuCommand(FXComposite *p, const std::string &text, FXIcon *icon, FXObject *tgt, FXSelector sel, const bool disable=false)
build menu command
virtual void setMicrosimID(const std::string &newID)
Changes the microsimID of the object.
GUIGlObjectType getType() const
Returns the type of the object as coded in GUIGlObjectType.
void buildPopUpMenuCommonOptions(GUIGLObjectPopupMenu *ret, GUIMainWindow &app, GUISUMOAbstractView *parent, const SumoXMLTag tag, const bool selected, bool addSeparator=true)
GUIGlObject(GUIGlObjectType type, const std::string µsimID, FXIcon *icon)
Constructor.
A window containing a gl-object's parameter.
void mkItem(const char *name, bool dynamic, ValueSource< T > *src)
Adds a row which obtains its value from a ValueSource.
void closeBuilding(const Parameterised *p=0)
Closes the building of the table.
T getColor(const double value) const
A point in 2D or 3D with translation and scaling methods.
double distanceTo2D(const Position &p2) const
returns the euclidean distance in the x-y-plane
double distanceTo(const Position &p2) const
returns the euclidean distance in 3 dimensions
double x() const
Returns the x-position.
double y() const
Returns the y-position.
static const RGBColor WHITE
static const RGBColor BLUE
static const RGBColor GREY
static RGBColor fromHSV(double h, double s, double v)
Converts the given hsv-triplet to rgb, inspired by http://alvyray.com/Papers/CG/hsv2rgb....
static const RGBColor DEFAULT_COLOR
The default color (for vehicle types and vehicles).
static const RGBColor RED
named colors
Structure representing possible vehicle parameter.
bool wasSet(long long int what) const
Returns whether the given parameter was set.
RGBColor color
The vehicle's color, TraCI may change this.
static bool isValidVehicleID(const std::string &value)
whether the given string is a valid id for a vehicle or flow
static const std::string format(const std::string &format, T value, Targs... Fargs)
adds a new formatted message
auxiliar struct used for calculate pathStopIndex