COVID19-Tracker-ESP32

Dieser kleine Tracker hilft Ihnen, über den Ausbruch des Coronavirus und die Situation in Ihrem Land auf dem Laufenden zu bleiben. Das Display zeigt abwechselnd die aktuellen Daten verschiedener Länder Ihrer Wahl an.

Die Daten werden von der folgenden Website gesammelt: 
www.worldometers.info/coronavirus/

Benötigte Hardware 

Anzahl Bauteil Anmerkung
1 AZ-Touch Wandgehäuseset mit Touchscreen für ESP8266 und ESP32
1 ESP32 NodeMCU Module WLAN WiFi Development Board mit CP2102 (Nachfolgermodell zum ESP8266)


Als Hardware-Plattform wurde unser AZ-Touch-Kit für ESP32 verwendet. Dieses Kit wird mit einem 2,4-Zoll-TFT-Touchscreen geliefert, der für die Datenausgabe verwendet wird.


Alle Informationen über die Hardware finden Sie hier: 
https://www.az-delivery.de/products/arduitouch-wandgehauseset-mit-touchscreen-fur-esp8266-und-esp32?_pos=2&_sid=2d1c17c61&_ss=r


Bibliotheken 

Installieren Sie die folgenden Bibliotheken über den Arduino Library Manager

Adafruit GFX-Bibliothek https://github.com/adafruit/Adafruit-GFX-Library/archive/master.zip

Adafruit ILI9341 Bibliothek https://github.com/adafruit/Adafruit_ILI9341

Sie können die Bibliothek auch direkt als ZIP-Datei herunterladen und den Ordner unter: yourarduinosketchfolder/libraries/  dekomprimieren.

Starten Sie nach der Installation der Bibliotheken die Arduino-IDE neu.

WiFi-Einstellungen

Geben Sie Ihre WiFi-SSID und Ihr Passwort in die Felder im WiFi-Abschnitt ein:

Geben Sie hier Ihre SSID ein: 

#define WIFI_SSID "xxxxxx" //

Geben Sie hier Ihr WiFi-Passwort ein: 

#define WIFI_PASS "xxxxx" //

Land-Einstellungen

Sie können die Länder in der Hauptschleife des Programms entsprechend Ihren Interessen ändern/ hinzufügen/löschen.


Software

 *  Application note: Covid 19 tracker for AZ-Touch and ESP32 DEV KIT 3
 *  Version 1.0
 *  Copyright (C) 2020  Hartmut Wendt  www.zihatec.de
 *  
 *
 *  This program is free software: you can redistribute it and/or modify
 *  it under the terms of the GNU General Public License as published by
 *  the Free Software Foundation, either version 3 of the License, or
 *  (at your option) any later version.
 *
 *  This program is distributed in the hope that it will be useful,
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 *  GNU General Public License for more details.
 *
 *  You should have received a copy of the GNU General Public License
 *  along with this program.  If not, see .
*/ 

/*______Import Libraries_______*/
#include  
#include 
#include 
#include   
#include 
#include "Adafruit_GFX.h"
#include "Adafruit_ILI9341.h"

/*______End of Libraries_______*/

/*__Pin definitions for the Arduino MKR__*/
#define TFT_CS   5
#define TFT_DC   4
#define TFT_MOSI 23
#define TFT_CLK  18
#define TFT_RST  22
#define TFT_MISO 19
#define TFT_LED  15  


#define HAVE_TOUCHPAD
#define TOUCH_CS 14
#define TOUCH_IRQ 2 
/*_______End of definitions______*/

/*____Calibrate Touchscreen_____*/
#define MINPRESSURE 10      // minimum required force for touch event
#define TS_MINX 370
#define TS_MINY 470
#define TS_MAXX 3700
#define TS_MAXY 3600
/*______End of Calibration______*/


/*____Wifi _____________________*/
///////please enter your sensitive data in the Secret tab/arduino_secrets.h
#define WIFI_SSID "xxxxxx"       // Enter your SSID here
#define WIFI_PASS "xxxxx"    // Enter your WiFi password here
// Number of milliseconds to wait without receiving any data before we give up
const int kNetworkTimeout = 30*1000;
// Number of milliseconds to wait if no data is available before trying again
const int kNetworkDelay = 2000; 
/*______End of Wifi______*/


int status = WL_IDLE_STATUS;
int infected=0;
int recovered=0;
int deaths=0;


WiFiClientSecure client;
HttpClient http(client,"www.worldometers.info", 443); 

Adafruit_ILI9341 tft = Adafruit_ILI9341(TFT_CS, TFT_DC, TFT_RST);


