Benutzer-Werkzeuge

Webseiten-Werkzeuge


infrastruktur:lounge:kiosk

Unterschiede

Hier werden die Unterschiede zwischen zwei Versionen angezeigt.

Link zu dieser Vergleichsansicht

Beide Seiten der vorigen RevisionVorhergehende Überarbeitung
Nächste Überarbeitung
Vorhergehende Überarbeitung
Nächste ÜberarbeitungBeide Seiten der Revision
infrastruktur:lounge:kiosk [2019-05-24 02:09] – Benutzung dokumentiert xqinfrastruktur:lounge:kiosk [2019-05-25 21:33] – Neue Features dokumentiert, Touchscreen-Installation dokumentiert xq
Zeile 1: Zeile 1:
-+====== kiosk ======             +====== kiosk ======             
 {{tag> hardware software kiosk}} {{tag> hardware software kiosk}}
 Das Shackspace Informationsterminal (kurz: kiosk) bietet Zugriff auf häufig benötigte Funktionen und Informationen des shack. Diese sind über eine einfache Menüstruktur schnell zu erreichen und durch die Position im Zentrum der Lounge auch physisch in Reichweite. Das Shackspace Informationsterminal (kurz: kiosk) bietet Zugriff auf häufig benötigte Funktionen und Informationen des shack. Diese sind über eine einfache Menüstruktur schnell zu erreichen und durch die Position im Zentrum der Lounge auch physisch in Reichweite.
 +
 +DNS entry: lounge.kiosk.shack \\
 +username:  shack
  
 ---- ----
Zeile 29: Zeile 32:
  
 Hier wird der aktuelle Stromverbrauch des shack angezeigt. Einsehbar ist der gesamte Stromverbrauch sowie der Verbrauch über die einzelnen Phasen verteilt. Die Ansicht kann über diverse Zeiträume gezoomt werden. Hier wird der aktuelle Stromverbrauch des shack angezeigt. Einsehbar ist der gesamte Stromverbrauch sowie der Verbrauch über die einzelnen Phasen verteilt. Die Ansicht kann über diverse Zeiträume gezoomt werden.
 +
 +
 +----
 +{{ :infrastruktur:lounge:kiosk-mate.jpg?300|}}
 +==== Matemat-Füllstand ====
 +Hier wird der aktuelle Füllstand der Schächte im [[/project/blue_frost|Mate-Mat]] angezeigt.
 +
 +----
 +{{ :infrastruktur:lounge:kiosk-events.jpg?300|}}
 +==== Eventliste ====
 +Zeigt die nächsten anstehenden Events von events.shackspace.de an, zudem deren Dauer.
 +
 +----
 +{{ :infrastruktur:lounge:kiosk-info.jpg?300|}}
 +==== Informations-Seite ====
 +Hier finden sich im Moment nur die Abholtermine der Müllabfuhr (Restmüll, Gelber Sack, Papiermüll). Mehr folgt irgendwann™.
  
 ---- ----
Zeile 46: Zeile 65:
  
 ---- ----
-=====  Entwicklung ======+===== Entwicklung ===== 
 + 
 +==== System ==== 
 +Der kiosk_v5 läuft auf einem NixOS. Dieses meldet automatisch den User //shack// an, welcher dann eine **i3**-Session startet. 
 + 
 +Der **i3** startet dann die Kiosk-Anwendung. 
 + 
 +Besonderheit: Der **i3** benutzt keinerlei Bars, was dazu führt, dass die Anwendung in ein "quasi-Vollbild" gestartet wird. 
 + 
 +Configs/Dokumentation: https://github.com/MasterQ32/shack_kiosk_v5_konfig 
 + 
 +==== Anwendung ==== 
 Entwickelt mit C++17 auf Basis von SDL2 als Renderer und libcurl als Web-Backend. Benutzt nix sowie qmake als Buildsystem. Entwickelt mit C++17 auf Basis von SDL2 als Renderer und libcurl als Web-Backend. Benutzt nix sowie qmake als Buildsystem.
 +
 +=== Allgemeines ===
  
 Source-Repository: https://github.com/MasterQ32/shack_kiosk_v5 Source-Repository: https://github.com/MasterQ32/shack_kiosk_v5
  
-Aux/Dokumentation: https://github.com/MasterQ32/shack_kiosk_v5_konfig+Dependencies: 
 +  * [[https://github.com/nlohmann/json|nlohmann/json]] (git submodule) 
 +  * [[https://github.com/nothings/stb|nothings/stb]] (git submodule) 
 +  * sdl2 (pkg-config) 
 +  * sdl2_image (pkg-config) 
 +  * sdl2_ttf (pkg-config) 
 +  * libcurl (pkg-config) 
 + 
 +=== Software-Architektur === 
 + 
 +Die Anwendung hat eine schwache Modularisierung: 
 +  * UI-Module (mainmenu, screensaver, powerview, …), welche jeweils eine Bildschirm-Seite darstellen 
 +  * Hilfmodule (fontrenderer, http_client, …) 
 + 
 +Die Module sind untereinander nur mit der notwendigen API verbunden und haben nach außen hin eine kleine Schnittstelle. Innerhalb eines Moduls ist nicht mehr als die notwendige Abstraktion getätigt (KISS-Prinzip). 
 + 
 +Die Initialisierung eines UI-Moduls ist etwas unorthodox (Singleton-Pattern mit "init on first access"), funktioniert aber für diesen Anwendungsfall problemlos. 
 + 
 +=== Touchscreen Treiber === 
 + 
 +Der Monitor des Kiosk wird mit einem eGalax Touch-Display bedient, wofür es nur poporitäre Treiber gibt. Diese findet man auf der [[http://www.eeti.com/drivers_Linux.html|offiziellen Seite des Herstellers]] oder als Sicherungskopie in dem Konfig-Repo. 
 + 
 +Die Treiber im Repo wurden für die existente NixOS-Installation angepasst und so gepatcht, dass sie problemlos auf dem System funktioniert (Pfade mit patchelf und ähnlichem angepasst, damit die Shared Objects gefunden werden).
  
 +Zudem muss der Treiber noch passend im X-Server konfiguriert werden. Dies geschieht in der NixOS-Konfiguration.
  
 ===== Historie ====== ===== Historie ======
  
 Siehe [[project:anytouchkiosk|IBM AnyTouch Kiosk]] Siehe [[project:anytouchkiosk|IBM AnyTouch Kiosk]]
infrastruktur/lounge/kiosk.txt · Zuletzt geändert: 2021-03-24 16:59 von 192.168.146.218