Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
eclipse
GitHub Repository: eclipse/sumo
Path: blob/main/tests/complex/traci/gui/polygon_dynamics_remove/runner.py
169689 views
1
#!/usr/bin/env python
2
# -*- coding: utf-8 -*-
3
# Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo
4
# Copyright (C) 2008-2025 German Aerospace Center (DLR) and others.
5
# This program and the accompanying materials are made available under the
6
# terms of the Eclipse Public License 2.0 which is available at
7
# https://www.eclipse.org/legal/epl-2.0/
8
# This Source Code may also be made available under the following Secondary
9
# Licenses when the conditions for such availability set forth in the Eclipse
10
# Public License 2.0 are satisfied: GNU General Public License, version 2
11
# or later which is available at
12
# https://www.gnu.org/licenses/old-licenses/gpl-2.0-standalone.html
13
# SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-or-later
14
15
# @file runner.py
16
# @author Michael Behrisch
17
# @author Daniel Krajzewicz
18
# @date 2011-03-04
19
20
21
from __future__ import print_function
22
from __future__ import absolute_import
23
import os
24
import sys
25
26
if "SUMO_HOME" in os.environ:
27
sys.path.append(os.path.join(os.environ["SUMO_HOME"], "tools"))
28
import traci # noqa
29
import sumolib # noqa
30
31
32
traci.start([sumolib.checkBinary('sumo-gui'),
33
"-n", "input_net.net.xml",
34
"-r", "input_routes.rou.xml",
35
"-S", "-Q"])
36
37
trackedVehIDs = []
38
39
while traci.simulation.getMinExpectedNumber() > 0:
40
traci.simulationStep()
41
newVehIDs = [vehID for vehID in traci.lane.getLastStepVehicleIDs('gneE1_0') if vehID not in trackedVehIDs]
42
for newVehID in newVehIDs:
43
pos = traci.vehicle.getPosition(newVehID)
44
shape = [pos, (pos[0]+1, pos[1]), (pos[0]+1, pos[1]+1), (pos[0], pos[1]+1)]
45
traci.polygon.add(newVehID, shape, (255, 0, 0), fill=True, layer=100)
46
traci.polygon.addDynamics(newVehID, trackedObjectID=newVehID)
47
trackedVehIDs.append(newVehID)
48
leavingVehIDs = [vehID for vehID in traci.lane.getLastStepVehicleIDs('gneE5_0') if vehID in trackedVehIDs]
49
for leavingVehID in leavingVehIDs:
50
traci.polygon.remove(leavingVehID)
51
trackedVehIDs.remove(leavingVehID)
52
53
traci.close()
54
55