POCL Neige en station : Différence entre versions

(Page créée avec « {{Tuto Details |Licences=Attribution (CC-BY) |Description=Création d’un petit objet connecté qui va chercher la météo sur internet et indique en temps réel s’il n... »)
 
Ligne 44 : Ligne 44 :
 
}}
 
}}
 
{{Tuto Step
 
{{Tuto Step
|Step_Title=Découper l'objet à la découpeuse laser
+
|Step_Title=Raccorder la bande de LED à l'esp32
 +
}}
 +
{{Tuto Step
 +
|Step_Title=Utiliser Thonny pour déposer les programmes sur l'ESP32
 +
}}
 +
{{Tuto Step
 +
|Step_Title=Tester le programme
 +
}}
 +
{{Tuto Step
 +
|Step_Title=Découper l'objet
 +
}}
 +
{{Tuto Step
 +
|Step_Title=Assembler l'objet et l'électronique
 
}}
 
}}
 
{{Notes
 
{{Notes
 
|Notes=<syntaxhighlight lang="python" line="1">
 
|Notes=<syntaxhighlight lang="python" line="1">
 +
# Programme boot.py :
 +
 
from machine import Pin
 
from machine import Pin
 
import time
 
import time
Ligne 65 : Ligne 79 :
 
gc.collect()
 
gc.collect()
  
ssid = 'nom_du_wifi'
+
ssid = 'Nom_Wifi'
password = 'mot_de_passe_du wifi'
+
password = 'Mot_de_passe_wifi'
 
valeur_main = None
 
valeur_main = None
led_ = None
 
  
np=neopixel.NeoPixel(Pin(15),2)
+
NB_LED = 2
led_ = 0
+
np=neopixel.NeoPixel(Pin(15),NB_LED)
 +
np[0] = (10, 0, 0)
 +
np.write()
 +
 
 +
bleu = (248, 248, 255)
 +
noir = (0, 0, 0)
 +
rouge = (255, 0, 0)
 +
 
 +
def allumer_couleur(couleur):
 +
    for i in range(NB_LED):
 +
        np[i]=couleur
 +
    np.write()
 +
 
 +
 
  
 
station = network.WLAN(network.STA_IF)
 
station = network.WLAN(network.STA_IF)
Ligne 79 : Ligne 105 :
  
 
while not station.isconnected() :
 
while not station.isconnected() :
 +
    allumer_couleur(rouge)
 
     time.sleep(1)
 
     time.sleep(1)
 
     print('Non connecté')
 
     print('Non connecté')
Ligne 84 : Ligne 111 :
 
print('Connection successful')
 
print('Connection successful')
 
#écrit les configurations de la connection
 
#écrit les configurations de la connection
print(station.ifconfig())
+
#print(station.ifconfig())
  
 
#Ville : Station Autrans 45°13'49.1"N 5°34'55.9"E
 
#Ville : Station Autrans 45°13'49.1"N 5°34'55.9"E
Ligne 90 : Ligne 117 :
 
long = '5.58194'
 
long = '5.58194'
  
def extract_Weather(list, url) :
 
    weather_data = requests.get(url)
 
    print(weather_data.json())
 
    #transforme tout le json en dictionnaire
 
    data = json.loads(weather_data.text)
 
    # pour n qui parcourt chaque élément de list soit json_path dans le code avec n qui prendra main puis pressure
 
    for n in list:
 
        if(n != ""):
 
            data = data[n]
 
    return str(data)
 
 
def allumer_bleu():
 
  global led_
 
  led_ = 0
 
  for count in range(2):
 
    np[led_]=(248,248,255)
 
    led_ = 1 + led_
 
  np.write()
 
  
def allumer_noir():
 
  global led_
 
  led_ = 0
 
  for count in range(2):
 
    np[led_]=(0,0,0)
 
    led_ = 1 + led_
 
  np.write()
 
  
 
# Récupération données
 
# Récupération données
Ligne 129 : Ligne 131 :
 
#print(description)
 
#print(description)
  
while True:
+
#Programme main.py :
  valeur_main = extract_Weather(json_path, weather_url)
+
 
  print(valeur_main)
+
def extract_Weather(list, url) :
  if valeur_main == "Snow":
+
    weather_data = requests.get(url)
      print("ca marche")
+
    #print(weather_data.json())
      allumer_bleu()
+
    #transforme tout le json en dictionnaire
  else valeur_main != "Snow" :
+
    data = json.loads(weather_data.text)
      allumer_noir()
+
    # pour n qui parcourt chaque élément de list soit json_path dans le code avec n qui prendra main puis pressure
  time.sleep(20)
+
    for n in list:
 +
        if(n != ""):
 +
            data = data[n]
 +
    return str(data)
 +
 
 +
valeur_main = extract_Weather(json_path, weather_url)
 +
print("Temps actuel : " + valeur_main)
 +
if valeur_main == "Snow":
 +
    print("ca marche")
 +
    allumer_couleur(bleu)
 +
else :
 +
    allumer_couleur(noir)
 +
time.sleep(7)
 
</syntaxhighlight>
 
</syntaxhighlight>
 
}}
 
}}

