Projekt:SpaceLED

Aus Schaffenburg
Zur Navigation springen Zur Suche springen

Übersicht

Es wird beschrieben wie man mit einem NodeMCU-(Clone)-Board, WLAN, drei Widerständen und einer RGB-LED den Zustand des Space in sein Wohnzimmer holen kann. Sofern die Schaltung mit Strom und WLAN-Internetzugang versorgt wird ist sie aus, wenn der Space offen ist, oder rot, wenn ers nicht ist. Während des Update leuchtet sie blau.

Ansprechpartner

Hendrik

SpaceLED

Artikel in Arbeit

ESP8266BASIC

Mein NodeMCU habe ich der guten alten Zeit willen mit ESP8266BASIC beladen. Wie es geht, steht auf deren Website.

Funktionsweise Hardware

Zwei Pins sind über Widerstände mit einer RGB-LED verbunden, wobei Port 0 die Rote versorgt, Port 4 die Blaue. Masse ist normal mit GND verbunden.

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. Wird der Space offen gemeldet, wird der Port an dem die rote LED hängt LO geschaltet, wird der Space verriegelt gemeldet, so wird der Pin high.

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.

Dieser Code ist für ein ESP8266 ohne WS2812.

let pcount = 0
let toffen = 300000
let tzu = 300000
timer 100,[service]
wait

[service]
pcount=pcount+1
cls
Status = left(wget("status.schaffenburg.org/"),1)
if Status == "v" then po 0 1 else po 0 0
if Status == "v" then wprint "Geschlossen" else wprint "Offen"
if Status == "v" then tdown = tzu else tdown=toffen
print pcount
timer tdown,[service]
wait

Und der für ESP8266 mit Unterstützung durch WS2812l, ohne Stromsparmodus. Achtung: Bitte mit 3.3V betreiben den Pixel, der GPIO zuliebe!

let pcount = 0
let toffen = 30000
let tzu = 30000
timer 100,[service]
wait

[service]
neo(0,25,25,25)
pcount=pcount+1
cls
Status = left(wget("status.schaffenburg.org/"),1)
if Status == "v" then neo(0,25,0,0) else neo(0,0,25,0)
if Status == "v" then wprint "Geschlossen" else wprint "Offen"
if Status == "v" then tdown = tzu else tdown=toffen
print pcount

timer tdown,[service]
wait

Lesestoff

Projekttagebuch:

  • 25.04.2016: Projektseite angefangen. Mangels Steckkontakten ist der grüne Die noch nicht angeschlossen und wird auch nicht angesteuert.
  • 30.04.2016 : Code buggy
  • 01.05.2016 : Code wieder ganz, Wifi-Down funktioniert. Geht immer nur ein Timer. Stromersparnis ist eher flach, Netzteil meint statt ~114 mA eher 104 mA anzuliefern (schwankend.) Next step: Schauen ob es GPIOs gibt die im Sleepmode Zustand halten, wenn nicht: WS2812 "Programmierbare LED" oder dergleichen, die während des ESP8266-Sleepmode weiter das letzte Kommando ausführt.
  • 02.05.2016: WS2812-Band geordert!
  • 04.05.2016: Code aufgeräumt, überflüssige Stromersparnis beseitigt.