Nous pourrions montrer un usager consultant le TRAMONTIME depuis chez lui, suivi d’un décompte coloré des LED indiquant le temps restant jusqu'à l'arrivée du tramway. Ensuite, l'utilisateur part au bon moment, évitant ainsi l'attente inutile à l'arrêt. +
Ce matin, Julie se prépare pour aller trav … Ce matin, Julie se prépare pour aller travailler. Elle consulte son TRAMONTIME pour connaître l'arrivée de son tramway. Les LED sont encore vertes, indiquant qu'il lui reste 10 minutes avant son passage. Elle finit de se préparer tranquillement et, en jetant un dernier coup d'œil, voit que les LED passent au jaune, signalant qu'il ne reste plus que 5 minutes. Julie quitte rapidement son appartement et arrive à l'arrêt juste à temps, avant que les LED ne passent au rouge.ps, avant que les LED ne passent au rouge. +
Le TRAMONTIME est une innovation dédiée au … Le TRAMONTIME est une innovation dédiée aux usagers des transports en commun de Bordeaux Métropole. Cet appareil informatif offre en temps réel la position des bus, tramways et navettes, ainsi que le temps restant avant leur arrivée. Grâce à TRAMONTIME, les usagers peuvent planifier leur départ depuis chez eux. Il permet aux usagers d'optimiser leur temps et d'éviter de longues attentes ou des retards.éviter de longues attentes ou des retards. +
Le TRAMONTIME fonctionne en captant les do … Le TRAMONTIME fonctionne en captant les données en temps réel sur l'arrivée du transport sélectionné. Un décompte des minutes restantes avant le passage du véhicule est alors activé, sur une temporalité de 15 minutes. Ce décompte est visualisé à travers des LED, qui changent de couleur en fonction du temps restant : du vert lorsque l'utilisateur a encore largement le temps, jusqu'au rouge lorsque le véhicule est sur le point de passer ou a été raté. Cela permet aux usagers de suivre facilement l'approche du transport.suivre facilement l'approche du transport. +
Après avoir exploré plusieurs options, nou … Après avoir exploré plusieurs options, nous avons choisi un jeu de données dédié aux transports en commun, car il concerne l'ensemble des usagers. Ce jeu de données offre des informations détaillées sur la fréquence, les horaires, les retards et la position en temps réel des bus, tramways et navettes. temps réel des bus, tramways et navettes. +, Ensuite il a fallu déterminer la forme et … Ensuite il a fallu déterminer la forme et le design de l'appareil. Nous avons commencé par esquisser plusieurs croquis. Une fois les options sélectionnées, nous avons procédé à la modélisation 3D de l'appareil, permettant d'évaluer ses dimensions et une visualisation clair de l'objet final. une visualisation clair de l'objet final. +, import network
import time
import urequest … import network
import time
import urequests as requests
import machine
import neopixel
# Configuration du WiFi
SSID = 'OnePlus 9'
PASSWORD = '123456789'
# Configuration du bandeau LED
LED_PIN = 6 # Pin GPIO pour le bandeau LED
NUMPIXELS = 15 # Nombre de LEDs sur le bandeau
np = neopixel.NeoPixel(machine.Pin(LED_PIN), NUMPIXELS) # Initialisation du bandeau LED
# Fonction pour se connecter au WiFi
def connect_to_wifi():
wlan = network.WLAN(network.STA_IF)
wlan.active(True)
if not wlan.isconnected():
print(f"Try connect to SSID : {SSID}")
wlan.connect(SSID, PASSWORD)
while not wlan.isconnected():
print('.', end=" ")
time.sleep_ms(500)
print("\nConnected to WiFi!")
# Fonction pour obtenir le temps actuel et le temps du prochain bus via l'API
def get_bus_time():
try:
# Requête pour obtenir le prochain passage de bus
nextbus = requests.get('https://lb.enzopb.me/api.php').text
# Requête pour obtenir l'heure actuelle
actualtime = requests.get('https://lb.enzopb.me/time.php').text
# Convertir les temps en entiers (secondes depuis epoch)
nextbus_time = int(nextbus)
current_time = int(actualtime)
# Calculer la différence en secondes (ajustée par un décalage de 7200 secondes)
time_remaining = nextbus_time - current_time - 7200
print(f"Prochain bus dans {time_remaining} secondes.")
return time_remaining
except Exception as e:
print(f"Erreur lors de la requête API : {e}")
return None
# Fonction pour afficher les LEDs en fonction du temps restant
def afficher_leds(time_remaining):
for i in range(NUMPIXELS):
if time_remaining >= (i * 60):
intensity = map_value(time_remaining - (i * 60), 0, 60, 0, 255)
color = get_color(i, intensity) # Obtenir la couleur de la LED
np[i] = color # Appliquer la couleur à la LED i
else:
np[i] = (0, 0, 0) # Éteindre la LED
np.write() # Mettre à jour le bandeau LED
# Fonction pour définir la couleur d'une LED en fonction de son index
def get_color(led_index, intensity):
if 10 <= led_index <= 14:
return (0, intensity, 0) # Vert
elif 5 <= led_index <= 9:
return (intensity, intensity, 0) # Jaune
else:
return (intensity, 0, 0) # Rouge
# Fonction pour mapper une valeur (MicroPython n'a pas de fonction map native)
def map_value(x, in_min, in_max, out_min, out_max):
return (x - in_min) * (out_max - out_min) // (in_max - in_min) + out_min
# Boucle principale
def main_loop():
while True:
time_remaining = get_bus_time()
if time_remaining is not None:
afficher_leds(time_remaining)
else:
print("Erreur lors de la récupération des données de temps.")
time.sleep(15) # Attendre 15 secondes avant de rafraîchir
# Programme principal
if __name__ == "__main__":
connect_to_wifi()
main_loop()me__ == "__main__":
connect_to_wifi()
main_loop() et Pour réaliser notre conception, nous avons … Pour réaliser notre conception, nous avons utilisé un décapeur thermique afin de façonner certaines parties du boîtier et une découpe laser pour obtenir des formes précises dans les matériaux choisis. En raison des contraintes de temps, nous avons opté pour un assemblage rapide en utilisant de la colle afin de fixer les différentes pièces ensemble. de fixer les différentes pièces ensemble. +
Date de modification« Date de modification (Modification date) » est une propriété prédéfinie qui correspond à la date de la dernière modification d’un sujet et est fournie par MédiaWiki Sémantique.