8.9 Blynk-basiertes Einbruchmeldesystem¶
Dieses Projekt demonstriert ein einfaches Einbruchmeldesystem für Zuhause, das einen PIR-Bewegungssensor (HC-SR501) nutzt. Wenn das System über die Blynk-App auf den Modus „Abwesend“ eingestellt ist, überwacht der PIR-Sensor Bewegungen. Jede erkannte Bewegung löst eine Benachrichtigung in der Blynk-App aus, die den Benutzer über einen möglichen Einbruch informiert.
Benötigte Komponenten
Für dieses Projekt benötigen wir die folgenden Komponenten.
Es ist definitiv praktisch, ein ganzes Kit zu kaufen. Hier ist der Link:
Name |
ARTIKEL IN DIESEM KIT |
LINK |
---|---|---|
ESP32 Starter Kit |
320+ |
Sie können sie auch separat über die untenstehenden Links kaufen.
KOMPONENTENVORSTELLUNG |
KAUF-LINK |
---|---|
- |
|
1. Schaltungs-Zusammenbau¶
2. Blynk-Konfiguration¶
2.1 Blynk-Initialisierung
Navigieren Sie zur BLYNK und wählen Sie START FREE.
Geben Sie Ihre E-Mail-Adresse ein, um den Registrierungsprozess zu starten.
Bestätigen Sie Ihre Registrierung per E-Mail.
Nach der Bestätigung erscheint die Blynk Tour. Es wird empfohlen, „Überspringen“ zu wählen. Erscheint auch Quick Start, überlegen Sie, auch dies zu überspringen.
2.2 Template-Erstellung
Erstellen Sie zunächst ein Template in Blynk. Folgen Sie den nachfolgenden Anweisungen, um das Template Intrusion Alert System zu erstellen.
Geben Sie dem Template einen Namen, wählen Sie als Hardware ESP32 und als Connection Type WiFi, dann wählen Sie Done.
2.3 Generierung von Datenströmen
Öffnen Sie das gerade erstellte Template, um zwei Datenströme zu erstellen.
Klicken Sie auf New Datastream.
Wählen Sie im Popup Virtual Pin aus.
Benennen Sie den Virtual Pin V0 als AwayMode. Setzen Sie den DATA TYPE auf Integer mit den MIN- und MAX-Werten 0 und 1.
Erstellen Sie ähnlich einen weiteren Virtual Pin-Datenstrom. Benennen Sie ihn Current Status und setzen Sie den DATA TYPE auf String.
2.4 Einrichten eines Ereignisses
Als Nächstes richten wir ein Ereignis ein, das eine E-Mail-Benachrichtigung sendet, wenn ein Einbruch erkannt wird.
Klicken Sie auf Add New Event.
Definieren Sie den Namen des Ereignisses und dessen spezifischen Code. Wählen Sie für TYPE Warning und schreiben Sie eine kurze Beschreibung für die E-Mail, die gesendet werden soll, wenn das Ereignis eintritt. Sie können auch einstellen, wie oft Sie benachrichtigt werden.
Gehen Sie zum Abschnitt Notifications, um Benachrichtigungen zu aktivieren und E-Mail-Details einzurichten.
2.5 Feinabstimmung des Web-Dashboards
Es ist wichtig, dass das Web Dashboard perfekt mit dem Einbruchmeldesystem interagiert.
Ziehen Sie einfach sowohl das Switch widget als auch das Label widget auf das Web Dashboard.
Wenn Sie mit der Maus über ein Widget fahren, erscheinen drei Symbole. Verwenden Sie das Einstellungssymbol, um die Eigenschaften des Widgets anzupassen.
In den Einstellungen des Switch widget wählen Sie Datastream als AwayMode(V0). Setzen Sie ONLABEL und OFFLABEL auf „away“ bzw. „home“.
In den Einstellungen des Label widget wählen Sie Datastream als Current Status(V1).
2.6 Speichern des Templates
Vergessen Sie zum Schluss nicht, Ihr Template zu speichern.
2.7 Erstellen eines Geräts
Jetzt ist es an der Zeit, ein neues Gerät zu erstellen.
Klicken Sie auf From template, um mit einer neuen Einrichtung zu beginnen.
Wählen Sie dann das Template Intrusion Alert System und klicken Sie auf Create.
Hier sehen Sie die
Template ID
, denDevice Name
und denAuthToken
. Sie müssen diese in Ihren Code kopieren, damit der ESP32 mit Blynk arbeiten kann.
3. Codeausführung¶
Bevor Sie den Code ausführen, stellen Sie sicher, dass Sie die
Blynk
-Bibliothek über den Library Manager in der Arduino IDE installiert haben.Öffnen Sie die Datei
iot_9_intrusion_alert_system.ino
, die sich im Verzeichnisesp32-starter-kit-main\c\codes\iot_9_intrusion_alert_system
befindet. Sie können auch deren Inhalt in die Arduino IDE kopieren.Ersetzen Sie die Platzhalter für
BLYNK_TEMPLATE_ID
,BLYNK_TEMPLATE_NAME
undBLYNK_AUTH_TOKEN
mit Ihren eigenen einzigartigen IDs.#define BLYNK_TEMPLATE_ID "TMPxxxxxxx" #define BLYNK_TEMPLATE_NAME "Intrusion Alert System" #define BLYNK_AUTH_TOKEN "xxxxxxxxxxxxx"
Geben Sie auch die
ssid
und daspassword
Ihres WLAN-Netzwerks ein.char ssid[] = "your_ssid"; char pass[] = "your_password";
Wählen Sie das richtige Board (ESP32 Dev Module) und den Port, und klicken Sie dann auf den Upload-Button.
Öffnen Sie den Seriellen Monitor (Baudrate auf 115200 einstellen) und warten Sie auf eine erfolgreiche Verbindungsmeldung.
Nach einer erfolgreichen Verbindung startet das Aktivieren des Schalters in Blynk die Überwachung des PIR-Moduls. Wenn eine Bewegung erkannt wird (Zustand 1), wird „Jemand ist hier!“ angezeigt und eine Warnung an Ihre E-Mail gesendet.
4. Code-Erklärung¶
Konfiguration & Bibliotheken
Hier richten Sie die Blynk-Konstanten und Zugangsdaten ein. Sie schließen auch die notwendigen Bibliotheken für den ESP32 und Blynk ein.
/* Comment this out to disable prints and save space */ #define BLYNK_PRINT Serial #define BLYNK_TEMPLATE_ID "xxxxxxxxxxx" #define BLYNK_TEMPLATE_NAME "Intrusion Alert System" #define BLYNK_AUTH_TOKEN "xxxxxxxxxxxxxxxxxxxxxxxxxxx" #include <WiFi.h> #include <WiFiClient.h> #include <BlynkSimpleEsp32.h>
WiFi-Einrichtung
Geben Sie Ihre WLAN-Zugangsdaten ein.
char ssid[] = "your_ssid"; char pass[] = "your_password";
PIR-Sensor-Konfiguration
Legen Sie den Pin fest, an dem der PIR-Sensor angeschlossen ist, und initialisieren Sie die Zustandsvariablen.
const int sensorPin = 14; int state = 0; int awayHomeMode = 0; BlynkTimer timer;
setup() Funktion
Diese Funktion initialisiert den PIR-Sensor als Eingang, richtet die serielle Kommunikation ein, verbindet sich mit WLAN und konfiguriert Blynk.
Wir verwenden
timer.setInterval(1000L, myTimerEvent)
um das Timer-Intervall insetup()
zu setzen. Hier legen wir fest, dass die FunktionmyTimerEvent()
alle 1000ms ausgeführt wird. Sie können den ersten Parameter vontimer.setInterval(1000L, myTimerEvent)
ändern, um das Intervall zwischen den Ausführungen vonmyTimerEvent
zu variieren.
void setup() { pinMode(sensorPin, INPUT); // Set PIR sensor pin as input Serial.begin(115200); // Start serial communication at 115200 baud rate for debugging // Configure Blynk and connect to WiFi Blynk.begin(BLYNK_AUTH_TOKEN, ssid, pass); timer.setInterval(1000L, myTimerEvent); // Setup a function to be called every second }
loop() Funktion
Die loop-Funktion führt kontinuierlich Blynk und die Blynk-Timer-Funktionen aus.
void loop() { Blynk.run(); timer.run(); }
Blynk-App-Interaktion
Diese Funktionen werden aufgerufen, wenn das Gerät sich mit Blynk verbindet und wenn sich der Zustand des virtuellen Pins V0 in der Blynk-App ändert.
Jedes Mal, wenn das Gerät sich mit dem Blynk-Server verbindet oder aufgrund schlechter Netzwerkbedingungen erneut verbindet, wird die Funktion
BLYNK_CONNECTED()
aufgerufen. Der BefehlBlynk.syncVirtual()
fordert einen einzelnen virtuellen Pinwert an. Der angegebene virtuelle Pin führt einenBLYNK_WRITE()
-Aufruf durch.Immer wenn sich der Wert eines virtuellen Pins auf dem BLYNK-Server ändert, wird
BLYNK_WRITE()
ausgelöst.
// This function is called every time the device is connected to the Blynk.Cloud BLYNK_CONNECTED() { Blynk.syncVirtual(V0); } // This function is called every time the Virtual Pin 0 state changes BLYNK_WRITE(V0) { awayHomeMode = param.asInt(); // additional logic }
Datenverarbeitung
Jede Sekunde ruft die Funktion
myTimerEvent()
die FunktionsendData()
auf. Wenn der Abwesenheitsmodus in Blynk aktiviert ist, überprüft sie den PIR-Sensor und sendet eine Benachrichtigung an Blynk, wenn eine Bewegung erkannt wird.Wir verwenden
Blynk.virtualWrite(V1, "Jemand in Ihrem Haus! Bitte überprüfen!");
um den Text eines Labels zu ändern.Verwenden Sie
Blynk.logEvent("intrusion_detected");
, um ein Ereignis in Blynk zu protokollieren.
void myTimerEvent() { sendData(); } void sendData() { if (awayHomeMode == 1) { state = digitalRead(sensorPin); // Read the state of the PIR sensor Serial.print("state:"); Serial.println(state); // If the sensor detects movement, send an alert to the Blynk app if (state == HIGH) { Serial.println("Somebody here!"); Blynk.virtualWrite(V1, "Somebody in your house! Please check!"); Blynk.logEvent("intrusion_detected"); } } }
Referenz