69 #ifdef CHECK_MEMORY_LEAKS 71 #endif // CHECK_MEMORY_LEAKS 93 GUINet& net, FXGLVisual* glVis,
108 for (std::vector<std::string>::const_iterator i = names.begin(); i != names.end(); ++i) {
118 "\tLocate Junction\tLocate a junction within the network.",
120 ICON_ABOVE_TEXT | FRAME_THICK | FRAME_RAISED);
123 "\tLocate Street\tLocate a street within the network.",
125 ICON_ABOVE_TEXT | FRAME_THICK | FRAME_RAISED);
129 "\tLocate Vehicle\tLocate a vehicle within the network.",
131 ICON_ABOVE_TEXT | FRAME_THICK | FRAME_RAISED);
136 "\tLocate Vehicle\tLocate a person within the network.",
138 ICON_ABOVE_TEXT | FRAME_THICK | FRAME_RAISED);
143 "\tLocate TLS\tLocate a tls within the network.",
145 ICON_ABOVE_TEXT | FRAME_THICK | FRAME_RAISED);
148 "\tLocate Additional\tLocate an additional structure within the network.",
150 ICON_ABOVE_TEXT | FRAME_THICK | FRAME_RAISED);
153 "\tLocate PoI\tLocate a PoI within the network.",
155 ICON_ABOVE_TEXT | FRAME_THICK | FRAME_RAISED);
158 "\tLocate Polygon\tLocate a Polygon within the network.",
160 ICON_ABOVE_TEXT | FRAME_THICK | FRAME_RAISED);
185 glMatrixMode(GL_MODELVIEW);
187 glDisable(GL_TEXTURE_2D);
188 glDisable(GL_ALPHA_TEST);
190 glEnable(GL_DEPTH_TEST);
201 glPolygonMode(GL_FRONT_AND_BACK, GL_FILL);
204 minB[0] = bound.
xmin();
205 minB[1] = bound.
ymin();
206 maxB[0] = bound.
xmax();
207 maxB[1] = bound.
ymax();
209 glEnable(GL_POLYGON_OFFSET_FILL);
210 glEnable(GL_POLYGON_OFFSET_LINE);
214 glTranslated(0, 0, -.01);
220 glTranslated(0, 0, .01);
257 const std::vector<MSTrafficLightLogic*>& logics = tlsControl.
getAllLogics();
259 SUMOReal minDist = std::numeric_limits<SUMOReal>::infinity();
260 for (std::vector<MSTrafficLightLogic*>::const_iterator i = logics.begin(); i != logics.end(); ++i) {
266 if (lanes.size() > 0) {
267 const Position& endPos = lanes[0]->getShape().back();
277 const std::vector<MSTrafficLightLogic*> logics = vars.
getAllLogics();
278 if (logics.size() > 1) {
280 for (
unsigned int i = 0; i < logics.size() - 1; ++i) {
281 if (minTll->
getProgramID() == logics[i]->getProgramID()) {
286 if (l == logics[0]) {
309 return dynamic_cast<GUILane*
>(o);
void paintGLGrid()
paints a grid
void changeStepAndDuration(MSTLLogicControl &tlcontrol, SUMOTime simStep, unsigned int step, SUMOTime stepDuration)
Changes the current phase and her duration.
bool isActive(const MSTrafficLightLogic *tl) const
Returns whether the given tls program is the currently active for his tls.
virtual void buildViewToolBars(GUIGlChildWindow &)
builds the view toolbars
MSEdge & getEdge() const
Returns the lane's edge.
GUICompleteSchemeStorage gSchemeStorage
long onCmdCloseLane(FXObject *, FXSelector, void *)
interaction with the simulation
const SUMOReal SUMO_const_laneWidth
Storage for all programs of a single tls.
bool setColorScheme(const std::string &name)
void unlock()
release exclusive access to the simulation state
SUMORTree * myGrid
The visualization speed-up.
void switchTo(const std::string &id, const std::string &programID)
Switches the named (id) tls to the named (programID) program.
void closeTraffic(bool rebuildAllowed=true)
close this lane for traffic
bool gaming
whether the application is in gaming mode or not
SUMOTime getCurrentTimeStep() const
get the current simulation time
SUMOReal ymin() const
Returns minimum y-coordinate.
GUIMainWindow * myApp
The application.
SUMOReal xmin() const
Returns minimum x-coordinate.
static MSNet * getInstance()
Returns the pointer to the unique instance of MSNet (singleton).
void lock()
grant exclusive access to the simulation state
SUMOReal distanceTo(const Position &p2) const
returns the euclidean distance in 3 dimension
GUIDialog_ViewSettings * myVisualizationChanger
SUMOTime getCurrentTimeStep() const
Returns the current simulation step.
bool isGaming() const
return whether the gui is in gaming mode
GUIGlID getGlID() const
Returns the numerical id of the object.
SUMOReal xmax() const
Returns maximum x-coordinate.
A class that stores a 2D geometrical boundary.
A fixed traffic light logic.
SUMOReal scale
information about a lane's width (temporary, used for a single view)
Representation of a lane in the micro simulation (gui-version)
A class that stores and controls tls and switching of their programs.
std::vector< MSTrafficLightLogic * > getAllLogics() const
Locate addtional structure - button.
A road/street connecting two junctions (gui-version)
const std::string & getID() const
Returns the id.
SUMOTime duration
The duration of the phase.
const std::vector< std::string > & getNames() const
Returns a list of stored settings names.
int getTrackedID() const
Returns the id of the tracked vehicle (-1 if none)
std::string name
The name of this setting.
std::map< GUIGlObject *, int > myAdditionallyDrawn
List of objects for which GUIGlObject::drawGLAdditional is called.
void setCurrentScheme(const std::string &)
Sets the named scheme as the current.
static GUINet * getGUIInstance()
Returns the pointer to the unique instance of GUINet (singleton).
A point in 2D or 3D with translation and scaling methods.
long onCmdAddRerouter(FXObject *, FXSelector, void *)
MSTLLogicControl & getTLSControl()
Returns the tls logics control.
long onCmdCloseEdge(FXObject *, FXSelector, void *)
FXComboBox & getColoringSchemesCombo()
const LaneVector & getLanesAt(unsigned int i) const
Returns the list of lanes that are controlled by the signals at the given position.
bool contains(const std::string &name) const
Returns the information whether a setting with the given name is stored.
static GUIGlObjectStorage gIDStorage
A single static instance of this class.
GUIVisualizationSettings & get(const std::string &name)
Returns the named scheme.
const MSPhaseDefinition & getPhase(unsigned int givenstep) const
Returns the definition of the phase from the given position within the plan.
void onGamingClick(Position pos)
handle mouse click in gaming mode
void startTrack(int id)
Starts vehicle tracking.
Locate junction - button.
std::string getCurrentScheme() const
Returns the name of the currently chosen scheme.
FXDEFMAP(GUIViewTraffic) GUIViewTrafficMap[]
A single child window which contains a view of the simulation area.
FXbool makeCurrent()
A reimplementation due to some internal reasons.
std::vector< MSLane * > LaneVector
Definition of the list of links that participate in this tl-light.
GUIVisualizationSettings * myVisualizationSettings
A MSNet extended by some values for usage within the gui.
virtual ~GUIViewTraffic()
destructor
int doPaintGL(int mode, const Boundary &bound)
SUMOReal m2p(SUMOReal meter) const
meter-to-pixels conversion method
Locate polygons - button.
TLSLogicVariants & get(const std::string &id) const
Returns the variants of a named tls.
bool showGrid
Information whether a grid shall be shown.
void drawDecals()
Draws the stored decals.
virtual int Search(const float a_min[2], const float a_max[2], const GUIVisualizationSettings &c) const
Find all within search rectangle.
The parent class for traffic light logics.
static const bool gUseMesoSim
const std::string & getProgramID() const
Returns this tl-logic's id.
SUMOReal ymax() const
Returns maximum y-coordinate.
void unblockObject(GUIGlID id)
Marks an object as unblocked.
std::vector< MSTrafficLightLogic * > getAllLogics() const
Returns a vector which contains all logics.
GUIGlID getObjectUnderCursor()
returns the id of the object under the cursor using GL_SELECT
GUIGlObject * getObjectBlocking(GUIGlID id)
Returns the object from the container locking it.
static FXIcon * getIcon(GUIIcon which)
void stopTrack()
Stops vehicle tracking.
GUILane * getLaneUnderCursor()
FXPopup * getLocatorPopup()