E-Ink Display mit ESPHome und Home Assistant steuern (ESP32)

Schon etwas lรคnger hatte ich mir vorgenommen ein E-Ink Display mit ESPHome zu steuern, um ein individuelles Dashboard umzusetzen. Dieses Smart Home Dashboard kann dann nahezu beliebig platziert werden.

Warum wรผrde man ein Dashboard bauen wollen, welches jederzeit gewisse Smart Home Zustรคnde anzeigt? Nun, wie bereits mehrfach ausgefรผhrt, ist unser Smart Home mehr als nur die Schaltzentrale diverser Gerรคte. Vielmehr laufen in unserem Smart Home unterschiedlichste Informationen zusammen, um diese dann beliebig nutzen zu kรถnnen.

Unser Smart Home sagt uns, wenn es eine neue Sendung in der DHL Packstation gibt, oder wie lange der Weg zur Arbeit circa dauern wird. Ebenso weiรŸ unser Smart Home, wann welche Mรผlltonne abgeholt wird.

Lange Rede, kurzer Sinn: In unserem Smart Home (Home Assistant), laufen sehr viele Informationen zusammen. Um diese Informationen bei Bedarf abzurufen, nervt es mich aber, jedes mal mein Handy in die Hand nehmen zu mรผssen. Warum kann ich mir gewisse Informationen nicht einfach auf einem nicht allzu viel Strom verbrauchenden Display anzeigen lassen?

Du magst Home Assistant? Dann abonniere kostenlos meine Beitrรคge mit Tipps, Tricks und Anleitungen rund um Home Assistant:

Follow Home Assistant
( 424 Followers )
X

Follow Home Assistant

E-mail : *
* Ich stimme der Datenschutzerklรคrung zu!

Garantiert kein Spam, keine Werbung und immer mit Abmelde-Link, solltest du es dir anders รผberlegen!

Folgende Produkte benรถtigst du fรผr den Nachbau:

AZDelivery 3 x ESP32 NodeMCU Module WLAN WiFi Dev Kit C...
AZDelivery 3 x ESP32 NodeMCU Module WLAN WiFi Dev Kit C...*
โœ… Leistungsfรคhiger ESP32-Microcontroller verbaut! Absolute Neuheit am Markt!
24,99 EUR Amazon Prime

ESPHome in Home Assistant

Der ESP32 ist wohl der bekannteste, kostengรผnstige Microcontroller, mit welchem sich ideal kleinere Bastel-Technik-Projekte umsetzen lassen (Wikipedia: ESP32).

Mittels ESPHome kann wird die Integration dieser „Bastel-Projekte“ in Home Assistant denkbar einfach!

Normal muss man mittels eines Flashers speziell fรผr den ESP32 kompilierte Software auf den Microcontroller aufspielen und kann diesen dann erst nutzen.

Mit ESPHome genรผgt es, einmalig eine OTA (Over-The-Air – also WLAN) Verbindung zwischen dem ESP-Microvontroller und Home Assistant herzustellen, und schon kann man aus Home Assistant heraus beliebige Updates, also Software-Anpassungen an den ESP32 per WLAN schicken.

Die Integration in Home Assistant ermรถglicht nicht unbedingt mehr Mรถglichkeiten, aber sie macht das Setup deutlich einfacher! Kein umstรคndliches Weitergeben der Daten รผber MQTT (oder รคhnlich) mehr. Einfach mit ESPHome einrichten, und schon kann das Bastel-Projekt in beide Richtungen von Home Assistant genutzt werden (also beispielweise Daten vom ESP32 auslesen oder/und Daten an den ESP senden).

Und wie man Daten an den ESP32 sendet, erklรคre ich hier an des Beispiels des E-Ink Display mit ESPHome, mit welchem ich mir ein Dashboard-Display baue!

Eine wesentliche Sache noch zu den ESP32-Controllern: Hier gibt es nennenswerte Unterschiede, was die Beschaffenheit und Qualitรคt der Boards angeht!

