ESP32 Projekt: Anzeige für Wettervorhersage - AZ-Delivery

Projet ESP32: affichage des prévisions météo

 

Comment sera la météo demain et après-demain? Les projets de stations météorologiques classiques que vous voyez dans la scène ne peuvent rien en dire, car ils affichent et enregistrent uniquement les valeurs de température actuelles. Nous choisissons ici une approche différente: avec l'ESP32 (https://az-delivery.de/products/esp32-developmentboard), nous téléchargeons les prévisions météorologiques pour les cinq prochains jours à partir de https://openweathermap.org  et les montrer sur un petit écran OLED (https://az-delivery.de/products/0-96zolldisplay).

 

Le projet est mis en œuvre en trois sections: (1) préparation du matériel, (2) génération d'une clé API pour OpenWeatherMap pour accéder aux données, et (3) logiciel pour télécharger et afficher les prévisions météorologiques.

 

Matériel informatique

 

 

L'écran est connecté à l'ESP32 avec 3,3 V et GND. Pour la connexion I²C, SCL sont également connectés à G22 et SDA à G21. La figure suivante montre le matériel entièrement câblé.

Les graphiques peuvent même être affichés sur le mini-écran. Avec les exemples d'esquisses de la bibliothèque, ce ne sont que quelques clics.

 

Les graphiques peuvent même être affichés sur le mini-écran. Avec les exemples d'esquisses de la bibliothèque, ce ne sont que quelques clics.

 

API Openweathermap

OpenWeatherMap est une société informatique qui fournit des données météorologiques. À petite échelle, même gratuitement. Pour obtenir des données météorologiques, vous devez envoyer des demandes HTTP à l'API OpenWeatherMap (https://openweathermap.org/forecast5) envoyer. Cela nécessite une authentification à l'aide d'une clé API. Vous pouvez obtenir votre clé API sur la page de prix (https://openweathermap.org/price). Par exemple, cela ressemble à ceci:


a254362gegeg715dce096a37b32c17aa

 

 

Si vous avez maintenant l'URL dans le navigateur http://api.openweathermap.org/data/2.5/forecast?q=Karlsruhe,de&appid=a254362gegeg715dce096a37b32c17aa  , vous obtiendrez les prévisions météo pour Karlsruhe pour les cinq prochains jours. Dans l'URL, remplacez Karlsruhe par le nom de votre ville et la clé API derrière appid =  à travers votre.

 

Les données retournées sont au format JSON. L'attribut temp donne la température prévue en Kelvin pour le temps Allemand  le. Ce dernier est un Horodatage Unix, qui se présente à nouveau sous une forme lisible dt_txt  est envoyé. Exemple de démarrage d'une réponse:

 

