Eclipse SUMO - Simulation of Urban MObility
Loading...
Searching...
No Matches
GNEMoveElementLane.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-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// Class used for moving lane shapes
19/****************************************************************************/
20#include <config.h>
21
23#include <netedit/GNENet.h>
24#include <netedit/GNEUndoList.h>
25
26#include "GNEMoveElementLane.h"
27
28// ===========================================================================
29// Method definitions
30// ===========================================================================
31
36
37
39
40
43 // edit depending if shape is being edited
44 if (myLane->isShapeEdited()) {
45 // calculate move shape operation
46 return getEditShapeOperation(myLane, myLane->getLaneShape(), false);
47 } else {
48 return nullptr;
49 }
50}
51
52
53std::string
55 return myMovedElement->getCommonAttribute(key);
56}
57
58
59double
61 return myMovedElement->getCommonAttributeDouble(key);
62}
63
64
67 return myMovedElement->getCommonAttributePosition(key);
68}
69
70
73 return myMovedElement->getCommonAttributePositionVector(key);
74}
75
76
77void
79 myMovedElement->setCommonAttribute(key, value, undoList);
80}
81
82
83bool
85 return myMovedElement->isCommonAttributeValid(key, value);
86}
87
88
89void
91 myMovedElement->setCommonAttribute(key, value);
92}
93
94
95void
97 // edit depending if shape is being edited
98 if (myLane->isShapeEdited()) {
99 // get original shape
100 PositionVector shape = myLane->getLaneShape();
101 // check shape size
102 if (shape.size() > 2) {
103 // obtain index
104 int index = shape.indexOfClosest(clickedPosition);
105 // get snap radius
106 const double snap_radius = myLane->getNet()->getViewNet()->getVisualisationSettings().neteditSizeSettings.laneGeometryPointRadius;
107 // check if we have to create a new index
108 if ((index != -1) && shape[index].distanceSquaredTo2D(clickedPosition) < (snap_radius * snap_radius)) {
109 // remove geometry point
110 shape.erase(shape.begin() + index);
111 // commit new shape
112 undoList->begin(myLane, TLF("remove geometry point of %", myLane->getTagStr()));
114 undoList->end();
115 }
116 }
117 }
118}
119
120
121void
123 // set custom shape
124 myLane->getParentEdges().front()->getNBEdge()->getLaneStruct(myLane->getIndex()).customShape = moveResult.shapeToUpdate;
125 // update geometry
126 myLane->updateGeometry();
127}
128
129
130void
132 // commit new shape
133 undoList->begin(myLane, TLF("moving custom shape of %", myLane->getTagStr()));
135 undoList->end();
136}
137
138/****************************************************************************/
#define TLF(string,...)
Definition MsgHandler.h:306
const std::string invalid_return< std::string >::value
SumoXMLAttr
Numbers representing SUMO-XML - attributes.
@ SUMO_ATTR_CUSTOMSHAPE
whether a given shape is user-defined
std::string toString(const T &t, std::streamsize accuracy=gPrecision)
Definition ToString.h:46
static void changeAttribute(GNEAttributeCarrier *AC, SumoXMLAttr key, const std::string &value, GNEUndoList *undoList, const bool force=false)
change attribute
GNEAttributeCarrier * myMovedElement
pointer to element
GNEMoveElement(GNEAttributeCarrier *movedElement)
constructor
GNEMoveOperation * getEditShapeOperation(const GUIGlObject *obj, const PositionVector originalShape, const bool maintainShapeClosed)
calculate move shape operation
std::string getMovingAttribute(SumoXMLAttr key) const override
get moving attribute
void removeGeometryPoint(const Position clickedPosition, GNEUndoList *undoList) override
remove geometry point in the clicked position
double getMovingAttributeDouble(SumoXMLAttr key) const override
get moving attribute double
Position getMovingAttributePosition(SumoXMLAttr key) const override
get moving attribute position
bool isMovingAttributeValid(SumoXMLAttr key, const std::string &value) const override
check if the given moving attribute is valid
GNEMoveElementLane()=delete
invalidate default constructor
GNELane * myLane
pointer to lane
void setMoveShape(const GNEMoveResult &moveResult) override
set move shape
GNEMoveOperation * getMoveOperation() override
get move operation
void commitMoveShape(const GNEMoveResult &moveResult, GNEUndoList *undoList) override
commit move shape
PositionVector getMovingAttributePositionVector(SumoXMLAttr key) const override
get moving attribute positionVector
void setMovingAttribute(SumoXMLAttr key, const std::string &value, GNEUndoList *undoList) override
set moving attribute (using undo-list)
PositionVector shapeToUpdate
shape to update (edited in moveElement)
void end()
End undo command sub-group. If the sub-group is still empty, it will be deleted; otherwise,...
void begin(GUIIcon icon, const std::string &description)
Begin undo command sub-group with current supermode. This begins a new group of commands that are tre...
A point in 2D or 3D with translation and scaling methods.
Definition Position.h:37
A list of positions.
int indexOfClosest(const Position &p, bool twoD=false) const