void setup() {
  //Initialize serial and wait for port to open:
  Serial.begin(9600);
  while (!Serial) {
    ; // wait for serial port to connect. Needed for native USB port only
  }

  // init GPIOs
  pinMode(TFT_LED, OUTPUT); // define as output for backlight control

  // initialize the TFT
  Serial.println("Init TFT ...");
  tft.begin();          
  tft.setRotation(3);   // landscape mode  
  tft.fillScreen(ILI9341_BLACK);// clear screen 

  tft.setCursor(70,110);
  tft.setTextColor(ILI9341_WHITE);
  tft.setTextSize(2);
  tft.print("Connecting...");
  digitalWrite(TFT_LED, LOW);    // LOW to turn backlight on; 


 // Set WiFi to station mode and disconnect from an AP if it was Previously
  // connected
  WiFi.mode(WIFI_STA);
  WiFi.disconnect();
  delay(100);

  // Attempt to connect to Wifi network:
  Serial.print("Connecting Wifi: ");
  Serial.println(WIFI_SSID);
  WiFi.begin(WIFI_SSID, WIFI_PASS);
  while (WiFi.status() != WL_CONNECTED) {
    Serial.print(".");
    delay(500);
  }
  Serial.println("");
  Serial.println("WiFi connected");
  Serial.println("IP address: ");
  IPAddress ip = WiFi.localIP();
  Serial.println(ip); 
 

}

void loop() {
 check_country("China");
 delay(2000);
 check_country("Italy");
 delay(2000); 
 check_country("Germany");
 delay(2000); 
 check_country("Spain");
 delay(2000); 
 check_country("Austria");
 delay(2000); 
 check_country("Switzerland");
 delay(2000); 
}


void draw_country_screen(String sCountry){
  tft.fillScreen(ILI9341_BLACK);// clear screen

  // headline
  tft.setCursor(10,10);
  tft.setTextColor(ILI9341_WHITE);
  tft.setTextSize(3);
  tft.print(sCountry + ":");

  // infected
  tft.setCursor(10,70);
  tft.setTextColor(ILI9341_RED);
  tft.print("Infected:");
  tft.setCursor(200,70);
  tft.print(infected);

  // recovered
  tft.setCursor(10,130);
  tft.setTextColor(ILI9341_GREEN);
  tft.print("Recovered:");
  tft.setCursor(200,130);
  tft.print(recovered);

  // deaths
  tft.setCursor(10,190);
  tft.setTextColor(ILI9341_LIGHTGREY);
  tft.print("Deaths:");
  tft.setCursor(200,190);
  tft.print(deaths); 
      
}

void check_country(String sCountry) {
  int err =0;
  int readcounter = 0;
  int read_value_step = 0;
  String s1 = "";
  String s2 = "";
  
  err = http.get("/coronavirus/country/" + sCountry +"/");
  if (err == 0)
  {
    Serial.println("startedRequest ok");

    err = http.responseStatusCode();
    if (err >= 0)
    {
      Serial.print("Got status code: ");
      Serial.println(err);

      // Usually you'd check that the response code is 200 or a
      // similar "success" code (200-299) before carrying on,
      // but we'll print out whatever response we get

      // If you are interesting in the response headers, you
      // can read them here:
      //while(http.headerAvailable())
      //{
      //  String headerName = http.readHeaderName();
      //  String headerValue = http.readHeaderValue();
      //}

      Serial.print("Request data for ");
      Serial.println(sCountry);
    
      // Now we've got to the body, so we can print it out
      unsigned long timeoutStart = millis();
      char c;
      // Whilst we haven't timed out & haven't reached the end of the body
      while ( (http.connected() || http.available()) &&
             (!http.endOfBodyReached()) &&
             ((millis() - timeoutStart) < kNetworkTimeout) )
      {
          if (http.available())
          {
              c = http.read();
              s2 = s2 + c;
              if (readcounter < 255) {
                readcounter++;
              } else {
                readcounter = 0;
                String tempString = "";
                tempString.concat(s1);
                tempString.concat(s2);
                // check infected first 
                if (read_value_step == 0) {                               
                  int place = tempString.indexOf("Coronavirus Cases:");
                  if ((place != -1) && (place < 350)) { 
                    read_value_step = 1;
                    s2 = tempString.substring(place + 15);
                    tempString = s2.substring(s2.indexOf("#aaa") + 6);
                    s1 = tempString.substring(0, (tempString.indexOf("")));
                    s1.remove(s1.indexOf(","),1);  
                    Serial.print("Coronavirus Cases: ");
                    Serial.println(s1);
                    infected = s1.toInt();
                  }
                  
                }
                // check deaths               
                if (read_value_step == 1) {
                  int place = tempString.indexOf("Deaths:");
                  if ((place != -1) && (place < 350)) { 
                    read_value_step = 2;
                    s2 = tempString.substring(place + 15);
                    tempString = s2.substring(s2.indexOf("") + 6);
                    s1 = tempString.substring(0, (tempString.indexOf("")));
                    s1.remove(s1.indexOf(","),1);  
                    Serial.print("Deaths: ");
                    Serial.println(s1);
                    deaths = s1.toInt();
                  }
                }                
                // check recovered               
                if (read_value_step == 2) {
                  int place = tempString.indexOf("Recovered:");
                  if ((place != -1) && (place < 350)) {                   
                    s2 = tempString.substring(place + 15);
                    tempString = s2.substring(s2.indexOf("") + 6);
                    s1 = tempString.substring(0, (tempString.indexOf("")));
                    s1.remove(s1.indexOf(","),1);  
                    Serial.print("Recovered: ");
                    Serial.println(s1);
                    recovered = s1.toInt();
                    draw_country_screen(sCountry);
                    http.stop();
                    return;
                  }
                }                
      
                s1 = s2;
                s2 = ""; 
              }              
              
              // We read something, reset the timeout counter
              timeoutStart = millis();
          }
          else
          {
              // We haven't got any data, so let's pause to allow some to
              // arrive
              delay(kNetworkDelay);
          }
      }
    }
    else
    {    
      Serial.print("Getting response failed: ");
      Serial.println(err);
    }
  }
  else
  {
    Serial.print("Connect failed: ");
    Serial.println(err);
  }
  http.stop();
  
}