Viele schwรถren darauf, die Boards bei AliExpress oder รคhnlichen Seiten zu bestellen. Klar, die Preise sind in der Regel unschlagbar gรผnstig, aber man wartet halt auch teilweise sehr lange (nicht selten mehrere Wochen). Und eigentlich will man doch so schnell wie mรถglich loslegen… ๐Ÿ˜‰

Darรผber hinaus, habe ich es auch schon mehrfach erlebt, dass bei solchen Bestellungen die Boards zwar irgendwann ankam, jedoch in Einzelteile zerlegt war: Mal was das WLAN-Modul nicht verlรถtet und nahezu immer waren eigentlich die „Pins“ nicht angelรถtet.

Ich weiรŸ nicht wie regelmรครŸig du lรถtest, aber ich bin da wahrlich kein Profi drin. Und so etwas erschwert dann das Bastelprojekt in meinen Augen unnรถtig, weshalb ich die ESP32-Controller mittlerweile auch bei Amazon kaufe. Dies hat zwei wesentliche Vorteile: Die Ware ist in wenigen Tagen da und (sofern man die richtigen kauft) auch gleich einsatzbereit:

In den letzten Monaten habe ich sehr gute Erfahrungen mit den Boards vom Hรคndler AZ-Delivery gemacht. Hier im 3er-Pack, wodurch je Stรผck noch ca. 6 โ‚ฌ anfallen:

AZDelivery 3 x ESP32 NodeMCU Module WLAN WiFi Dev Kit C...*
  • โœ… Leistungsfรคhiger ESP32-Microcontroller verbaut! Absolute Neuheit...
  • โœ… Komfortables Prototyping durch einfache Programmierung per...

Bei dieser Variante habe ich bislang immer sofort einsatzbereite Controller erhalten, weshalb ich die Boards absolut empfehle!

E-Ink Display Waveshare 7,5 Inch

Um ein E-Ink Display mit ESPHome aus Dashboard fรผr unser Smarthome zu nutzen, habe ich auf ein bereits in meinem Besitz befindliches E-Ink Display zurรผckgreifen kรถnnen. Vor einigen Monaten wollte ich einmal ein Projekt von heise nachbauen und hatte mir hierfรผr ein Waveshare 7.5 Inch E-Ink Display gekauft.

Zu dem Projekt bin ich nie gekommen, dafรผr konnte ich das Display nun aber sinnvoll nutzen! ๐Ÿ˜‰

Natรผrlich kann man auch ein kleineres Display nehmen – aber ich persรถnlich mรถchte relativ viele Informationen/Daten anzeigen. Und damit dies nicht zu unรผbersichtlich wird, bevorzuge ich ein grรถรŸeres Display:

Der Vorteil bei diesem Display ist, dass alles dabei ist, was man zum Anschluss an den ESP32-Controller benรถtigt!

Waveshare 7.5 Inch E-Paper Display Hat Module V2 Kit 800x480...*
  • Note:Version 2 please use corresponding demo code in wiki.This is an...

E-Ink an ESP32 anschlieรŸen

Wenn du alle Teile beisammen hast (also eigentlich nur ein ESP32-Board sowie ein Waveshare 7.5 Inch E-Ink Display), kannst du alles miteinander verbinden.

Fรผr einen Proof of Concept sind die Steckverbindungen perfekt, da alles in wenigen Minuten miteinander verbunden ist!

Ich habe das E-Ink Display wie folgt angeschlossen, so dass diese Pin-Belegung auch fรผr dich passend sein dรผrfte:

ESP32E-Ink Display
G4Busy
G21RST
G22DC
G23DIN
G5CS
G16CLK
GNDGND
3V33V3

Bitte vergewissere dich, dass diese Zuordnung auch fรผr dich zutreffend ist. Es ist mรถglich, dass sich unsere genutzten Komponenten technisch unterscheiden!

E-Ink Display mit ESPHome
E-Ink Display mit ESPHome und Home Assistant

ESPHome Node einrichten