{
morue: "200",
message: 0,0447,
cnt: 40,
liste: [
   {
     Allemand: 1503241200,
principal: {
       temp: 293,69,
temp_min: 293,69,
temp_max: 293.738,
pression: 1017.16,
niveau_de la mer: 1037.44,
grnd_level: 1017.16,
humidité: 53,
temp_kf: -0.05
     },
météo: [
       {
identifiant: 800,
principal: "Clear",
description: "ciel clair",
icône: "01d"
       }
     ],
nuages: {
tout: 0
     }, [...]

 

 

Logiciels

Cette section décrit le fonctionnement du programme. Pour une compréhension plus approfondie, jetez un œil au code (https://github.com/Simsso/Microcontroller-Examples/tree/master/ESP32/WeatherDisplay) indispensable. Les fichiers de projet procèdent comme suit:

  • WeatherDisplay.ino: Arduino-Sketch, programme principal: connecte tous les composants.
  • OpenWeatherMapAPI.h: Fichier d'en-tête de l'API OpenWeatherMap: définit comment accéder à OpenWeatherMap.
  • OpenWeatherMapAPI.cpp: Fichier de code API OpenWeatherMap: implémente les méthodes du fichier d'en-tête précédent.
  • OLEDScreen.h: Fichier d'en-tête d'écran OLED: contrôle l'affichage OLED et affiche les données météorologiques sous forme graphique.
  • WeatherForecastSample.cpp: Échantillon de prévisions météorologiques: classe qui représente une seule prévision météorologique.

 

Accès API avec l'ESP32

Afin d'afficher les informations météorologiques, l'ESP32 doit recevoir les données répertoriées ci-dessus en partie de l'API OpenWeatherMap. En raison de sa longueur, le code de téléchargement et de lecture se trouve dans des fichiers C ++ séparés qui sont inclus dans le ketch principal #include  être impliqué. Pour pouvoir exécuter l'exemple de programme, vous devez disposer du contenu complet du dossier de https://github.com/Simsso/Microcontroller-Examples/tree/master/ESP32/WeatherDisplay téléchargez puis ouvrez le fichier .ino avec l'IDE Arduino. Le programme télécharge des données météorologiques à intervalles réguliers (2 heures par défaut). Ceux-ci sont partagés avec la bibliothèque ArduinoJson (https://github.com/bblanchon/ArduinoJson/) analysés, c'est-à-dire lus afin qu'ils puissent être utilisés dans le programme.

 

Pour pouvoir mettre le code en service, vous devez installer les bibliothèques

  • Entrez votre SSID WLAN et votre mot de passe (fichier WeatherDisplay.ino),
  • mettre à jour la ville pour laquelle une prévision doit être faite (fichier WeatherDisplay.ino, variable interroger) et
  • entrez une clé API OpenWeatherMap valide (fichier WeatherDisplay.ino, variable apiKey).

 

Afficher les prévisions météo

L'affichage qui montre les données météorologiques téléchargées peut être contrôlé, par exemple, avec la bibliothèque Ai_Ardulib_SSD1306 (https://github.com/acrobotic/Ai_Ardulib_SSD1306). Au moment de la publication de ce message, cela contenait un bug qui a été corrigé dans cette demande de pull: https://github.com/barbeque/Ai_Ardulib_SSD1306/tree/patch-1. Pour être sûr, téléchargez le code à partir de ce dernier lien.

 

Dans la version actuelle, le programme WeatherDisplay affiche les prévisions météorologiques sous forme simple, c'est-à-dire sans autre formatage. Vous êtes cordialement invité à embellir l'affichage avec des graphiques nuage / soleil, par exemple. http://www.instructables.com/id/Display-Images-on-OLED-Screen-With-Arduino-ATtiny8/.

 

Avec cette météo - 13 ° C - jouer avec l'ESP32 est tout simplement la meilleure chose à faire.

DisplaysEsp-32Projekte für anfänger

29 commentaires

Andreas Wolter

Andreas Wolter

@Bernd Schröder:
Der Link für das Abrufen der Wetterdaten sieht so aus:
http://api.openweathermap.org/data/2.5/weather?q=STADT,LAENDERCODE&APPID=APIKEY

Zuerst müsste also der Standort bestimmt (Stadt und Laendercode) und in diesen Link eingefügt werden. Eventuell hilft die Library “WifiLocation” weiter: https://www.arduino.cc/reference/en/libraries/wifilocation/
Ansonsten bräuchte man GPS und muss daraus aber den Städtenamen und den Ländercode generieren.

Das Zusammensetzen des Links kann man dann mit Substrings erledigen, denke ich. Ich denke, es ist möglich.
Eine weitere Möglichkeit wäre ein Webinterface, in das man den aktuellen Standort per Smartphone oder PC über den Browser eingibt.

Grüße,
Andreas Wolter
AZ-Delivery Blog

Bernd Schröder

Bernd Schröder

Kann man das auch für mobile Anwendung mit wechselnden Standorten machen?
Also so, dass die Software den momentanen Standort ermittelt und dann für diesen Standort das Wetter angezeigt wird.

Yuu

Yuu

Vielen Dank für den Artikel, hat bei mir wunderbar geklappt :)

Warum es bei manchen nicht geklappt hat weiß ich nicht, ich stellte mich als totaler Anfänger nur etwas an mit den Installieren der richtigen Liberies. Auf geheiß mancher Kommentare hab ich ArduinoJson 5.10 installieren lassen statt 6, keine Ahnung ob es mit 6 auch genauso gut klappt.

Hab rechts am Display nur diverse Pixel… Pixelfehler? Sieht etwas schmutzig aus aber sonst erkennt man alles gut. Vielleicht probiere ich mal das ganze an größere Displays.

Anonymous

Anonymous

Dieses Projekt ist das erste mit WIFI und ESP32 für mich. Ich fand die Idee spannend und habe mich nun etliche Stunden damit beschäftigt. Ich habe die Treiber installiert, das Board richtig im IDE angemeldet und den Sketch samt Libraries nun auch übertragen kommen.
Dennoch läuft es noch nicht. Ich bekomme zwar den Versuch angezeigt, dass die Kommunikation nach außen passieren soll, im IDE wird “connecting…connecting…” angezeigt, aber denn laufe ich immer auf einen Timeout. Dies Wifi Zugangsdaten sind es definitiv nicht und so komme ich also nicht weiter.
Kann jemand helfen?

Johannes Sock

Johannes Sock

Hi Horst,
danke für deinen Kommentar v. 12.03.. Die ArduinoJson Lib Version 5 hat mir bisher auch noch nicht weiter geholfen, wobei ich den Verdacht habe, dass sich hier noch ein Problem mit der Ai_Ardulib_SSD1306 Library auftut, zumal der Link auf https://github.com/barbeque/Ai_Ardulib_SSD1306/tree/patch-1 lt. Projektbeschreibung (soll einen Bugfix beinhalten) nicht funktioniert. Alles in allem muss ich feststellen, dass dieses Projekt für Anfänger wie mich eine Nummer zu hoch zu sein scheint. Schade drum, aber ich werfe hier zur Zeit das Handtuch.
Eine überarbeitete ausgereifte Installationsanweisung mit aktuellen und korrekten Downloadlinks wäre schon toll.
LG Johannes

Horst Koch

Horst Koch

Hallo Johannes,
ich bin auch Anfänger und habe mich mit der Software ziemlich “abgequält”. Funktioniert hat einfach die Installation der ArduinoJson Lib Version 5, also die alte Version vor dem Compilieren.

Viele Grüße
Horst

edu

edu

Gibt es bereits ein ausgeführtes Projekt mit einem seriellen Feinstaubsensor am ESP32 der per WLAN die Daten an eine z.b. Handy oder PC-App oder direkt per WLAN an eine entfernte Datenbank sendet?

danke f. eine Info – edu

Thomas

Thomas

Läuft das nicht irgendwie in ein Wetterabo? Die FreeCalls sind doch begrenzt.
Zitat
We accumulate the total number of calls from all the API keys that belong to your account.
When your account exceeds the limit, we do not block your account immediately but send you an automatic notification by email asking you to switch to one of our paid subscriptions within the reasonable term. If we do not get any feedback from you, we suspend your account. To renew your account, contact us
Zitat Ende

Johannes Sock

Johannes Sock

Kann mich Uli Engel nur anschließen. Das Projekt scheitert bei mir ann der Compilerei mit der Fehlermeldung
Arduino: 1.8.12 (Windows 10), Board: “ESP32 Dev Module, Disabled, Default 4MB with spiffs (1.2MB APP/1.5MB SPIFFS), 240MHz (WiFi/BT), QIO, 80MHz, 4MB (32Mb), 921600, None”

OpenWeatherMapAPI.cpp:13:11: error: DynamicJsonBuffer is a class from ArduinoJson 5. Please see arduinojson.org/upgrade to learn how to upgrade your program to ArduinoJson version 6

DynamicJsonBuffer jsonBuffer(20000); // response body size is usually around 15 kByte ^

OpenWeatherMapAPI.cpp:13:29: error: expected constructor, destructor, or type conversion before ‘(’ token

DynamicJsonBuffer jsonBuffer(20000); // response body size is usually around 15 kByte ^

sketch\OpenWeatherMapAPI.cpp: In static member function ‘static ArduinoJson::JsonObject* OpenWeatherMapAPI::getData(String, String)’:

OpenWeatherMapAPI.cpp:102:22: error: ‘jsonBuffer’ was not declared in this scope

JsonObject& root = jsonBuffer.parseObject(resBody); ^

OpenWeatherMapAPI.cpp:103:13: error: ‘ArduinoJson::JsonObject {aka class ArduinoJson6141_0000010::ObjectRef}’ has no member named ‘success’

if (!root.success()) { ^

Mehrere Bibliotheken wurden für “WiFi.h” gefunden
Benutzt: C:\Users\Socke\AppData\Local\Arduino15\packages\esp32\hardware\esp32\1.0.4\libraries\WiFi
Nicht benutzt: C:\Program Files (x86)\Arduino\libraries\WiFi
exit status 1
DynamicJsonBuffer is a class from ArduinoJson 5. Please see arduinojson.org/upgrade to learn how to upgrade your program to ArduinoJson version 6

Ungültige Bibliothek C:\Users\Socke\Documents\Arduino\libraries\Microcontroller-Examples-master in keine Header-Dateien (.h) in C:\Users\Socke\Documents\Arduino\libraries\Microcontroller-Examples-master gefunden gefunden
Ungültige Bibliothek C:\Users\Socke\Documents\Arduino\libraries\Microcontroller-Examples-master in keine Header-Dateien (.h) in C:\Users\Socke\Documents\Arduino\libraries\Microcontroller-Examples-master gefunden gefunden

Dieser Bericht wäre detaillierter, wenn die Option
“Ausführliche Ausgabe während der Kompilierung”
in Datei → Voreinstellungen aktiviert wäre.

Scheint ein Problem mit der ArduinoJson.h-Datei in der Version 5 zu sein.
Wer hat hier schon eine Lösung gefunden, die einem Neuling in diesem Metier weiter helfen kann?
Ich wäre hierfür sehr dankbar, da ich dadurch vielleicht etwas mehr über die Codierung lernen könnte.
Gruß Johannes

Michael

Michael

Kann ich das Projekt auch mit einem ESP8266 umsetzen?
Was muss ich ändern?

Ulli Engel

Ulli Engel

Hallo,
kann man auch einen ESP8266 verwenden?
Was muss ich dann ggf. anpassen?

Danke

Ulli Engel

Ulli Engel

Hi,
ich lese den Blog regelmäßig und habe heute diese Wetterstations-Anleitung darin gefunden. Vielleicht ist dieser Blog nur für Profis gedacht. Mich interessiert aber dieses Thema und ich würde es gerne nachbauen. Doch für einen Anfänger wie ich es bin ist die Darstellung sehr kurz (zu kurz). Und wenn ich die Kommentare der Profis lese, frage ich mich, wie Anfänger hier zu einem gewünschte “Erlebnis” kommen sollen. Ich würde mich über mehr Ausführlichkeit mit mehr Informationen freuen.
Gruß Ulli

Gerhart Ullmann

Gerhart Ullmann

Hallo,
könntet Ihr bitte die Gelbe Schriftfarbe in Blau oder Rotändern? Das wäre deutlich besser zu sehen.
Gruß
Gerhart

Thomas

Thomas

Und diese Datei noch: OpenWeatherMapAPI.h

—snip

#include
#include “SSD1306.h”

#include “WeatherForecastSample.cpp”

class OpenWeatherMapAPI
{
public:
static void init(const char* ssid, const char* password);
static bool getForecast(
String query,
String appId,
WeatherForecastSample** forecast,
int* count);

private:
//static JsonObject* getData(String query, String appId);
static JsonObject getData(String query, String appId);

static String getResponse(String query, String appId);

};

#endif

—snap

Thomas

Thomas

Hallo,

evtl, das mal testen, wenn ArduinoJson Lib 6.10.1

Datei: OpenWeatherMapAPI.cpp

—snip

#include
#include
#include

#include “OpenWeatherMapAPI.h”
#include “WeatherForecastSample.cpp”

const char *owmApiHost = “api.openweathermap.org”;
const uint64_t timeout = 5000; // [ms]

DynamicJsonDocument jDoc(30000);

void OpenWeatherMapAPI::init(const char* ssid, const char* password)
{
Serial.println("Connecting to " + String(ssid));
WiFi.begin(ssid, password);

while (WiFi.status() != WL_CONNECTED) { } Serial.println("Connected with IP address " + WiFi.localIP().toString());

};

bool OpenWeatherMapAPI::getForecast(String query, String appId, WeatherForecastSample** forecast, int* count)
{
//const JsonObject* root = OpenWeatherMapAPI::getData(query, appId);
//const
JsonObject root = OpenWeatherMapAPI::getData(query, appId);
if (root.isNull()) return false;

*count = 20; forecast = new WeatherForecastSample[count]; for (int i = 0; i < *count; i++) { (*forecast)[i].dt = (root)[“list”][i][“dt”].as(); (*forecast)[i].temp = (root)[“list”][i][“main”][“temp”].as(); (*forecast)[i].description = (root)[“list”][i][“weather”]0[“description”].as(); (*forecast)[i].dtTxt = (root)[“list”][i][“dt_txt”].as(); if ((*forecast)[i].dtTxt.length() == 0) { *count = i; break; } } Serial.println("Forecast data parsed "); return true;

};

String OpenWeatherMapAPI::getResponse(String query, String appId)
{
WiFiClient client;
const int httpPort = 80;
if (!client.connect(owmApiHost, httpPort)) {
Serial.println(“Connection failed”);
return "";
}

String path = “/data/2.5/forecast?q=” + query + “&appid=” + appId; client.print( “GET " + path + " HTTP/1.1\r\n" + “Host: " + owmApiHost + “\r\n” + “Connection: close\r\n” + “Pragma: no-cache\r\n” + “Cache-Control: no-cache\r\n” + “User-Agent: ESP32\r\n” + “Accept: text/html,application/json\r\n\r\n”); uint64_t startMillis = millis(); while (client.available() == 0) { if (millis() – startMillis > timeout) { Serial.println(“Client timeout”); client.stop(); return ""; } } String resHeader = "", resBody = ""; bool receivingHeader = true; while(client.available()) { String line = client.readStringUntil(‘\r’); if (line.length() == 1 && resBody.length() == 0) { receivingHeader = false; continue; } if (receivingHeader) { resHeader += line; } else { resBody += line; } } client.stop(); Serial.print("Data received successfully (request body size: " + String(resBody.length()) + " bytes)"); Serial.println(resBody); return resBody;

};

JsonObject OpenWeatherMapAPI::getData(String query, String appId)
{
String resBody = OpenWeatherMapAPI::getResponse(query, appId);
const int contentLength = resBody.length();
JsonObject root;

if (contentLength > 0) { // parse JSON DeserializationError error = deserializeJson(jDoc, resBody); if (error) { Serial.println(error.c_str()); Serial.println(“return nullptr”); return root; //nullptr; } else { Serial.println(error.c_str()); root = jDoc.as(); Serial.println(“return &root”); //return &root; return root; } } return root; //nullptr;

};

—snap

Peter Pi.

Peter Pi.

Nachtrag: Mit der Version 5 der ArduinoJson Lib läuft es. Es gibt auch eine Anleitung zum Update von V5 auf V6.

Peter Pi.

Peter Pi.

Scheint mit den o.a. Quellen nicht zu kompilieren, weil die lib von version 5 auf 6 ein upgrade bekommen hat.

“DynamicJsonBuffer is a class from ArduinoJson 5. Please see arduinojson.org/upgrade to learn how to upgrade your program to ArduinoJson version 6”

Ich wollte das nur schnell zusammenbauen und probieren, da die Hardware bereits vorliegt, also wenn jemand Rat weiß, Danke!

Peter F.

Peter F.

Interessanter Ansatz, jedoch ist openwether hier ein Overkill
Mit wttr.in wäre es einfacher und man bekommt eine kleine Grafik dazu.
Wer würde es versuchen, bin leider selbst kein Programmierer?

Joerg

Joerg

Und wenn man openweathermap auf deutsch umstellt, kommen die Umlaute nicht richtig raus. Hat jemand einen Vorschlag?

Wolfgang

Wolfgang

Schade, dass alles ausverkauft ist! Hätte es gerne nachgebaut.

Wolfgang Noel

Wolfgang Noel

Hallo Thomas, mit der Änderung funktioniert es jetzt einwandfrei. Danke

Thomas

Thomas

Hallo,

bei mit wurde die Wetterdaten auch immer nur beim ersten Mal geladen.
Abhilfe brachte bei mit eine Anpasung der OpenWeatherMapAPI.cpp
Oben der der globalen Variablendeklaration DynamicJsonBuffer jsonBuffer(20000); auskommentieren und …

—snip
const char *owmApiHost = “api.openweathermap.org”;
const uint64_t timeout = 5000; // [ms]

//DynamicJsonBuffer jsonBuffer(20000); // response body size is usually around 15 kByte → auskommentieren

void OpenWeatherMapAPI::init(const char* ssid, const char* password)
—snap

…eine Kopie davon in der Funktion JsonObject* OpenWeatherMapAPI::getData(String query, String appId)

—snip
JsonObject* OpenWeatherMapAPI::getData(String query, String appId)
{
String resBody = OpenWeatherMapAPI::getResponse(query, appId);
const int contentLength = resBody.length();
if (contentLength > 0) {
// parse JSON
DynamicJsonBuffer jsonBuffer(20000); // response body size is usually around 15 kByte → hierhin kopieren

JsonObject& root = jsonBuffer.parseObject(resBody);

—snap

Beim Aufruf der Funktion wird jedes Mal der Buffer neu erstellt.

Bitte mal testen.

Gruß Thomas

Eveline Purps

Eveline Purps

Das ist doch mal eine konkrete Anleitung – bin gespannt ob es funktioniert. Sowas könnte man doch gut weiter machen….

Wolfgang Noel

Wolfgang Noel

Hallo, leider werden bei mir die Daten nicht aktualisiert. Soll eigentlich doch alle 2 Stunden erfolgen. Scripte so wie in der Vorlage übernommen. Nach Neustart wird auch aktualisiert.

Wolfgang

Wolfgang

Hallo, ich habe alle Programmteile so übernommen. Programm funktioniert auch soweit. Leider werden die Daten nicht automatisch aktualisiert. Nach einem Neustart sind die aktuellen Daten dann da. Woran kann das liegen?

Stephan

Stephan

Hallo zusammen,

habe das Programm heute morgen mal umgesetzt, gefällt mir.

@Michael … du brauchst meines Erachtens den Patch nicht mehr; die Library funktioniert auch so.

Ich habe eine einzige Sache geändert: Und zwar in der OLEDScreen.h habe ich in Zeile 15 aus (font5x7) (font8x8) gemacht, sonst wurde bei mir der Text nicht korrekt auf dem Display ausgegeben …

Gruß, Stephan

 Michael

Michael

Hallo leider ist der link https://github.com/barbeque/Ai_Ardulib_SSD1306/tree/patch-1 nicht mehr online, das bauen bricht leider mit einem fehler ab. wo kann ich den patch noch downloaden? bitte um eure hilfe.

MFG
Michael

Marcus

Marcus

Herrliche Spielerei – jetzt macht mein Raspberry / OpenHab die Wettervorhersage nicht mehr selbst, sondern bekommt sie direkt gemeinsam mit den gemessenen Wetterdaten von einem ESP32. Und dieser zeigt die Werte auch noch in der Garage auf dem OLED an.

Stephan

Stephan

Tolle Idee! Jetzt noch eine Variante mit Solarbetrieb wäre cool!

Laisser un commentaire

Tous les commentaires sont modérés avant d'être publiés

Articles de blog recommandés

  1. ESP32 jetzt über den Boardverwalter installieren - AZ-Delivery
  2. Internet-Radio mit dem ESP32 - UPDATE - AZ-Delivery
  3. Arduino IDE - Programmieren für Einsteiger - Teil 1 - AZ-Delivery
  4. ESP32 - das Multitalent - AZ-Delivery