Raspberry Pi Audio Player für Blinde: Unterschied zwischen den Versionen

 
(15 dazwischenliegende Versionen desselben Benutzers werden nicht angezeigt)
Zeile 1: Zeile 1:
[[Kategorie:Tipps_und_Tricks]]
{{Infobox Projekt
|name            = R-Pi Audio Player für Blinde
|status          = experimentell
|beschreibung    = Audioplayer mit extrem einfacher Bedienung
|autor          = [[Benutzer:JanT|Jan]]
|owner          = Jan
|image          = RPi-Audioplayer.jpeg
|version        = 1.0
}}
 
Dieser Audioplayer richtet sich an Blinde, speziell ältere Blinde, die den Umgang mit Technik nicht gewohnt sind. Er basiert auf Debian plus MPD und einem Pythonscript. Er bekommt Hardwaretasten über den GPIO und evtl auch einen Lautstärkeregler und ein kleines Display. Außerdem USB Automount.
Dieser Audioplayer richtet sich an Blinde, speziell ältere Blinde, die den Umgang mit Technik nicht gewohnt sind. Er kann aber auch für eigene Projekte verwendet werden.
 
Die Daisy-Player, die im Handel erhältlich sind, sind nicht nur extrem teuer sondern auch unbedienbar für meine Zielgruppe.
 
Die Eckpunkte:
* möglichst einfach und unkompliziert
* eher großes Gehäuse und sehr große Tasten
* ohne viel Aufwand mit Inhalt füttern
* erweiterter Zugang für Wartung
 
Batteriebetrieb oder Bluetooth sind für mich eher zweitrangig, können aber nachgerüstet werden.


= Hardware =  
= Hardware =  
Zeile 7: Zeile 28:


* Hauptplatine
* Hauptplatine
** Raspberry Pi Zero W, Nachteil: keine Klinke
** Raspberry Pi Zero W
** Raspberry Pi 1B Nachteil: sehr schlechte Qualität an Klinkeausgang
*** Falls in Kombination mit Tastern und HiFiBerry geplant, bitte eine Version ohne GPIO-Leiste kaufen und später nur die genutzten Pins auflöten.
*** keine Klinke
*** eingebautes WLAN und BT
** Raspberry Pi 1B  
*** sehr schlechte Qualität an Klinkeausgang
* Audio
* Audio
** HiFiBerry DAC+ Zero mit 2x Chinch passt auch bei allen anderen PI mit Standard-GPIO, belegt ab Werk *ALLE* GPIO
** HiFiBerry DAC+ Zero mit 2x Chinch  
*** passt bei allen Pi mit Standard-GPIO,  
*** belegt ab Werk ''ALLE'' GPIO, das kann aber umgangen werden
** Klinke-Buchse, sofern vorhanden und Qualität ausreichend für die eigenen Bedürfnisse
** Klinke-Buchse, sofern vorhanden und Qualität ausreichend für die eigenen Bedürfnisse
** Bluetooth, onboard bei Zero W und ab 2B glaube ich.
** Bluetooth, onboard bei Zero W und ab 2B?
** beliebige? USB Soundkarte  
** beliebige? USB Soundkarte  
* Bedienung
* Bedienung
** eine Handvoll Taster  
** eine Handvoll Taster  
** Handy mit beliebiger App, die den MPD steuern kann (Netzwerk notwendig)
** Handy mit beliebiger App, die den MPD steuern kann (Netzwerk notwendig)
** TODO: kleines Display
** TODO kleines Display
* System
* System
** (Micro-)SD-Karte mindestens 8 GB
** (Micro-)SD-Karte mindestens 8 GB
* Medienvorrat
* Medienvorrat
** SD remote bestücken (Netzwerk notwendig)
** SD remote bestücken (Netzwerk notwendig)
** Online-Quelle (Netzwerk notwendig)
** Auf Auto Mount USB-Stick
** Auf Auto Mount USB-Stick
*** für Raspberry Zero ist ein MicroUSB-Adapter oder USB-Hub notwendig
*** für Raspberry Zero ist ein MicroUSB-Adapter und/oder USB-Hub notwendig
* Wifi und BT
** Kann mittels einfacher USB-Dongles nachgerüstet werden, falls das Modell diese nicht mitbringt
* Stromversorgung
* Stromversorgung
** Original-Netzteil, angeblich "einzig", da geglättete VCC  
** Original-Netzteil, angeblich "einzig", da geglättete VCC  
Zeile 29: Zeile 59:
** TODO Lithium Akku  
** TODO Lithium Akku  
*** Waveshare Battery Hat für 14500 Lithium-Akku
*** Waveshare Battery Hat für 14500 Lithium-Akku
**** Falls nicht kompatibel mit Hifiberry es kann auch über USB angeschlossen werden
**** Falls nicht kompatibel mit HiFiBerry kann es auch über USB angeschlossen werden
* TODO Gehäuse