Um den ESP32 nun einzurichten, kannst du grundsรคtzlich dem Wizzard in Home Assistant folgen. Dieser fragt dich nach den relevanten Angaben. Diese werden letztlich in einer YAML-Datei gespeichert, so dass du diese auch im Nachgang noch korrigieren/anpassen kannst!

Wichtig ist jedoch, dass du zusรคtzlich zu dem Wizzard auch noch in Home Assistant deinen ESP32 als Integration hinzufรผgen musst. Erst hierdurch erlangt die API ihre Funktionalitรคt, so dass der ESP auch Zugriff auf die Zustรคnde deiner Entitรคten in Home Assistant hat!

Hierfรผr gehst du รผber Einstellungen -> Integrationen -> Integration hinzufรผgen und suchst nach ESPHome. Im sich รถffnenden Dialog gibst du die IP-Adresse (Host) deines neuen ESPs ein.

Hast du die beschriebenen Schritte befolgt, kannst du mit der „Programmierung“ deines E-Ink Display mit ESPHome loslegen. Hier eine Vorschau, was nun mit wenigen Zeilen Code mรถglich ist:

Und hier noch, als eine Art Inspiration, ein Auszug des von mir genutzten Codes:

esphome:
  name: esp32-eink
  platform: ESP32
  board: lolin_d32

wifi:
  ssid: "WLAN-SSID"
  password: "PASSWORD"

  # Enable fallback hotspot (captive portal) in case wifi connection fails
  ap:
    ssid: "Esp32-Eink Fallback Hotspot"
    password: "Password2"

captive_portal:

# Enable logging
logger:

# Enable Home Assistant API
api:
  password: "Password3"

ota:
  password: "Password4"
  
font:
  - file: 'fonts/GoogleSans-Bold.ttf'
    id: status_font
    size: 18
    glyphs:
      ['&', '@', '!', '?', ',', '.', '"', '%', '(', ')', '+', '-', '_', ':', 'ยฐ', '0',
       '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E',
       'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S',
       'T', 'U', 'V', 'W', 'X', 'Y', 'Z', ' ', 'a', 'b', 'c', 'd', 'e', 'f',
       'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't',
       'u', 'v', 'w', 'x', 'y', 'z', 'รฅ', 'รค', 'รถ', 'รผ', 'ร„', 'ร–', 'รœ', '/', 'โ‚ฌ', 'โ€™', 'รŸ']
  - file: 'fonts/GoogleSans-Bold.ttf'
    id: watch_font
    size: 90
    glyphs:
      [':', ".", '0', '1', '2', '3', '4', '5', '6', '7', '8', '9']
  - file: 'fonts/materialdesignicons-webfont.ttf'
    id: icon_font
    size: 32
    glyphs: [
     '๓ฐ ฆ', #mdi-home-account
     '๓ฑ', #mdi-home-circle-outline
     '๓ฑƒ', #mdi-storefront-outline
     '๓ฐฆ‘', #mdi-office-building
     '๓ฐ—', #mdi-package-variant-closed
     '๓ฐšฅ', #mdi-power-plug
     '๓ฐŸŠ' #mdi-fuel
     ]
    
text_sensor:
  - platform: homeassistant
    id: dhlpin
    entity_id: sensor.dhl_pin_json
    internal: true
  - platform: homeassistant
    id: dhlpindate
    entity_id: sensor.dhl_date_json
    internal: true
  - platform: homeassistant
    id: disk_free
    entity_id: sensor.disk_free
    internal: true
  - platform: homeassistant
    id: pixel_olli
    entity_id: device_tracker.pixel_4_xl
    internal: true
  - platform: homeassistant
    id: pixel_isa
    entity_id: device_tracker.sne_lx1
    internal: true
  - platform: homeassistant
    id: travel_time_rewe
    entity_id: sensor.travel_time_rewe
    internal: true
  - platform: homeassistant
    id: travel_time_pwc
    entity_id: sensor.travel_time_pwc
    internal: true 
  - platform: homeassistant
    id: power_price
    entity_id: sensor.electricity_price_road
    internal: true
  - platform: homeassistant
    id: quote
    entity_id: sensor.myquote_quote
    internal: true
  - platform: homeassistant
    id: person
    entity_id: sensor.myquote_person
    internal: true
  - platform: homeassistant
    id: fuel_jaeger
    entity_id: sensor.tankerkoenig_jaeger_overath_e10
  - platform: homeassistant
    id: fuel_shell
    entity_id: sensor.tankerkoenig_overath_siegburger_str_e10