void printWiFiStatus() {
  // print the SSID of the network you're attached to:
  Serial.print("SSID: ");
  Serial.println(WiFi.SSID());

  // print your board's IP address:
  IPAddress ip = WiFi.localIP();
  Serial.print("IP Address: ");
  Serial.println(ip);

  // print the received signal strength:
  long rssi = WiFi.RSSI();
  Serial.print("signal strength (RSSI):");
  Serial.print(rssi);
  Serial.println(" dBm");
}

Anmerkung: Bitte schauen Sie auf unseren GITHUB Account. Dort finden Sie immer den aktuellen Stand der Software. Zwischenzeitlich haben wir Hinweise von unseren Kunden in die Software eingearbeitet und die verbesserten Versionen auf GITHUB bereitgestellt. Es kann auch in Zukunft passieren, dass die Daten nicht oder nur teilweise abgerufen werden können, weil die Struktur der Webseite www.worldometers.info/coronavirus/  geändert wird. Darauf haben wir keinen Einfluss und können dann nur darauf mit einer Anpassung des Codes reagieren.

https://github.com/HWHardsoft/COVID19-Tracker-ESP32

https://github.com/HWHardsoft/COVID19-Tracker-Arduino-MKR

Lizenz 

Diese Bibliothek ist freie Software; Sie können sie unter den Bedingungen der GNU (Lesser General Public License), wie sie von der Free Software Foundation veröffentlicht wurde, weitergeben und/oder modifizieren; entweder in der Version 2.1 der Lizenz oder (nach Ihrer Wahl) in jeder späteren Version.

Diese Bibliothek wird in der Hoffnung verteilt, dass sie nützlich sein wird, aber OHNE JEDE GARANTIE; sogar ohne die implizite Garantie der MARKTGÄNGIGKEIT oder der EIGNUNG FÜR EINEN BESTIMMTEN ZWECK. Sehen Sie die GNU Lesser General Public License für weitere Einzelheiten.

DisplaysEsp-32Projekte für anfänger

107 Kommentare

Eckehard Schaefer

Eckehard Schaefer

Sehr geehrte Damen und Herren,
ich hätte das gerne erworben, finde aber nicht den Preis noch eine Bestellmöglichkeit.
Mit freundlichem Gruß.
Eckehard Schaefer

Juergen Gille

Juergen Gille

Hallo
Der Projekt-Beitrag ist ja interessant, ABER könnt Ihr bitte auch noch den dazugehörigen Sketch veröffentlichen!

Reinhard Bruckner

Reinhard Bruckner

Prima Idee.
Aber wo ist der Source-Code??

Volker

Volker

nette Idee, nur wo ist denn der Link zum Programm??
LG
Volker

mike

mike

Kann es sein das der eigentliche sourcecode fehlt?
Hardware klar
Bibliotheken klar
Modifikationen (welche Länder) am source klar
Aber wo findet sich der source code?

Wolfgang Prinz

Wolfgang Prinz

Schöne Idee!
Kann es sein, dass der Link zur eigentlichen Software fehlt, die die Daten von der Worldometer Webseite liest und aufbereitet?

Matthias

Matthias

Hallo, interessante Idee und schöne Ausnutzung vorhandener Ressourcen. Ich vermisse nur den Code für den Sketch selbst, das Filtern der Daten von der Webseite ist der algorithmisch interessanteste Teil :-)

Einen Kommentar hinterlassen

Alle Kommentare werden vor der Veröffentlichung moderiert

Empfohlene Blogbeiträge

  1. ESP32 jetzt über den Boardverwalter installieren
  2. Lüftersteuerung Raspberry Pi
  3. Arduino IDE - Programmieren für Einsteiger - Teil 1
  4. ESP32 - das Multitalent
  5. OTA - Over the Air - ESP Programmieren über WLAN