67 myCurrentLaneLabel =
new FXLabel(getCollapsableFrame(),
TL(
"No lane selected"), 0,
GUIDesignLabel(JUSTIFY_LEFT));
77 myCurrentLaneLabel->setText(
TL(
"No lane selected"));
79 myCurrentLaneLabel->setText((std::string(
TL(
"Current Lane: ")) + laneID).c_str());
89 myConnectorFrameParent(connectorFrameParent) {
108 if (myConnectorFrameParent->myCurrentEditedLane != 0) {
109 myConnectorFrameParent->getViewNet()->getUndoList()->abortAllChangeGroups();
110 if (myConnectorFrameParent->myNumChanges) {
111 myConnectorFrameParent->getViewNet()->setStatusBarText(
TL(
"Changes reverted"));
113 myConnectorFrameParent->cleanup();
114 myConnectorFrameParent->getViewNet()->updateViewNet();
122 if (myConnectorFrameParent->myCurrentEditedLane != 0) {
124 if (myProtectRoutesCheckBox->isEnabled() && (myProtectRoutesCheckBox->getCheck() == TRUE)) {
125 for (
const auto& demandElement : myConnectorFrameParent->myCurrentEditedLane->getParentEdge()->getChildDemandElements()) {
127 FXMessageBox::warning(getApp(), MBOX_OK,
128 TL(
"Error saving connection operations"),
"%s",
129 (
TLF(
"Connection edition cannot be saved because route '%' is broken.", demandElement->getID()).c_str()));
135 myConnectorFrameParent->getViewNet()->getUndoList()->end();
136 if (myConnectorFrameParent->myNumChanges) {
137 myConnectorFrameParent->getViewNet()->setStatusBarText(
TL(
"Changes accepted"));
139 myConnectorFrameParent->cleanup();
141 myConnectorFrameParent->getViewNet()->getNet()->requireRecompute();
152 myConnectorFrameParent(connectorFrameParent) {
181 std::vector<GNEAttributeCarrier*> deadEnds;
183 for (
const auto& edge : myConnectorFrameParent->getViewNet()->getNet()->getAttributeCarriers()->getEdges()) {
184 for (
const auto& lane : edge.second->getChildLanes()) {
185 if (edge.second->getNBEdge()->getConnectionsFromLane(lane->getIndex()).size() == 0) {
186 deadEnds.push_back(lane);
191 myConnectorFrameParent->getViewNet()->updateViewNet();
199 std::set<GNEAttributeCarrier*> deadStarts;
202 for (
const auto& junction : myConnectorFrameParent->getViewNet()->getNet()->getAttributeCarriers()->getJunctions()) {
204 for (
const auto& outgoingEdge : junction.second->getGNEOutgoingEdges()) {
205 for (
const auto& lane : outgoingEdge->getChildLanes()) {
206 deadStarts.insert(lane);
210 for (
const auto& incomingEdge : junction.second->getGNEIncomingEdges()) {
211 for (
const auto& connection : incomingEdge->getNBEdge()->getConnections()) {
216 std::vector<GNEAttributeCarrier*> selectObjects(deadStarts.begin(), deadStarts.end());
218 myConnectorFrameParent->getViewNet()->updateViewNet();
225 std::vector<GNEAttributeCarrier*> conflicts;
227 for (
const auto& edge : myConnectorFrameParent->getViewNet()->getNet()->getAttributeCarriers()->getEdges()) {
228 const EdgeVector destinations = edge.second->getNBEdge()->getConnectedEdges();
229 for (
const auto& destination : destinations) {
232 const bool isConflicted = count_if(edge.second->getNBEdge()->getConnections().begin(), edge.second->getNBEdge()->getConnections().end(),
235 conflicts.push_back(lane);
242 myConnectorFrameParent->getViewNet()->updateViewNet();
249 std::vector<GNEAttributeCarrier*> pass;
250 for (
const auto& edge : myConnectorFrameParent->getViewNet()->getNet()->getAttributeCarriers()->getEdges()) {
251 for (
const auto& connection : edge.second->getNBEdge()->getConnections()) {
252 if (connection.mayDefinitelyPass) {
253 pass.push_back(edge.second->getChildLanes()[connection.fromLane]);
258 myConnectorFrameParent->getViewNet()->updateViewNet();
265 myConnectorFrameParent->myConnectionModifications->onCmdCancelModifications(0, 0, 0);
266 myConnectorFrameParent->getViewNet()->getUndoList()->begin(
GUIIcon::CONNECTION,
TL(
"clear connections from selected lanes, edges and junctions"));
269 for (
const auto& junction : selectedJunctions) {
270 junction->setLogicValid(
false, myConnectorFrameParent->getViewNet()->getUndoList());
274 const auto selectedEdges = myConnectorFrameParent->getViewNet()->getNet()->getAttributeCarriers()->getSelectedEdges();
275 for (
const auto& edge : selectedEdges) {
276 for (
const auto& lane : edge->getChildLanes()) {
277 myConnectorFrameParent->removeConnections(lane);
281 const auto selectedLanes = myConnectorFrameParent->getViewNet()->getNet()->getAttributeCarriers()->getSelectedLanes();
282 for (
const auto& lane : selectedLanes) {
283 myConnectorFrameParent->removeConnections(lane);
285 myConnectorFrameParent->getViewNet()->getUndoList()->end();
286 myConnectorFrameParent->getViewNet()->updateViewNet();
293 myConnectorFrameParent->myConnectionModifications->onCmdCancelModifications(0, 0, 0);
294 myConnectorFrameParent->getViewNet()->getUndoList()->begin(
GUIIcon::CONNECTION,
TL(
"reset connections from selected lanes"));
295 const auto selectedJunctions = myConnectorFrameParent->getViewNet()->getNet()->getAttributeCarriers()->getSelectedJunctions();
296 for (
const auto& junction : selectedJunctions) {
297 junction->setLogicValid(
false, myConnectorFrameParent->getViewNet()->getUndoList());
299 myConnectorFrameParent->getViewNet()->getUndoList()->end();
300 if (selectedJunctions.size() > 0) {
301 auto viewNet = myConnectorFrameParent->getViewNet();
302 viewNet->getNet()->requireRecompute();
303 viewNet->getNet()->computeNetwork(viewNet->getViewParent()->getGNEAppWindows());
305 myConnectorFrameParent->getViewNet()->updateViewNet();
360 GNEFrame(viewParent, viewNet,
TL(
"Edit Connections")),
388 for (
const auto& lane : viewObjects.
getLanes()) {
390 if (lane->getParentEdge()->isMarkedForDrawingFront()) {
433 bool changed =
false;
455 if (mayDefinitelyPass) {
478 }
else if ((fromPermissions & toPermissions) == 0) {
531 it->setSpecialColor(0);
548 const int toIndex = targetLane->
getIndex();
549 std::vector<NBEdge::Connection>::const_iterator con_it = find_if(
550 connections.begin(), connections.end(),
552 const bool isConnected = con_it != connections.end();
554 if (con_it->mayDefinitelyPass) {
FXDEFMAP(GNEConnectorFrame::ConnectionModifications) ConnectionModificationsMap[]
@ MID_GNE_CONNECTORFRAME_SELECTDEADENDS
select dead end lanes
@ MID_GNE_SET_ATTRIBUTE
attribute edited
@ MID_CANCEL
Cancel-button pressed.
@ MID_CHOOSEN_CLEAR
Clear set.
@ MID_OK
Ok-button pressed.
@ MID_GNE_CONNECTORFRAME_SELECTDEADSTARTS
select lanes that have no connection leading to it
@ MID_GNE_CONNECTORFRAME_SELECTCONFLICTS
select lanes that are connected from concurrent lanes
@ MID_CHOOSEN_RESET
Reset set.
@ MID_GNE_CONNECTORFRAME_SELECTPASS
select lanes with connections that have the pass attribute set to 'true'
#define GUIDesignLabel(justify)
#define GUIDesignCheckButton
checkButton placed in left position
#define GUIDesignLabelFrameInformation
label extended over frame without thick and with text justify to left, used to show information in fr...
std::vector< NBEdge * > EdgeVector
container for (sorted) edges
long long int SVCPermissions
bitset where each bit declares whether a certain SVC may use this edge/lane
@ SVC_PEDESTRIAN
pedestrian
const std::string getID() const
get ID (all Attribute Carriers have one)
GNENet * getNet() const
get pointer to net
static const std::string FEATURE_MODIFIED
feature has been manually modified (implies approval)
NBEdge::Connection & getNBEdgeConnection() const
get Edge::Connection
~ConnectionModifications()
destructor
long onCmdSaveModifications(FXObject *, FXSelector, void *)
Called when the user presses the OK-Button saves any connection modifications.
ConnectionModifications(GNEConnectorFrame *connectorFrameParent)
FOX-declaration.
long onCmdCancelModifications(FXObject *, FXSelector, void *)
Called when the user presses the Cancel-button discards any connection modifications.
FXButton * mySaveButton
"OK" button
FXButton * myCancelButton
"Cancel" button
FXCheckButton * myProtectRoutesCheckBox
protect routes checkbox
~ConnectionOperations()
destructor
FXButton * mySelectDeadStartsButton
"Select Dead Starts" button
FXButton * mySelectConflictsButton
"Select Conflicts" button
long onCmdSelectDeadEnds(FXObject *, FXSelector, void *)
Called when the user presses the select dead ends button.
long onCmdResetSelectedConnections(FXObject *, FXSelector, void *)
Called when the user presses the reset selected connections button.
long onCmdSelectDeadStarts(FXObject *, FXSelector, void *)
Called when the user presses the select dead starts button.
long onCmdSelectPass(FXObject *, FXSelector, void *)
Called when the user presses the select pass button.
FXButton * mySelectDeadEndsButton
"Select Dead Ends" button
long onCmdClearSelectedConnections(FXObject *, FXSelector, void *)
Called when the user presses the clear selected connections button.
FXButton * myClearSelectedButton
"Clear Selected"
long onCmdSelectConflicts(FXObject *, FXSelector, void *)
Called when the user presses the select conflicts button.
ConnectionOperations(GNEConnectorFrame *connectorFrameParent)
FOX-declaration.
FXButton * myResetSelectedButton
"Reset Selected"
FXButton * mySelectPassingButton
"Select Edges which may always pass"
~ConnectionSelection()
destructor
ConnectionSelection(GNEConnectorFrame *connectorFrameParent)
constructor
void updateCurrentLaneLabel(const std::string &laneID)
set current junction label
Legend(GNEConnectorFrame *connectorFrameParent)
constructor
int myNumChanges
number of changes
std::vector< NBEdge::Connection > myDeletedConnections
vector of connections deleted in the current editing step
void cleanup()
clean up when deselecting current lane
void initTargets()
init targets
GNEConnectorFrame(GNEViewParent *viewParent, GNEViewNet *viewNet)
Constructor.
ConnectionModifications * getConnectionModifications() const
get pointer to ConnectionModifications module
GNEConnectorFrame::ConnectionOperations * myConnectionOperations
ConnectionOperations module.
GNEConnectorFrame::Legend * myLegend
Legend module.
void buildConnection(GNELane *lane, const bool mayDefinitelyPass, const bool allowConflict, const bool toggle)
either sets the current lane or toggles the connection of the current lane to this lane (if they shar...
~GNEConnectorFrame()
Destructor.
void removeConnections(GNELane *lane)
remove connections
std::set< GNELane * > myPotentialTargets
the set of lanes to which the current lane may be connected
LaneStatus getLaneStatus(const std::vector< NBEdge::Connection > &connections, const GNELane *targetLane) const
return the status of toLane
GNEConnectorFrame::ConnectionModifications * myConnectionModifications
ConnectionModifications module.
void handleLaneClick(const GNEViewNetHelper::ViewObjectsSelector &viewObjects)
either sets the current lane or toggles the connection of the
GNELane * myCurrentEditedLane
the lane of which connections are to be modified
LaneStatus
the status of a target lane
GNEConnectorFrame::ConnectionSelection * myConnectionSelection
ConnectionSelection module.
CurrentLane * myCurrentLane
CurrentLane module.
A road/street connecting two junctions (netedit-version)
NBEdge * getNBEdge() const
returns the internal NBEdge
GNEJunction * getFromJunction() const
get from Junction (only used to increase readability)
GNEConnection * retrieveGNEConnection(int fromLane, NBEdge *to, int toLane, bool createIfNoExist=true)
get GNEConnection if exist, and if not create it if create is enabled
GNEJunction * getToJunction() const
get from Junction (only used to increase readability)
GNEViewNet * getViewNet() const
get view net
GNEViewNet * myViewNet
FOX need this.
const GNEHierarchicalContainerChildren< GNELane * > & getChildLanes() const
get child lanes
void invalidateTLS(GNEUndoList *undoList, const NBConnection &deletedConnection=NBConnection::InvalidConnection, const NBConnection &addedConnection=NBConnection::InvalidConnection)
NBNode * getNBNode() const
Return net build node.
This lane is powered by an underlying GNEEdge and basically knows how to draw itself.
int getIndex() const
returns the index of the lane
void setSpecialColor(const RGBColor *Color2, double colorValue=std::numeric_limits< double >::max())
GNEEdge * getParentEdge() const
get parent edge
std::vector< GNEJunction * > getSelectedJunctions() const
return selected junctions
GNEEdge * retrieveEdge(const std::string &id, bool hardFail=true) const
get edge by id
A NBNetBuilder extended by visualisation and editing capabilities.
void deleteConnection(GNEConnection *connection, GNEUndoList *undoList)
remove connection
GNENetHelper::AttributeCarriers * getAttributeCarriers() const
get all attribute carriers used in this net
GNEViewNet * getViewNet() const
get view net
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...
void add(GNEChange *command, bool doit=false, bool merge=true)
Add new command, executing it if desired. The new command will be merged with the previous command if...
class used to group all variables related with objects under cursor after a click over view
GNELane * getLaneFrontNonLocked() const
get front lane or a pointer to nullptr checking if is locked
const std::vector< GNELane * > & getLanes() const
get lanes
GNENet * getNet() const
get the net object
const GNEViewNetHelper::MouseButtonKeyPressed & getMouseButtonKeyPressed() const
get Key Pressed module
GNEUndoList * getUndoList() const
get the undoList object
void setStatusBarText(const std::string &text)
set statusBar text
A single child window which contains a view of the simulation area.
static FXButton * buildFXButton(FXComposite *p, const std::string &text, const std::string &tip, const std::string &help, FXIcon *ic, FXObject *tgt, FXSelector sel, FXuint opts=BUTTON_NORMAL, FXint x=0, FXint y=0, FXint w=0, FXint h=0, FXint pl=DEFAULT_PAD, FXint pr=DEFAULT_PAD, FXint pt=DEFAULT_PAD, FXint pb=DEFAULT_PAD)
build button
static FXIcon * getIcon(const GUIIcon which)
returns a icon previously defined in the enum GUIIcon
const GUIVisualizationSettings & getVisualisationSettings() const
get visualization settings (read only)
GUIVisualizationCandidateColorSettings candidateColorSettings
candidate color settings
C++ TraCI client API implementation.
A list item which allows for custom coloring.
MFXGroupBoxModule (based on FXGroupBox)
FXVerticalFrame * getCollapsableFrame()
get collapsable frame (used by all elements that will be collapsed if button is toggled)
static FXColor getFXColor(const RGBColor &col)
converts FXColor to RGBColor
static const NBConnection InvalidConnection
The representation of a single edge during network building.
SVCPermissions getPermissions(int lane=-1) const
get the union of allowed classes over all lanes or for a specific lane
std::vector< Connection > getConnectionsFromLane(int lane, const NBEdge *to=nullptr, int toLane=-1) const
Returns connections from a given lane.
bool hasConnectionTo(const NBEdge *destEdge, int destLane, int fromLane=-1) const
Retrieves info about a connection to a certain lane of a certain edge.
Represents a single node (junction) during network building.
const EdgeVector & getOutgoingEdges() const
Returns this node's outgoing edges (The edges which start at this node)
static const RGBColor WHITE
static const RGBColor special
color for selected special candidate element (Usually selected using shift+click)
static const RGBColor conflict
color for selected conflict candidate element (Usually selected using ctrl+click)
static const RGBColor target
color for selected candidate target
static const RGBColor possible
color for possible candidate element
static const RGBColor source
color for selected candidate source
A structure which describes a connection between edges or lanes.
bool mayDefinitelyPass
Information about being definitely free to drive (on-ramps)
int tlLinkIndex
The index of this connection within the controlling traffic light.