sensor:
  - platform: homeassistant
    id: temp
    entity_id: sensor.temperature_16
    internal: true

    
time:
  - platform: homeassistant
    id: hass_time

spi:
  clk_pin: 16
  mosi_pin: 23
  
display:
  - platform: waveshare_epaper
    id: epaper
    cs_pin: 5
    busy_pin: 4
    reset_pin: 21
    dc_pin: 22
    model: 7.50in
    update_interval: 60s
    
    lambda: |
      ESP_LOGI("display", "Updating..");
      
      //quote
      it.printf(1, 300, id(status_font), TextAlign::BOTTOM_LEFT, "%s", id(quote).state.c_str());
      it.printf(1, 330, id(status_font), TextAlign::BOTTOM_LEFT, "%s", id(person).state.c_str());
      
      it.printf(1, 60, id(status_font), TextAlign::BOTTOM_LEFT, "Diskfree: %s", id(disk_free).state.c_str());
      it.printf(1, 90, id(status_font), TextAlign::BOTTOM_LEFT, "Test-Temp: %5.1f", id(temp).state);
      
      //DHL
      it.print(1, 120, id(icon_font), TextAlign::BOTTOM_LEFT, "๓ฐ—");
      it.printf(34, 116, id(status_font), TextAlign::BOTTOM_LEFT, "(%s): %s", id(dhlpindate).state.c_str(), id(dhlpin).state.c_str());
      
      //fuel
      it.print(1, 150, id(icon_font), TextAlign::BOTTOM_LEFT, "๓ฐŸŠ");
      it.printf(34, 146, id(status_font), TextAlign::BOTTOM_LEFT, "Jaeger %s, Shell %s", id(fuel_jaeger).state.c_str(), id(fuel_shell).state.c_str());
      
      //Time
      it.strftime(380, 100, id(watch_font),TextAlign::BOTTOM_LEFT, "%H:%M", id(hass_time).now());
      it.strftime(380, 110, id(status_font),TextAlign::BOTTOM_LEFT, "%A, %d.%m.%y, KW %W", id(hass_time).now());
      it.line(380, 108, 600, 108);
      
      //User-States
      //Isa
      it.print(380, 140, id(status_font),TextAlign::BOTTOM_LEFT,"Isa");
      if(strcmp(id(pixel_isa).state.c_str(), "home") == 0) {
        it.print(380, 170, id(icon_font), TextAlign::BOTTOM_LEFT, "๓ฐ ฆ");
      } else {
        it.print(380, 170, id(icon_font), TextAlign::BOTTOM_LEFT, "๓ฑ");
      }
      it.print(410, 140, id(icon_font), TextAlign::BOTTOM_LEFT, "๓ฐฆ‘");
      it.printf(413, 168, id(status_font), TextAlign::BOTTOM_LEFT, "%s", id(travel_time_pwc).state.c_str());
      //Olli
      it.print(444, 140, id(status_font),TextAlign::BOTTOM_LEFT,"Olli");
      it.print(480, 140, id(icon_font), TextAlign::BOTTOM_LEFT, "๓ฑƒ");
      it.printf(483, 168, id(status_font), TextAlign::BOTTOM_LEFT, "%s", id(travel_time_rewe).state.c_str());
      if(strcmp(id(pixel_olli).state.c_str(), "home") == 0) {
        it.print(444, 170, id(icon_font), TextAlign::BOTTOM_LEFT, "๓ฐ ฆ");
      } else {
        it.print(444, 170, id(icon_font), TextAlign::BOTTOM_LEFT, "๓ฑ");
      }
      
      //power_price
      it.line(520, 108, 520, 170);
      it.print(522, 140, id(icon_font), TextAlign::BOTTOM_LEFT, "๓ฐšฅ");
      it.printf(550, 137, id(status_font), TextAlign::BOTTOM_LEFT, "%s โ‚ฌ", id(power_price).state.c_str());
      

