Mp3-plugin

Aus VDR Wiki
Wechseln zu: Navigation, Suche

Inhaltsverzeichnis

Beschreibung

Autor: Stefan Huelswitt

Spielt MP3s, OGGs, WAVs etc. ab. Auch Internetradio kann damit benutzt werden. Es benutzt als Ausgabegerät entweder die DVB-Karte oder eine Soundkarte. Das Bedienkonzept ist playlisten-zentriert.

Bilder

Einstellungen

Hardwareanforderungen

  • DVB Karte
  • Optional Soundkarte

Softwareanforderungen

  • zlib
  • libid3tag
  • libmad
  • libsndfile (optional für WAV-Dateien)
  • libvorbis, libvorbisfile (optional für OGG-Dateien)
  • netpbm (optional für Hintergrundbilder)
  • mjpegtools (optional für Hintergrundbilder)

Installation

Source

...der benötigten Bibliotheken:

cd $SOURCEDIR
tar xfvz zlib-<VERSION>.tar.gz
cd zlib-<VERSION>.tar.gz
./configure --prefix=/usr/local
make
make install
ldconfig
cd -

tar xvzf libid3tag-<VERSION>.tar.gz
cd libid3tag-<VERSION>
./configure --prefix=/usr/local
make
make install
ldconfig
cd -

tar xvzf libmad-<VERSION>.tar.gz
cd libmad-<VERSION>
./configure --prefix=/usr/local
make
make install
ldconfig
cd -

tar xvzf libsndfile-<VERSION>.tar.gz
cd libsndfile-<VERSION>
./configure --prefix=/usr/local
make
make install
ldconfig

tar xvzf libogg-<VERSION>.tar.gz
cd libogg-<VERSION>
./configure --prefix=/usr/local
make
make install
ldconfig
cd -

tar xvzf libvorbis-<VERSION>.tar.gz
cd libvorbis-<VERSION>
./configure --prefix=/usr/local \
            --with-ogg-libraries=/usr/local/lib
make
make install
ldconfig

...des MP3-Plugins: Entpacken des Plugins in VDR/PLUGINS/src/mp3 (nur Zahlen und Buchstaben im Verzeichnisnamen, sonst findet make plugins das Plugin nicht), dann im VDR-Verzeichnis make plugins.

Arch-Linux

pacman -S libid3tag libmad libsndfile libvorbis mplayer

Crux

prt-get depinst libid3tag libmad libsndfile libvorbis mplayer

Debian

apt-get install libvorbis-dev libmad0-dev libsndfile1-dev libogg-dev libid3tag0-dev mplayer-586

Gentoo

emerge libid3tag libmad libsndfile libvorbis mplayer

SuSE

yast -i libid3tag libid3tag-devel mad-devel libsndfile-devel libvorbis-devel mplayer

Optionen

WITHOUT_MP3=1 Übersetzen ohne MP3-Plugin
WITHOUT_MPLAYER=1 Übersetzen ohne MPlayer-Plugin
WITHOUT_LIBSNDFILE=1 Übersetzen ohne Libsndfile
WITHOUT_LIBVORBISFILE=1 Übersetzen ohne libvorbisfile
WITH_OSS_OUTPUT=1 Übersetzen mit "OSS sound Ausgabe". Laut HISTORY kann das DSP device mit angegeben werden: -D [NUM] somit -D 1
BROKEN_PCM=1 Please note that you need a 261d firmware or you have to compile with...


Konfiguration

Es wird davon ausgegangen, das das Plugin bereits entpackt und verlinkt wurde, siehe Plugin Installation.

Minimale Installation: examples/mp3sources.conf.example nach /video/plugins/ kopieren, anpassen, VDR per vdr -P'mp3' starten.