Version du 12 octobre 2025 à 19:37

Auteur avatarCarolineCO | Dernière modification 3/12/2025 par CarolineCO

Pas encore d'image

Création d’un petit objet connecté qui va chercher la météo sur internet et indique en temps réel s’il neige dans ta station de ski préférée.
Licence : Attribution (CC-BY)

Étape 1 - Réunir le matériel

Étape 2 - Préparer l'ESP 32

⚠️ Attention, ton ESP32 doit avoir été flashé avec micropython !

Tutoriel pour le faire : Installation de micropython

ou directement

⚠️ Cela fonctionne uniquement sur Google Chrome et Microsoft Edge.

Rendez-vous en bas de la page d'accueil :

https://dblocadata.debrouillonet.org/~test/#flash

Étape 3 - Raccorder la bande de LED à l'esp32

Étape 4 - Utiliser Thonny pour déposer les programmes sur l'ESP32

Étape 5 - Tester le programme

Étape 6 - Découper l'objet

Étape 7 - Assembler l'objet et l'électronique

Éléments pédagogiques


Sources et ressources

# Programme boot.py :

from machine import Pin
import time
try:
  import urequests as requests
except:
  import requests
try:
  import ujson as json
except:
  import json
import network
import neopixel
import esp
esp.osdebug(None)
import gc
gc.collect()

ssid = 'Nom_Wifi'
password = 'Mot_de_passe_wifi'
valeur_main = None

NB_LED = 2
np=neopixel.NeoPixel(Pin(15),NB_LED)
np[0] = (10, 0, 0)
np.write()

bleu = (248, 248, 255)
noir = (0, 0, 0)
rouge = (255, 0, 0)
  
def allumer_couleur(couleur):
    for i in range(NB_LED):
        np[i]=couleur
    np.write()



station = network.WLAN(network.STA_IF)
# se connecte
station.active(True)
station.connect(ssid, password)

while not station.isconnected() :
    allumer_couleur(rouge)
    time.sleep(1)
    print('Non connecté')

print('Connection successful')
#écrit les configurations de la connection
#print(station.ifconfig())

#Ville : Station Autrans 45°13'49.1"N 5°34'55.9"E
lat = '45.2302778'
long = '5.58194'



# Récupération données
api_key = '1e3c7b8ac112252a6250d681373bc7ed'
#https://api.openweathermap.org/data/2.5/weather?lat=44.866669&lon=-0.61667&appid=1e3c7b8ac112252a6250d681373bc7ed
weather_url = 'https://api.openweathermap.org/data/2.5/weather?lat=' + lat + '&lon=' + long + '&appid=' + api_key
#va chercher main dans la première case du tableau weather
json_path = ['weather', 0, 'main'] 

# Weather Description
#weather = extract_Weather(json_path, weather_url)
#description = 'Description: ' + weather
#print(description)

#Programme main.py :

def extract_Weather(list, url) :
    weather_data = requests.get(url)
    #print(weather_data.json())
    #transforme tout le json en dictionnaire
    data = json.loads(weather_data.text)
    # pour n qui parcourt chaque élément de list soit json_path dans le code avec n qui prendra main puis pressure
    for n in list:
        if(n != ""):
            data = data[n]
    return str(data)

valeur_main = extract_Weather(json_path, weather_url)
print("Temps actuel : " + valeur_main)
if valeur_main == "Snow":
    print("ca marche")
    allumer_couleur(bleu)
else :
    allumer_couleur(noir)
time.sleep(7)

Dernière modification 3/12/2025 par user:CarolineCO.

Commentaires

Draft