Dieser Beitrag ist Teil einer kleinen Beitrags-Serie rund um den hass.io Home Assistant.

17 Gedanken zu „E-Ink Display mit ESPHome und Home Assistant steuern (ESP32)“

  1. Hi,
    ein cooles Beispiel von Dir. Ich habe mir mit einem ESP32 und einem OLED SH1106 128×32 Display was gebastelt.
    Ich versteh nur nicht den Part mit ‚if‘

    Aktuell wechselt die Anzeige bei mir alle 5 Sekunden, ich mรถchte aber Page 2 nur anzeigen wenn der Timer startet
    und dann Page 1 und 3 nicht anzeigen (erst wenn der Timer der OralB die 2 Minuten erreicht hat).

    Kannst Du mir da einen Tipp geben?
    GruรŸ, AndiFidi

    display:
    – platform: ssd1306_i2c
    model: „SH1106 128×32“
    id: oled
    pages:
    – id: page1
    lambda: |-
    it.printf(0, 0, id(verdana10), „%.1f ยฐC“, id(temp).state);
    it.printf(85, 0, id(verdana10), „%.1f %%“, id(hum).state);
    it.line(0,14,128,14);
    it.strftime(2, 15, id(verdana12), „%d.%m.%Y – %H:%M“, id(esptime).now());

    – id: page2
    lambda: |-
    it.printf(0, 0, id(verdana10), „Andreas: %.1f min.“, id(putza).state);
    it.line(0,14,128,14);
    it.printf(0, 15, id(verdana10), „Nicole: %.1f min.“, id(putzn).state);

    – id: page3
    lambda: |-
    it.printf(0, 0, id(verdana10), „Balkon Temp: %.1f ยฐC“, id(aussentemp).state);
    it.line(0,14,128,14);
    it.printf(0, 15, id(verdana10), „Balkon LF: %.1f %%“, id(aussenlf).state);
    interval:
    – interval: 5s
    then:
    – display.page.show_next: oled
    – component.update: oled

    Antworten
  2. Moin Olli,
    genau sowas suche ich schon seit Tagen …
    Ich mรถchte รผber das Display Daten meiner Solaranlage anzeigen lassen, ist der Code von oben so komplett das es mit genau diesen Daten direkt
    funktioniert?
    Ich habe leider garkeine Ahnung von dem Codegeschnippel und wรผrde es tatsรคchlich รผber try and error probieren, aber ESP Home zum Beispiel liefert wohl keinen Displaytreiber fรผr das groรŸe Display aber du hast es ja am laufen.
    Ich bin eher so der Typ Drag and Drop ๐Ÿ˜›

    Antworten
  3. Hallo Olli, danke fรผr die Ideen. Ich hatte schon mal einen Anlauf unternommen, รคhnliches umzusetzen, war dann aber gescheitert. Mein Problem ist, dass ich einen flexiblen Textblock darstellen mรถchte, an den unterschiedliche Skripte ihre Meldungen hinschicken kรถnnen. Oben stehen dann die aktuellen, die รคlteren verschwinden unten automatisch. Vielleicht auch eine weitere Spalte mit Terminen (caldav).
    Bisher konnte ich nur Code Beispiele finden, die im Display klar festlegen, was wo steht, dafรผr sind meine Infos aber zu dynamisch.
    Vermutlich sollte sich ein groรŸes json (in HA zusammengesetzt) irgendwie mit wenigen Zeilen Code als groรŸer Block darstellen lassen (also bspw รผber 70% t Flรคche). Hast Du da eine Idee fรผr den lambda Teil?

    Antworten
    • Hi Tilo,
      das klingt fรผr mich so, als kรถnnte man es ggf. รผber ein Template in Home Assistant lรถsen? Und deine Skripte „bespielen“ dann diese Template, wobei jeweils die Historie als Attribut hinterlegt wird? Zu Attributen hatte ich hier mal was geschrieben https://smarterkram.de/3480/

      Ggf. kann man beim Setzen des neuen Wertes fรผr dein Template mittels SQL (https://www.home-assistant.io/integrations/sql/) die bisherigen Werte als Attribut(e) setzen?

      In dem Code fรผr das E-Ink wรผrdest du dann das Template und dessen Attribute einbauen. Klingt das fรผr dich halbwegs nachvollziehbar?

      Antworten
  4. Hi, das ist eine extrem gute Idee mit dem e-ink Display und sieht mega aus! Kannst du das Display auch als Touch Display benutzen? Also quasi als normales Homeassistant Dashboard und Lichter ein und ausschalten? Oder ist es nur um Sensoren und das Wetter zu visualisieren?

    Liebe GrรผรŸe!

    Antworten
  5. Hi Olli, ich habe das รคhnlich umgesetzt mit einem 4.2 Zoll Display. Da ich es mit einem Akku betreiben mรถchte, mache ich nur alle 30 Min. ein Update der Anzeige und dazwischen Deep Sleep des Esp32. Trotzdem saugt es mir den Akku leer nach ein paar Tagen. Ich vermute, dass zwar der Esp32 im Deep Sleep ist, aber nicht das ePaper Display. Das kann z.B. auch kein partielles Refresh und zeichnet immer den kompletten Screen neu. Hast du Erfahrungen mit dem Akkubetrieb?
    Viele GrรผรŸe,
    Steffen

    Antworten
    • Hi Steffen, also eigentlich sollte das E-Ink nur Strom saugen, wenn es ร„nderungen erfรคhrt. Pushst du denn sehr regelmรครŸig Aktualisierungen an das E-Ink obwohl der ESP „offline“ ist?

      Ich nutze mein E-Ink ausschlieรŸlich an einem Netzteil!

      Viele GrรผรŸe

      Olli

      Antworten
  6. Hallo Olli, ich war begeistert von der Idee und habe mir gleich die Komponenten besorgt. Leider bleibt mein Display weiรŸ. ESP ist eingerichtet und ich habe erstmal versucht die Zeit anzuzeigen. Was mir aufgefallen ist, in deiner Liste mit PIN Belegungen fehlt einer. Auf deinem Foto hast du ihn gesteckt (DIN). Welche Variante ist richtig? Danke und GruรŸ, Fabian

    Antworten
  7. Hi Olli, danke fรผr dein Unboxing Beitrag. Hรคttest Du auch deine ESPHome Yaml code mal als Beispiel angehรคngt, wรคr mir mehr geholfen gewesen ๐Ÿ™‚

    Antworten
  8. Hi! Ich hab auch das 7.5 Zoll Display am laufen, leider hab ich Probleme mit der Lesbarkeit. Es wird immer wieder sehr hellgrau und der Kontrast ist dann weg… Ich hab viele Beitrรคge im Netz gefunden, aber hilfreich war keiner. Mein Display zeigt auch die Uhrzeit an und wird jede Minute aktualisiert… Trotzdem bleibt das Problem…

    Antworten
    • Hi! Das klingt fรผr mich nach einem Defekt des Displays? Hast du es schon lange und ggf. einmal falsch angeschlossen? Oder kannst du es ggf. noch reklamieren?

      Ich kenne solche Probleme mit meinem Display im Zusammenhang mit ESPHome nicht, so dass ich leider auch nur raten kann.

      Antworten
    • Hello I have exactly the same problem the readability which disappears progressively. I have not yet found a solution and on your side?

      Hallo ich habe genau das gleiche Problem die Lesbarkeit die nach und nach verschwindet. Ich habe noch keine Lรถsung gefunden und auf Ihrer Seite?

      Antworten

Schreibe einen Kommentar