mkdir -p /var/lib/cddb
cd $SOURCEDIR/VDR/PLUGINS/src/mp3/examples
# Die network.sh ist an die Bedürfnisse anzupassen.
mv network.sh.example network.sh
mv mount.sh.example mount.sh
chmod 777 *.sh
cp mp3sources.conf.example /etc/vdr/plugins/mp3sources.conf
cp mp3sources.conf.example /etc/vdr/plugins/mplayersources.conf
cd /usr/local/bin
ln -vs $SOURCEDIR/VDR/PLUGINS/src/mp3/examples/*.sh .
cd $SOURCEDIR/VDR
make all plugins

Übergabe:

vdr -P'mp3 -m /usr/local/bin/mount.sh -B /var/lib/cddb -n /usr/local/bin/network.sh'

Es ist auch möglich Internet-Streams zu empfangen, sicher nur für Standleitungen von Interesse.

Nun sollte auch klar werden, für was die network.sh anzupassen ist.

Ruft man einen Stream auf, kann mit besagten Script die Internetverbindung hergestellt werden.

Einfach ein Verzeichnis erstellen, möglichst unterhalb von den Einträgen der mp3sources.conf.

mkdir -p /mp3/streams

Dazu sind einfache Textfiles zu erstellen.

cd /mp3/streams
echo http://205.188.234.65:8030 > Beschreibung

Unter folgenden Adressen, findet man für jeden Geschmack etwas.

Oder per Script.

Einstellungen

Audio Modus = Streuen

Der MP3-Dekoder liefert 24bit Daten, die auf 16bit herunterskaliert werden müssen. Der Modus „Runden“ schneidet einfach die 8bit mit der niedrigsten Bedeutung vom 24bit-Wort ab, wo hingegen „Streuen“ eine Fehlerstrategie implementiert. Der Modus „Streuen“ ist geringfügig rechenintensiver.

Nur 48kHz Modus benutzen = nein

Falls „ja“, wird das MP3-Plugin gezwungen die Abtastrate der DVB-Karte von 48 kHz zu verwenden. Die Abtastraten der Musikstücke werden dann auf 48 kHz umgerechnet.

Anzeige Modus = 3

Bestimmt, welche Informationen im Fortschrittsbalken angezeigt werden: 1. Zeigt Titel und Künstlernamen 2. Zeigt zusätzlich Album und Jahr 3. Zeigt zusätzlich Abtastrate, Bitrate und Anzahl der Kanäle

Hintergrund Modus = Schwarz

Hintergrund wählt die Hintergrundanzeige während der Wiedergabe. Zur Auswahl steht „Schwarz“, das Live-Bild des zuletzt gewählten Fernsehkanals oder es wird ein Bild (.jpg, .gif, ...) angzeigt, das im Verzeichnis der mp3-Datei liegt (siehe Readme)

Default Loop Modus = nein

Bei „ja“ wird die automatische Wiederholung nach dem Ende einer Abspielliste eingeschaltet.

Default Shuffle Modus = nein

Bei „ja“ wird die Zufallswiedergabe der Abspielliste eingeschaltet.

ID3 Einlesen = Hintergrund

Ermöglicht das Einlesen von ID3-Tags im Hintergrund während der Wiedergabe. In der Abspielliste werden Titel und Künstler nur für Lieder angezeigt, die schon gespielt wurden, oder deren ID3-Tags bereits eingelesen wurden. Auch wenn „Hintergrund“ gewählt ist, wird die Funktion nur ausgeführt, wenn die Prozessorleistung für den Hintergrundprozess ausreicht.

Editor Modus = ID3 Namen

Dieser Eintrag bestimmt, ob in der Abspielliste Titel und Künstler, oder die Dateinamen angezeigt werden. Die Anzeige von Titel und Künstler kann etwas länger dauern, da alle ID3-Tags der Musikdateien erst eingelesen werden müssen. Hauptmenü Modus = Verz.Anzeige Wählt, ob bei Aufruf des MP3-Plugins die Abspielliste gezeigt wird oder ob gleich zur Verzeichnisanzeige weitergesprungen wird.

Normalisierer Pegel = 25

48 Einstellungen Setzt den Lautstärkepegel für den Normalisierer. Es sind Werte zwischen 0 und 50 erlaubt. Bei 0 wird der Normalisierer ausgeschaltet. Der Normalisierer wird gebraucht, wenn die Musikstücke einer Abspielliste mit verschiedenen Lautstärkepegeln aufgenommen wurden.

Begrenzer Pegel = 70

Setzt den Lautstärkepegel für den Lautstärkebegrenzer. Es sind Werte zwischen 25 und 100 erlaubt. Bei 100 wird der Begrenzer ausgeschaltet.

HTTP Proxy benutzen = nein

Ermöglicht die Benutzung eines HTTP Proxy-Servers beim Abspielen von Shoutcats / Icecast Streams.

HTTP Proxy Name = localhost

Der Hostname des HTTP Proxy-Servers. Wird nur benutzt, falls HTTP Proxy benutzen eingeschaltet wurde.

HTTP Proxy Port = 8080

Die Port Nummer des HTTP Proxy Servers. Wird nur benutzt, falls HTTP Proxy benutzen eingeschaltet wurde.

CDDB für CD-Audio = local/remote

Wenn eine Audio-CD gespielt wird, ermöglicht dieser Eintrag nach Titel und Stücknamen in der CDDB-Datenbank zur CD zu suchen. Man kann zwischen „local“ und „local&remote“ wählen. Für die lokale Suche muss natürlich die CDDB-Datenbank auf dem VDR-Rechner installiert sein.

CDDB Server = freedb.freedb.org

Hat man einen Internet-Anschluss für seinen VDR-Rechner, so kann über das Netz auf eine CDDBDatenbank zugegriffen werden. Der Hostname des CDDB Servers muss hier eingetragen werden und funktioniert nur, wenn local/remote im Eintrag vorher gewählt wurde.

CDDB Port = 888

Die Port Nummer des CDDB Servers.

Parameter

Parameter (kurz) Parameter (lang) Beschreibung
-m --mount=CMD use CMD to mount/unmount/eject mp3 sources (default: mount.sh)
-n --network=CMD execute CMD before & after network access (default: none)
-C --cache=DIR store ID3 cache file in DIR (default: video dir)
-V --cddb=DIR search CDDB files in DIR (default: /var/lib/cddb)
-D --dsp=DIR device for OSS output (default: none)
-i --iconv=CMD use CMD to convert background images (default: image_convert.sh)
-c --icache=DIR cache converted images in DIR (default: /var/cache/images/mp3)


Probleme

Fehlermeldung "Could not read YUV4MPEG2 header: unsupported features!"

Damit die Anzeige der Hintergrundbilder (mit "mjpegtools/sid 1:1.8.0-0.1") funktioniert, muß das Beispielskript image_convert.sh noch angepaßt werden. Die Zeilen

ppmtoy4m -v 0 -n 1 -r -F 30000:1001 | \
ppmtoy4m -v 0 -n 1 -r -F 25:1 | \

müssen in

ppmtoy4m -v 0 -n 1 -r -F 30000:1001 -S 420mpeg2 | \
ppmtoy4m -v 0 -n 1 -r -F 25:1 -S 420mpeg2 | \

geändert werden. Sonst gibt mpeg2enc die Fehlermeldung "Could not read YUV4MPEG2 header: unsupported features!" aus.


Glaube folgende Änderung, wäre besser, um es ein wenig Abwärtskompatibel zu halten.

--- image_convert.sh.example.org	2006-02-01 23:38:20.000000000 +0100
+++ image_convert.sh.example	2006-02-01 23:39:10.000000000 +0100
@@ -61,17 +61,23 @@
 #
 # now run the conversion
 #
+
+# 'chroma subsampling mode' mjpegtools >= 1.8.0
+if ppmtoy4m -h | egrep -q "'420mpeg2'" ; then
+    SUBSAMPLINGMODE="-S 420mpeg2"
+fi
+
 if [ "$FORMAT" = "ntsc" ]; then
   pnmscale $S $TMP | \
     pnmpad -black -width 704 -height 480 | \
     ppmntsc | \
-    ppmtoy4m -v 0 -n 1 -r -F 30000:1001 | \
+    ppmtoy4m -v 0 -n 1 -r -F 30000:1001 $SUBSAMPLINGMODE | \
     mpeg2enc -f 7 -T 90 -F 4 -nn -a 2 -v 0 -o "$MPG"
 else
   pnmscale $S $TMP | \
     pnmpad -black -width 704 -height 576 | \
     ppmntsc --pal | \
-    ppmtoy4m -v 0 -n 1 -r -F 25:1 | \
+    ppmtoy4m -v 0 -n 1 -r -F 25:1 $SUBSAMPLINGMODE | \
     mpeg2enc -f 7 -T 90 -F 3 -np -a 2 -v 0 -o "$MPG"
 fi
 #


Links

[1] http://www.underbit.com/products/mad (M)PEG (A)udio (D)ecoder Homepage
[2] http://www.zip.com.au/~erikd/libsndfile Homepage -> libsndfile
[3] http://www.vorbis.com/setup_linux/ Ogg Vorbis CODEC Project
[4] http://www.gzip.org/zlib Zlib
[5] http://www.muempf.de/index.html Homepage des Plugins
In anderen Sprachen