== Taster ==
== Taster ==
Für den Anschluss der Taster gilt folgendes:
Die GPIO-Pins des Pi sind nicht geschützt. Bei falschem Anschluss ist ruck zuck der Spannungsregler defekt. Dieser kann nicht getauscht werden. Totalschaden. Aus diesem Grund müssen einige Vorsichtsmaßnahmen getroffen werden:  
* Die GPIO-Pins des Pi sind nicht geschützt. Bei falschem Anschluss ist ruck zuck der Spannungsregler defekt. Dieser kann nicht getauscht werden. Totalschaden. Aus diesem Grund müssen einige Vorsichtsmaßnahmen getroffen werden:  
* Wir verwenden grundsätzlich GND als Input für die Buttons
** Wir verwenden grundätzlich GND als Input für die Buttons
* Wir blockieren alle anderen Anschlüsse durch leere Stecker so, dass nur die gewünschten Anschlüsse verwendet werden können.
**
* Wir setzen die Pins derart ein, dass der Stecker verkehrtherum aufgesteckt werden kann, ohne Schäden zu verursachen.


Für mich sieht die Lösung so aus:
* Der HifiBerry verwendet die Pins 12,27,28,35,38 und 40, außerdem benötigt er natürlich Spannungsversorgung.
* Ich habe mühsam die GPIO-Leiste zum Teil abgelötet und die Pins 5 bis 10 sowie 13 und 14 durch eine gewinkelte Leiste ersetzt.
* Darauf kommt ein 2x5 Stecker.
* Wir verwenden nun die beiden äußeren Paare sowie das mittlere Paar für jeweils einen Taster.
* Falls der Stecker falschherum aufgesteckt ist, passiert nichts anderes als der Tausch zweier Taster.
* Als GPIO für unsere drei Taster dienen nun also 3,15 und 27.


= Software =  
= Software =  
Mein Player basiert auf Rasberry OS (bisher Raspbian). Die aktuelle Version ist ein Debian Buster (10). Das ganze sollte aber auch auf anderen Systemen lauffähig sein.


== System installieren und einrichten ==  
== System installieren und einrichten ==  
* Installiere Debian/Raspian auf der SD-Karte.
=== System ===
* Starte mit Monitor, Tastatur und Netzwerk
* Download Raspberry Pi OS Lite von https://www.raspberrypi.org/software/operating-systems/#raspberry-pi-os-32-bit
* Installiere Debian/Raspian auf der SD-Karte
* Starte mit Monitor, Tastatur und Netzwerk-Kabel
 
=== Netzwerkzugriff ===
* Login pi/raspberry
* Login pi/raspberry
* Ändere das Passwort mit passwd???
* Ändere das Passwort mit passwd?
* Aktiviere den SSH Server mittels  
* Aktiviere den SSH Server mittels  
     sudo systemctl enable ssh
     sudo systemctl enable ssh
     sudo systemctl start ssh
     sudo systemctl start ssh
* /etc/hostname setzen, anschliessend Reboot?
* NTP einrichten, um die Uhrzeit automatisch einzustellen
    sudo systemctl enable systemd-timesyncd.service
    sudo nano /etc/systemd/timesyncd.conf
    # Inhalt beispielsweise
    [Time]
    NTP=0.de.pool.ntp.org 1.de.pool.ntp.org 2.de.pool.ntp.org 3.de.pool.ntp.org
    sudo systemctl start systemd-timesyncd.service
   
    # Alternativ...
    sudo apt install ntp
https://github.com/adafruit/Raspberry-Pi-Installer-Scripts/issues/92
https://bugs.launchpad.net/raspbian/+bug/1920806


* Am besten jetzt auch den Wifi-Zugriff einrichten
=== Wifi - optional, aber zu empfehlen ===
** Network-Manager installieren
* Network-Manager installieren
    sudo apt install network-manager-gnome
    sudo apt install network-manager-gnome
** TODO
* mittels NMCLI Wifi einrichten, siehe https://www.makeuseof.com/connect-to-wifi-with-nmcli/ https://kifarunix.com/connect-to-wifi-in-linux-using-nmcli-command/


* /etc/hostname setzen, anschliessend Reboot?
=== Paketmanagement ===
* Nun kann remote auf die Kiste zugegriffen werden
* NTP einrichten, um die Uhrzeit automatisch einzustellen
    /etc/systemd/timesyncd.conf


* Update durchführen
* Update durchführen
Zeile 70: Zeile 127:


** Pakete für das Pythonscript
** Pakete für das Pythonscript
     sudo apt install git libespeak1 python3-pip  
     sudo apt install git libespeak-ng1 python3-pip  


** Weitere Pakete für das Pythonscript, alternativ!! per APT oder per PIP3:
** Weitere Pakete für das Pythonscript, alternativ!! per APT oder per PIP3:
Zeile 81: Zeile 138:
** Optional Pakete für die Ansteuerung der GPIOs von der Kommandozeile
** Optional Pakete für die Ansteuerung der GPIOs von der Kommandozeile
     sudo apt install gpio-utils
     sudo apt install gpio-utils
** TODO Pakete für Google TTS
    mpg123, ...
** TODO Pakete für System TTS


== MPD einrichten ==
== MPD einrichten ==
* Medienverzeichnis
* Medienverzeichnis
* Audiodevice
* Audiodevice
    sudo mkdir /var/log/mpd
    # chown?


== Python Skript einrichten ==
== Python Skript einrichten ==
mitglieder, vorstand
283

Bearbeitungen