6. Pflanzenüberwachung

Das Ziel dieses Projekts ist es, ein intelligentes Bewässerungssystem zu erstellen, das die aktuelle Temperatur, Luftfeuchtigkeit, Lichtintensität und Bodenfeuchtigkeit erkennt und diese auf Blynk anzeigt.

Sobald Sie den Schalter in der Blynk Cloud umlegen, beginnt die Pumpe zu arbeiten und die Pflanzen werden bewässert.

Benötigte Komponenten

Für dieses Projekt benötigen wir die folgenden Komponenten.

Es ist definitiv praktisch, ein ganzes Set zu kaufen, hier ist der Link:

Name

ARTIKEL IN DIESEM SET

LINK

3 in 1 Starter Kit

380+

3 in 1 Starter Kit

Sie können diese auch separat über die untenstehenden Links kaufen.

KOMPONENTENVORSTELLUNG

KAUF-LINK

SunFounder R3 Platine

BUY

Breadboard

BUY

ESP8266 Modul

BUY

Jumper-Kabel

BUY

Widerstand

BUY

Fotowiderstand

BUY

DHT11 Feuchtigkeits- und Temperatursensor

-

Bodenfeuchtigkeitsmodul

BUY

L298N Modul

BUY

Kreiselpumpe

-

1. Schaltung aufbauen

Bemerkung

Das ESP8266-Modul benötigt einen hohen Strom, um eine stabile Betriebsumgebung zu gewährleisten. Stellen Sie also sicher, dass die 9V-Batterie angeschlossen ist.

../_images/wiring_soil_pump.jpg

2. Dashboard bearbeiten

  1. Die in den vorherigen Projekten erstellten Datenströme müssen gespeichert werden und werden auch in diesem Projekt verwendet.

  2. Zur Aufzeichnung der Bodenfeuchtigkeit erstellen Sie einen weiteren Datastream vom Typ Virtual Pin auf der Datastream-Seite. Stellen Sie den DATENTYP auf Integer und MIN und MAX auf 0 und 1024.

    ../_images/sp220610_155221.png
  3. Gehen Sie nun zur Wed Dashboard-Seite, ziehen Sie 2 Label-Widgets und setzen Sie ihre Datenströme auf V4 bzw. V5; ziehen Sie 2 Gauge-Widgets und setzen Sie ihre Datenströme auf V6 und V7; ziehen Sie zuletzt ein Switch-Widget und setzen Sie dessen Datenstrom auf V0.

    ../_images/sp220610_155350.png

3. Code ausführen

Öffnen Sie die Datei 6.plant_monitoring.ino unter dem Pfad 3in1-kit\iot_project\6.plant_monitoring oder kopieren Sie diesen Code in die Arduino IDE.

Bemerkung

  • Hier wird die DHT sensor library verwendet. Sie können sie über den Library Manager installieren.

    ../_images/lib_dht11.png
  1. Ersetzen Sie die Template ID, den Gerätenamen und den Auth Token durch Ihre eigenen Angaben. Geben Sie auch die ssid und das Passwort des von Ihnen verwendeten WLANs ein. Für detaillierte Anleitungen verweisen Sie bitte auf 1.4 Verbindung des R3-Boards mit Blynk herstellen.

  2. Nach Auswahl des richtigen Boards und Ports klicken Sie auf die Schaltfläche Upoad.

  3. Öffnen Sie den Serienmonitor (Baudrate auf 115200 einstellen) und warten Sie auf eine Aufforderung, wie z.B. eine erfolgreiche Verbindung.

    ../_images/2_ready.png

    Bemerkung

    Wenn die Meldung ESP antwortet nicht erscheint, wenn Sie sich verbinden, folgen Sie bitte diesen Schritten.

    • Stellen Sie sicher, dass die 9V-Batterie angeschlossen ist.

    • Setzen Sie das ESP8266-Modul zurück, indem Sie den Pin RST für 1 Sekunde mit GND verbinden und dann trennen.

    • Drücken Sie den Reset-Knopf auf dem R3-Board.

    Manchmal müssen Sie die oben genannte Operation 3-5 Mal wiederholen. Bitte haben Sie Geduld.

  4. Zurück zu Blynk, Sie sehen die aktuelle Temperatur, Luftfeuchtigkeit, Lichtintensität und Bodenfeuchtigkeit. Sie können die Pumpe die Pflanzen bewässern lassen, falls notwendig, indem Sie das Button Control-Widget anklicken.

    ../_images/sp220610_155350.png
  5. Wenn Sie Blynk auf mobilen Geräten verwenden möchten, verweisen Sie bitte auf Wie verwendet man Blynk auf einem mobilen Gerät?.

    ../_images/mobile_plant.jpg

Wie funktioniert das?

Dieses BLYNK_WRITE bewirkt, dass Blynks Switch-Widget die Pumpe startet, wenn es EIN ist und sie ausschaltet, wenn es AUS ist.

BLYNK_WRITE(V0)
{
    if(param.asInt()==1){
        digitalWrite(pumpA,HIGH);
    }else{
        digitalWrite(pumpA,LOW);
    }
}

Diese drei Funktionen werden verwendet, um die aktuelle Umgebungstemperatur, Luftfeuchtigkeit, Lichtintensität und Bodenfeuchtigkeit zu erhalten.

int readMoisture(){
    return analogRead(moisturePin);
}

int readLight(){
    return analogRead(lightPin);
}

bool readDHT() {

    // Reading temperature or humidity takes about 250 milliseconds!
    // Sensor readings may also be up to 2 seconds 'old' (it's a very slow sensor)
    humidity = dht.readHumidity();
    // Read temperature as Celsius (the default)
    temperature = dht.readTemperature();

    // Check if any reads failed and exit early (to try again).
    if (isnan(humidity) || isnan(temperature)) {
        Serial.println("Failed to read from DHT sensor!");
        return false;
    }
    return true;
}

Mit dem Blynk Timer werden die Umgebungstemperatur, Luftfeuchtigkeit, Lichtintensität und Bodenfeuchtigkeit jede Sekunde abgerufen und an den Datenstrom auf der Blynk Cloud gesendet, von dem aus die Widgets die Daten anzeigen.

void myTimerEvent()
{
    bool chk = readDHT();
    int light = readLight();
    int moisture = readMoisture();
    if(chk){
        Blynk.virtualWrite(V4,humidity);
        Blynk.virtualWrite(V5,temperature);
    }
    Blynk.virtualWrite(V6,light);
    Blynk.virtualWrite(V7,moisture);
}