(Page créée avec « {{Tuto Details |Licences=Attribution (CC-BY) |Description=Appareil informationnel des transports du réseau Bordeaux Métropole |Disciplines scientifiques=Arduino, Computi... ») |
|||
(Une révision intermédiaire par le même utilisateur non affichée) | |||
Ligne 1 : | Ligne 1 : | ||
{{Tuto Details | {{Tuto Details | ||
+ | |Main_Picture=TRAMONTIME__2024-10-11_033695.jpg | ||
|Licences=Attribution (CC-BY) | |Licences=Attribution (CC-BY) | ||
|Description=Appareil informationnel des transports du réseau Bordeaux Métropole | |Description=Appareil informationnel des transports du réseau Bordeaux Métropole | ||
Ligne 116 : | Ligne 117 : | ||
main_loop() | main_loop() | ||
|Step_Picture_00=TRAMONTIME__Capture_d_cran_2024-10-11_151117.png | |Step_Picture_00=TRAMONTIME__Capture_d_cran_2024-10-11_151117.png | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
}} | }} | ||
{{Tuto Step | {{Tuto Step |
Auteur monamicq | Dernière modification 11/10/2024 par Lmonamicq
Transport, information, affichage LED, horaire TRAMONTIME__2024-10-11_033695.jpg
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.
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.
import network import time import urequests as requests import machine import neopixel
SSID = 'OnePlus 9' PASSWORD = '123456789'
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
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!")
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
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
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
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
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
if __name__ == "__main__":
connect_to_wifi() main_loop()
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.
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.
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.
- Planifier le départ de son logement
- Permettre aux usagers d'optimiser leur temps
- Eviter de longues attentes ou des retards.
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.
Dernière modification 11/10/2024 par user:Lmonamicq.
Draft
Vous avez entré un nom de page invalide, avec un ou plusieurs caractères suivants :
< > @ ~ : * € £ ` + = / \ | [ ] { } ; ? #