Eclipse SUMO - Simulation of Urban MObility
Loading...
Searching...
No Matches
GNEConnectorFrame.cpp
Go to the documentation of this file.
1/****************************************************************************/
2// Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo
3// Copyright (C) 2011-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// The Widget for modifying lane-to-lane connections
19/****************************************************************************/
20#include <config.h>
21
27#include <netedit/GNEUndoList.h>
28#include <netedit/GNENet.h>
29#include <netedit/GNEViewNet.h>
33
34
35// ===========================================================================
36// FOX callback mapping
37// ===========================================================================
38
43
52
53// Object implementation
54FXIMPLEMENT(GNEConnectorFrame::ConnectionModifications, MFXGroupBoxModule, ConnectionModificationsMap, ARRAYNUMBER(ConnectionModificationsMap))
55FXIMPLEMENT(GNEConnectorFrame::ConnectionOperations, MFXGroupBoxModule, ConnectionOperationsMap, ARRAYNUMBER(ConnectionOperationsMap))
56
57
58// ===========================================================================
59// method definitions
60// ===========================================================================
61
62// ---------------------------------------------------------------------------
63// GNEConnectorFrame::CurrentLane - methods
64// ---------------------------------------------------------------------------
65
67 MFXGroupBoxModule(connectorFrameParent, TL("Lane")) {
68 // create lane label
69 myCurrentLaneLabel = new FXLabel(getCollapsableFrame(), TL("No lane selected"), 0, GUIDesignLabel(JUSTIFY_LEFT));
70}
71
72
74
75
76void
78 if (laneID.empty()) {
79 myCurrentLaneLabel->setText(TL("No lane selected"));
80 } else {
81 myCurrentLaneLabel->setText((std::string(TL("Current Lane: ")) + laneID).c_str());
82 }
83}
84
85// ---------------------------------------------------------------------------
86// GNEConnectorFrame::ConnectionModifications - methods
87// ---------------------------------------------------------------------------
88
90 MFXGroupBoxModule(connectorFrameParent, TL("Modifications")),
91 myConnectorFrameParent(connectorFrameParent) {
92
93 // Create "Cancel" button
94 myCancelButton = GUIDesigns::buildFXButton(getCollapsableFrame(), TL("Cancel"), "", TL("Discard connection modifications (Esc)"),
96 // Create "OK" button
97 mySaveButton = GUIDesigns::buildFXButton(getCollapsableFrame(), TL("OK"), "", TL("Save connection modifications (Enter)"),
99
100 // Create checkbox for protect routes
101 myProtectRoutesCheckBox = new FXCheckButton(getCollapsableFrame(), TL("Protect routes"), this, MID_GNE_SET_ATTRIBUTE, GUIDesignCheckButton);
102}
103
104
106
107
108long
110 if (myConnectorFrameParent->myCurrentEditedLane != 0) {
111 myConnectorFrameParent->getViewNet()->getUndoList()->abortAllChangeGroups();
112 if (myConnectorFrameParent->myNumChanges) {
113 myConnectorFrameParent->getViewNet()->setStatusBarText(TL("Changes reverted"));
114 }
115 myConnectorFrameParent->cleanup();
116 myConnectorFrameParent->getViewNet()->updateViewNet();
117 }
118 return 1;
119}
120
121
122long
124 if (myConnectorFrameParent->myCurrentEditedLane != 0) {
125 // check if routes has to be protected
126 if (myProtectRoutesCheckBox->isEnabled() && (myProtectRoutesCheckBox->getCheck() == TRUE)) {
127 for (const auto& demandElement : myConnectorFrameParent->myCurrentEditedLane->getParentEdge()->getChildDemandElements()) {
128 if (demandElement->isDemandElementValid() != GNEDemandElement::Problem::OK) {
129 FXMessageBox::warning(getApp(), MBOX_OK,
130 TL("Error saving connection operations"), "%s",
131 (TLF("Connection edition cannot be saved because route '%' is broken.", demandElement->getID()).c_str()));
132 return 1;
133 }
134 }
135 }
136 // finish route editing
137 myConnectorFrameParent->getViewNet()->getUndoList()->end();
138 if (myConnectorFrameParent->myNumChanges) {
139 myConnectorFrameParent->getViewNet()->setStatusBarText(TL("Changes accepted"));
140 }
141 myConnectorFrameParent->cleanup();
142 // mark network for recomputing
143 myConnectorFrameParent->getViewNet()->getNet()->requireRecompute();
144 }
145 return 1;
146}
147
148// ---------------------------------------------------------------------------
149// GNEConnectorFrame::ConnectionOperations - methods
150// ---------------------------------------------------------------------------
151
153 MFXGroupBoxModule(connectorFrameParent, TL("Operations")),
154 myConnectorFrameParent(connectorFrameParent) {
155
156 // Create "Select Dead Ends" button
157 mySelectDeadEndsButton = GUIDesigns::buildFXButton(getCollapsableFrame(), TL("Select Dead Ends"), "", TL("Selects all lanes that have no outgoing connection (clears previous selection)"),
159 // Create "Select Dead Starts" button
160 mySelectDeadStartsButton = GUIDesigns::buildFXButton(getCollapsableFrame(), TL("Select Dead Starts"), "", TL("Selects all lanes that have no incoming connection (clears previous selection)"),
162 // Create "Select Conflicts" button
163 mySelectConflictsButton = GUIDesigns::buildFXButton(getCollapsableFrame(), TL("Select Conflicts"), "", TL("Selects all lanes with more than one incoming connection from the same edge (clears previous selection)"),
165 // Create "Select Edges which may always pass" button
166 mySelectPassingButton = GUIDesigns::buildFXButton(getCollapsableFrame(), TL("Select Passing"), "", TL("Selects all lanes with a connection that has the 'pass' attribute set"),
168 // Create "Clear Selected" button
169 myClearSelectedButton = GUIDesigns::buildFXButton(getCollapsableFrame(), TL("Clear Selected"), "", TL("Clears all connections of all selected objects"),
171 // Create "Reset Selected" button
172 myResetSelectedButton = GUIDesigns::buildFXButton(getCollapsableFrame(), TL("Reset Selected"), "", TL("Recomputes connections at all selected junctions"),
174}
175
176
178
179
180long
182 // select all lanes that have no successor lane
183 std::vector<GNEAttributeCarrier*> deadEnds;
184 // every edge knows its outgoing connections so we can look at each edge in isolation
185 for (const auto& edge : myConnectorFrameParent->getViewNet()->getNet()->getAttributeCarriers()->getEdges()) {
186 for (const auto& lane : edge.second->getLanes()) {
187 if (edge.second->getNBEdge()->getConnectionsFromLane(lane->getIndex()).size() == 0) {
188 deadEnds.push_back(lane);
189 }
190 }
191 }
192 myConnectorFrameParent->getViewNet()->getViewParent()->getSelectorFrame()->handleIDs(deadEnds, GNESelectorFrame::ModificationMode::Operation::REPLACE);
193 return 1;
194}
195
196
197long
199 // select all lanes that have no predecessor lane
200 std::set<GNEAttributeCarrier*> deadStarts;
201 GNENet* net = myConnectorFrameParent->getViewNet()->getNet();
202 // every edge knows only its outgoing connections so we look at whole junctions
203 for (const auto& junction : myConnectorFrameParent->getViewNet()->getNet()->getAttributeCarriers()->getJunctions()) {
204 // first collect all outgoing lanes
205 for (const auto& outgoingEdge : junction.second->getGNEOutgoingEdges()) {
206 for (const auto& lane : outgoingEdge->getLanes()) {
207 deadStarts.insert(lane);
208 }
209 }
210 // then remove all approached lanes
211 for (const auto& incomingEdge : junction.second->getGNEIncomingEdges()) {
212 for (const auto& connection : incomingEdge->getNBEdge()->getConnections()) {
213 deadStarts.erase(net->getAttributeCarriers()->retrieveEdge(connection.toEdge->getID())->getLanes()[connection.toLane]);
214 }
215 }
216 }
217 std::vector<GNEAttributeCarrier*> selectObjects(deadStarts.begin(), deadStarts.end());
218 myConnectorFrameParent->getViewNet()->getViewParent()->getSelectorFrame()->handleIDs(selectObjects, GNESelectorFrame::ModificationMode::Operation::REPLACE);
219 return 1;
220}
221
222
223long
225 std::vector<GNEAttributeCarrier*> conflicts;
226 // conflicts happen per edge so we can look at each edge in isolation
227 for (const auto& edge : myConnectorFrameParent->getViewNet()->getNet()->getAttributeCarriers()->getEdges()) {
228 const EdgeVector destinations = edge.second->getNBEdge()->getConnectedEdges();
229 for (const auto& destination : destinations) {
230 GNEEdge* dest = myConnectorFrameParent->getViewNet()->getNet()->getAttributeCarriers()->retrieveEdge(destination->getID());
231 for (const auto& lane : dest->getLanes()) {
232 const bool isConflicted = count_if(edge.second->getNBEdge()->getConnections().begin(), edge.second->getNBEdge()->getConnections().end(),
233 NBEdge::connections_toedgelane_finder(destination, (int)lane->getIndex(), -1)) > 1;
234 if (isConflicted) {
235 conflicts.push_back(lane);
236 }
237 }
238 }
239
240 }
241 myConnectorFrameParent->getViewNet()->getViewParent()->getSelectorFrame()->handleIDs(conflicts, GNESelectorFrame::ModificationMode::Operation::REPLACE);
242 return 1;
243}
244
245
246long
248 std::vector<GNEAttributeCarrier*> pass;
249 for (const auto& edge : myConnectorFrameParent->getViewNet()->getNet()->getAttributeCarriers()->getEdges()) {
250 for (const auto& connection : edge.second->getNBEdge()->getConnections()) {
251 if (connection.mayDefinitelyPass) {
252 pass.push_back(edge.second->getLanes()[connection.fromLane]);
253 }
254 }
255 }
256 myConnectorFrameParent->getViewNet()->getViewParent()->getSelectorFrame()->handleIDs(pass, GNESelectorFrame::ModificationMode::Operation::REPLACE);
257 return 1;
258}
259
260
261long
263 myConnectorFrameParent->myConnectionModifications->onCmdCancelModifications(0, 0, 0);
264 myConnectorFrameParent->getViewNet()->getUndoList()->begin(GUIIcon::CONNECTION, TL("clear connections from selected lanes, edges and junctions"));
265 // clear junction's connection
266 const auto selectedJunctions = myConnectorFrameParent->getViewNet()->getNet()->getAttributeCarriers()->getSelectedJunctions();
267 for (const auto& junction : selectedJunctions) {
268 junction->setLogicValid(false, myConnectorFrameParent->getViewNet()->getUndoList()); // clear connections
269 junction->setLogicValid(false, myConnectorFrameParent->getViewNet()->getUndoList(), GNEAttributeCarrier::FEATURE_MODIFIED); // prevent re-guessing
270 }
271 // clear edge's connection
272 const auto selectedEdges = myConnectorFrameParent->getViewNet()->getNet()->getAttributeCarriers()->getSelectedEdges();
273 for (const auto& edge : selectedEdges) {
274 for (const auto& lane : edge->getLanes()) {
275 myConnectorFrameParent->removeConnections(lane);
276 }
277 }
278 // clear lane's connection
279 const auto selectedLanes = myConnectorFrameParent->getViewNet()->getNet()->getAttributeCarriers()->getSelectedLanes();
280 for (const auto& lane : selectedLanes) {
281 myConnectorFrameParent->removeConnections(lane);
282 }
283 myConnectorFrameParent->getViewNet()->getUndoList()->end();
284 return 1;
285}
286
287
288long
290 myConnectorFrameParent->myConnectionModifications->onCmdCancelModifications(0, 0, 0);
291 myConnectorFrameParent->getViewNet()->getUndoList()->begin(GUIIcon::CONNECTION, TL("reset connections from selected lanes"));
292 const auto selectedJunctions = myConnectorFrameParent->getViewNet()->getNet()->getAttributeCarriers()->getSelectedJunctions();
293 for (const auto& junction : selectedJunctions) {
294 junction->setLogicValid(false, myConnectorFrameParent->getViewNet()->getUndoList());
295 }
296 myConnectorFrameParent->getViewNet()->getUndoList()->end();
297 if (selectedJunctions.size() > 0) {
298 auto viewNet = myConnectorFrameParent->getViewNet();
299 viewNet->getNet()->requireRecompute();
300 viewNet->getNet()->computeNetwork(viewNet->getViewParent()->getGNEAppWindows());
301 }
302 return 1;
303}
304
305// ---------------------------------------------------------------------------
306// GNEConnectorFrame::ConnectionSelection - methods
307// ---------------------------------------------------------------------------
308
310 MFXGroupBoxModule(connectorFrameParent, TL("Selection")) {
311 // create label
312 new MFXDynamicLabel(getCollapsableFrame(), (std::string("- ") + TL("Hold <SHIFT> while clicking to create unyielding connections (pass=true).")).c_str(), 0, GUIDesignLabelFrameInformation);
313 new MFXDynamicLabel(getCollapsableFrame(), (std::string("- ") + TL("Hold <CTRL> while clicking to create conflicting connections (i.e. at zipper nodes or with incompatible permissions)")).c_str(), 0, GUIDesignLabelFrameInformation);
314}
315
316
318
319// ---------------------------------------------------------------------------
320// GNEConnectorFrame::ConnectionLegend - methods
321// ---------------------------------------------------------------------------
322
324 MFXGroupBoxModule(connectorFrameParent, TL("Information")) {
325
326 // create possible target label
327 FXLabel* possibleTargetLabel = new FXLabel(getCollapsableFrame(), TL("Possible Target"), 0, GUIDesignLabel(JUSTIFY_LEFT));
328 possibleTargetLabel->setBackColor(MFXUtils::getFXColor(connectorFrameParent->getViewNet()->getVisualisationSettings().candidateColorSettings.possible));
329 possibleTargetLabel->setTextColor(MFXUtils::getFXColor(RGBColor::WHITE));
330
331 // create source label
332 FXLabel* sourceLabel = new FXLabel(getCollapsableFrame(), TL("Source lane"), 0, GUIDesignLabel(JUSTIFY_LEFT));
333 sourceLabel->setBackColor(MFXUtils::getFXColor(connectorFrameParent->getViewNet()->getVisualisationSettings().candidateColorSettings.source));
334
335 // create target label
336 FXLabel* targetLabel = new FXLabel(getCollapsableFrame(), TL("Target lane"), 0, GUIDesignLabel(JUSTIFY_LEFT));
337 targetLabel->setBackColor(MFXUtils::getFXColor(connectorFrameParent->getViewNet()->getVisualisationSettings().candidateColorSettings.target));
338
339 // create target (pass) label
340 FXLabel* targetPassLabel = new FXLabel(getCollapsableFrame(), TL("Target (pass)"), 0, GUIDesignLabel(JUSTIFY_LEFT));
341 targetPassLabel->setBackColor(MFXUtils::getFXColor(connectorFrameParent->getViewNet()->getVisualisationSettings().candidateColorSettings.special));
342
343 // create conflict label
344 FXLabel* conflictLabel = new FXLabel(getCollapsableFrame(), TL("Conflict"), 0, GUIDesignLabel(JUSTIFY_LEFT));
345 conflictLabel->setBackColor(MFXUtils::getFXColor(connectorFrameParent->getViewNet()->getVisualisationSettings().candidateColorSettings.conflict));
346}
347
348
350
351// ---------------------------------------------------------------------------
352// GNEConnectorFrame - methods
353// ---------------------------------------------------------------------------
354
356 GNEFrame(viewParent, viewNet, TL("Edit Connections")),
358 myNumChanges(0) {
359 // create current lane module
360 myCurrentLane = new CurrentLane(this);
361
362 // create connection modifications module
364
365 // create connection operations module
367
368 // create connection selection module
370
371 // create connection legend module
372 myLegend = new Legend(this);
373}
374
375
377
378
379void
381 // get lane front
382 GNELane* clickedLane = viewObjects.getLaneFrontNonLocked();
383 // iterate over lanes
384 for (const auto& lane : viewObjects.getLanes()) {
385 // if parent edge of lane is front element, update clickedLane
386 if (lane->getParentEdge()->isMarkedForDrawingFront()) {
387 clickedLane = lane;
388 }
389 }
390 // build connection
392}
393
394
399
400
401void
403 // select lane as current lane
404 buildConnection(lane, false, false, true); // select as current lane
405 // iterate over all potential targets
406 for (const auto& potentialTarget : myPotentialTargets) {
407 // remove connections using the appropiate parameters in function "buildConnection"
408 buildConnection(potentialTarget, false, false, false);
409 }
410 // save modifications
412}
413
414
415void
416GNEConnectorFrame::buildConnection(GNELane* lane, const bool mayDefinitelyPass, const bool allowConflict, const bool toggle) {
417 if (myCurrentEditedLane == 0) {
418 myCurrentEditedLane = lane;
420 initTargets();
421 myNumChanges = 0;
422 myViewNet->getUndoList()->begin(GUIIcon::CONNECTION, TL("modify connections"));
423 } else if (myPotentialTargets.count(lane)
424 || (allowConflict && lane->getParentEdge()->getFromJunction() == myCurrentEditedLane->getParentEdge()->getToJunction())) {
425 const int fromIndex = myCurrentEditedLane->getIndex();
427 GNEEdge* destEdge = lane->getParentEdge();
428 std::vector<NBEdge::Connection> connections = srcEdge->getNBEdge()->getConnectionsFromLane(fromIndex);
429 bool changed = false;
430 // get lane status
431 LaneStatus status = getLaneStatus(connections, lane);
432 if (status == LaneStatus::CONFLICTED && allowConflict) {
434 }
435 // create depending of status
436 switch (status) {
438 if (toggle) {
439 // create new connection
440 NBEdge::Connection newCon(fromIndex, destEdge->getNBEdge(), lane->getIndex(), mayDefinitelyPass);
441 // if the connection was previously deleted (by clicking the same lane twice), restore all values
443 // fromLane must be the same, only check toLane
444 if (c.toEdge == destEdge->getNBEdge() && c.toLane == lane->getIndex()) {
445 newCon = c;
446 newCon.mayDefinitelyPass = mayDefinitelyPass;
447 }
448 }
449 NBConnection newNBCon(srcEdge->getNBEdge(), fromIndex, destEdge->getNBEdge(), lane->getIndex(), newCon.tlLinkIndex);
450 myViewNet->getUndoList()->add(new GNEChange_Connection(srcEdge, newCon, false, true), true);
451 if (mayDefinitelyPass) {
453 } else {
455 }
457 }
458 break;
461 // remove connection
462 GNEConnection* con = srcEdge->retrieveGNEConnection(fromIndex, destEdge->getNBEdge(), lane->getIndex());
466 changed = true;
467 break;
468 }
470 SVCPermissions fromPermissions = srcEdge->getNBEdge()->getPermissions(fromIndex);
471 SVCPermissions toPermissions = destEdge->getNBEdge()->getPermissions(lane->getIndex());
472 if ((fromPermissions & toPermissions) == SVC_PEDESTRIAN) {
473 myViewNet->setStatusBarText(TL("Pedestrian connections are generated automatically"));
474 } else if ((fromPermissions & toPermissions) == 0) {
475 myViewNet->setStatusBarText(TL("Incompatible vehicle class permissions"));
476 } else {
477 myViewNet->setStatusBarText(TL("Another lane from the same edge already connects to that lane"));
478 }
479 break;
480 }
481 if (changed) {
482 myNumChanges += 1;
483 }
484 } else {
485 myViewNet->setStatusBarText(TL("Invalid target for connection"));
486 }
488}
489
490
491void
493 // gather potential targets
495 // get potential targets
496 for (const auto& NBEEdge : nbn->getOutgoingEdges()) {
497 GNEEdge* edge = myViewNet->getNet()->getAttributeCarriers()->retrieveEdge(NBEEdge->getID());
498 for (const auto& lane : edge->getLanes()) {
499 myPotentialTargets.insert(lane);
500 }
501 }
502 // set color for existing connections
503 std::vector<NBEdge::Connection> connections = myCurrentEditedLane->getParentEdge()->getNBEdge()->getConnectionsFromLane(myCurrentEditedLane->getIndex());
504 for (const auto& lane : myPotentialTargets) {
505 switch (getLaneStatus(connections, lane)) {
508 break;
511 break;
514 break;
517 break;
518 }
519 }
520}
521
522
523void
525 // restore colors of potential targets
526 for (auto it : myPotentialTargets) {
527 it->setSpecialColor(0);
528 }
529 // clear attributes
530 myPotentialTargets.clear();
531 myNumChanges = 0;
533 myCurrentEditedLane = nullptr;
534 myDeletedConnections.clear();
536}
537
538
540GNEConnectorFrame::getLaneStatus(const std::vector<NBEdge::Connection>& connections, const GNELane* targetLane) const {
542 const int fromIndex = myCurrentEditedLane->getIndex();
543 NBEdge* destEdge = targetLane->getParentEdge()->getNBEdge();
544 const int toIndex = targetLane->getIndex();
545 std::vector<NBEdge::Connection>::const_iterator con_it = find_if(
546 connections.begin(), connections.end(),
547 NBEdge::connections_finder(fromIndex, destEdge, toIndex));
548 const bool isConnected = con_it != connections.end();
549 if (isConnected) {
550 if (con_it->mayDefinitelyPass) {
552 } else {
554 }
555 } else if (srcEdge->hasConnectionTo(destEdge, toIndex)
556 || (srcEdge->getPermissions(fromIndex) & destEdge->getPermissions(toIndex) & ~SVC_PEDESTRIAN) == 0) {
558 } else {
560 }
561}
562
563
564/****************************************************************************/
FXDEFMAP(GNEConnectorFrame::ConnectionModifications) ConnectionModificationsMap[]
@ MID_GNE_CONNECTORFRAME_SELECTDEADENDS
select dead end lanes
@ MID_GNE_SET_ATTRIBUTE
attribute edited
Definition GUIAppEnum.h:939
@ MID_CANCEL
Cancel-button pressed.
Definition GUIAppEnum.h:308
@ MID_CHOOSEN_CLEAR
Clear set.
Definition GUIAppEnum.h:605
@ MID_OK
Ok-button pressed.
Definition GUIAppEnum.h:306
@ 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.
Definition GUIAppEnum.h:609
@ MID_GNE_CONNECTORFRAME_SELECTPASS
select lanes with connections that have the pass attribute set to 'true'
#define GUIDesignButton
Definition GUIDesigns.h:82
#define GUIDesignLabel(justify)
Definition GUIDesigns.h:243
#define GUIDesignCheckButton
checkButton placed in left position
Definition GUIDesigns.h:192
#define GUIDesignLabelFrameInformation
label extended over frame without thick and with text justify to left, used to show information in fr...
Definition GUIDesigns.h:279
#define TL(string)
Definition MsgHandler.h:315
#define TLF(string,...)
Definition MsgHandler.h:317
std::vector< NBEdge * > EdgeVector
container for (sorted) edges
Definition NBCont.h:42
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
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.
FXCheckButton * myProtectRoutesCheckBox
protect routes checkbox
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(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)
Definition GNEEdge.h:53
NBEdge * getNBEdge() const
returns the internal NBEdge
Definition GNEEdge.cpp:781
const std::vector< GNELane * > & getLanes() const
returns a reference to the lane vector
Definition GNEEdge.cpp:1118
GNEJunction * getFromJunction() const
get from Junction (only used to increase readability)
Definition GNEEdge.h:77
GNEConnection * retrieveGNEConnection(int fromLane, NBEdge *to, int toLane, bool createIfNoExist=true)
get GNEConnection if exist, and if not create it if create is enabled
Definition GNEEdge.cpp:2293
GNEJunction * getToJunction() const
get from Junction (only used to increase readability)
Definition GNEEdge.h:82
GNEViewNet * getViewNet() const
get view net
Definition GNEFrame.cpp:150
GNEViewNet * myViewNet
FOX need this.
Definition GNEFrame.h:115
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.
Definition GNELane.h:46
int getIndex() const
returns the index of the lane
Definition GNELane.cpp:620
void setSpecialColor(const RGBColor *Color2, double colorValue=std::numeric_limits< double >::max())
Definition GNELane.cpp:882
GNEEdge * getParentEdge() const
get parent edge
Definition GNELane.cpp:196
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.
Definition GNENet.h:42
void deleteConnection(GNEConnection *connection, GNEUndoList *undoList)
remove connection
Definition GNENet.cpp:643
GNENetHelper::AttributeCarriers * getAttributeCarriers() const
get all attribute carriers used in this net
Definition GNENet.cpp:127
GNEViewNet * getViewNet() const
get view net
Definition GNENet.cpp:2163
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
Definition MFXUtils.cpp:112
static const NBConnection InvalidConnection
The representation of a single edge during network building.
Definition NBEdge.h:92
SVCPermissions getPermissions(int lane=-1) const
get the union of allowed classes over all lanes or for a specific lane
Definition NBEdge.cpp:4379
std::vector< Connection > getConnectionsFromLane(int lane, const NBEdge *to=nullptr, int toLane=-1) const
Returns connections from a given lane.
Definition NBEdge.cpp:1287
bool hasConnectionTo(const NBEdge *destEdge, int destLane, int fromLane=-1) const
Retrieves info about a connection to a certain lane of a certain edge.
Definition NBEdge.cpp:1325
Represents a single node (junction) during network building.
Definition NBNode.h:66
const EdgeVector & getOutgoingEdges() const
Returns this node's outgoing edges (The edges which start at this node)
Definition NBNode.h:273
static const RGBColor WHITE
Definition RGBColor.h:192
bool shiftKeyPressed() const
check if SHIFT is pressed during current event
bool controlKeyPressed() const
check if CONTROL is pressed during current event
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.
Definition NBEdge.h:201
bool mayDefinitelyPass
Information about being definitely free to drive (on-ramps)
Definition NBEdge.h:228
int tlLinkIndex
The index of this connection within the controlling traffic light.
Definition NBEdge.h:222