mitglieder, vorstand
1.688
Bearbeitungen
Dg3hda (Diskussion | Beiträge) (→Code) |
Dg3hda (Diskussion | Beiträge) Keine Bearbeitungszusammenfassung |
||
Zeile 1: | Zeile 1: | ||
= Übersicht = | = Übersicht = | ||
Es wird beschrieben wie man mit einem NodeMCU-(Clone)-Board, WLAN, | Es wird beschrieben wie man mit einem auf dem ESP8266 "IoT Chip" basierenden NodeMCU-(Clone)-Board, WLAN, und etwas LED-Zauberei den Zustand des Space in sein Wohnzimmer holen kann. Es gibt zwei Varianten des Codes, eine für eine RGB-LED direkt an der GPIO des ESP-Moduls, eine andere verwendet eine LED mit eingebautem adressierbaren Treiber WS2812, welche die zuletzt gewählten Helligkeits- und Farbeinstellungen speichert und das etwas energiehungrigere ESP-Modul zwischen den Abfragen in den Sleepmodus versetzt wird. | ||
=== Ansprechpartner === | === Ansprechpartner === | ||
Zeile 14: | Zeile 14: | ||
===Funktionsweise Hardware=== | ===Funktionsweise Hardware=== | ||
Mit RGB-LED: | |||
Die GPIO Pins sind über 330 Ohm - Widerstände mit einer RGB-LED (common cathode) verbunden, wobei GPIO Port 0 (Nodemcu D3) die Rote versorgt, Port 4 (Nodemcu D2)die Blaue. LED-Kathode ist normal mit GND verbunden. Wer will kann noch die Grüne mit GPIO 5 (nodemcu D1) verbinden. | |||
Mit WS2812 "intelligenter LED": | |||
Die Versorgungsspannung erhält die (einzelne) WS2812 aus dem 3.3V Regler des ESP-Moduls, Port 15 (nodemcu D8)sendet die Daten zum DI-Eingang der LED. GND ist GND. Achtung, WS2812 nicht mit 5V versorgen, der IO des ESP8266 zuliebe! Selbst wenn es nicht zurückwirkt, bekäme der ESP wohl kaum den logischen HI-Pegel hin. GPIO16 (nodemcu D0) wird mit dem RST-Eingang verbunden, um das wiederaufwachen nach dem Ende des Sleepmode zu ermöglichen. Das Programm mit Sleepmode hat noch eine "grace period" von ca. 45s, in der das Modul vor dem Sleepmodus ansprechbar bleibt um z.B. Änderungen durchzuführen. | |||
===Funktionsweise Software=== | ===Funktionsweise Software=== | ||
Das Programm ruft zeitgesteuert den Zustand von http://status.schaffenburg.org ab, schaut ob das erste Zeichen ein "v" für verriegelt ist. | Das Programm ruft zeitgesteuert den Zustand von http://status.schaffenburg.org ab, schaut ob das erste Zeichen ein "v" für verriegelt ist. | ||
Abhängig von der LED-Variante wird nun durch die LED-Farbe der Zustand des Space gemeldet: | |||
* ROT: Tür verriegelt | |||
* GRÜN: Tür offen | |||
Dazu kommt zeitweise noch Weiß: Das sagt nichts über den Space. Es bedeutet: Abfrage läuft. Bei Sleepmode-Variante gibt es einen Blauschimmer während der grace period WLAN ansprechbar. | |||
==Code== | ==Code== | ||
Der folgende Code ist mit ESP8266BASIC Version 2.0 Alpha 10 lauffähig. Voraussetzung ist das korrekte eintragen der Zugangsdaten als WLAN-Client und Freigabe für Internetzugriff. Ich habe dem Client nur Whitelistzugriff gegeben um ihn von anderen Websites fernzuhalten (damit er kein PR0N schaut) und hausintern einen DNS-Namen gegeben, um ihn nicht nur mit der IP-Adresse ansprechen zu können. Das Wiedernachschau-Intervall ist 5 Minuten, aber der Timer erschien mir bisher ein bischen flaky. | Der folgende Code ist mit ESP8266BASIC Version 2.0 Alpha 10 lauffähig. Voraussetzung ist das korrekte eintragen der Zugangsdaten als WLAN-Client und Freigabe für Internetzugriff. Ich habe dem Client nur Whitelistzugriff gegeben um ihn von anderen Websites fernzuhalten (damit er kein PR0N schaut) und hausintern einen DNS-Namen gegeben, um ihn nicht nur mit der IP-Adresse ansprechen zu können. Das Wiedernachschau-Intervall ist ~5 Minuten, aber der Timer erschien mir bisher ein bischen flaky. | ||
Dieser Code ist für ein ESP8266 ohne WS2812. | Dieser Code ist für ein ESP8266 ohne WS2812. | ||
Zeile 31: | Zeile 44: | ||
[service] | [service] | ||
po 4 1 | |||
po 5 1 | |||
po 0 1 | |||
pcount=pcount+1 | pcount=pcount+1 | ||
cls | cls | ||
Status = left(wget("status.schaffenburg.org/"),1) | Status = left(wget("status.schaffenburg.org/"),1) | ||
if Status == "v" then po 0 1 else po 0 0 | if Status == "v" then po 0 1 else po 0 0 | ||
if Status == "v" then po 5 0 else po 5 1 | |||
if Status == "v" then wprint "Geschlossen" else wprint "Offen" | if Status == "v" then wprint "Geschlossen" else wprint "Offen" | ||
if Status == "v" then tdown = tzu else tdown=toffen | if Status == "v" then tdown = tzu else tdown=toffen | ||
print pcount | print pcount | ||
po 4 0 | |||
timer tdown,[service] | timer tdown,[service] | ||
wait | wait | ||
</pre> | </pre> | ||
Dieser Code verwendet den Sleepmode des ESP8266, die WS2812 LED leuchtet dann anhand der letzten Vorgabe weiter. Der Stromverbrauch incl. des integrierten Spannungsregler auf dem AMICA-Board ist ca. 100 mA wenn aktiv, ca. 20 mA im Sleepmode des ESP8266, wenn die LED weiter leuchtet. | Dieser Code verwendet den Sleepmode des ESP8266, die WS2812 LED leuchtet dann anhand der letzten Vorgabe weiter. Der Stromverbrauch incl. des integrierten Spannungsregler auf dem AMICA-Board ist ca. 100 mA wenn aktiv, ca. 20 mA im Sleepmode des ESP8266, wenn die LED weiter leuchtet. |