mpd_oled - OLED status and spectrum display for Raspberry Pi

Build/modify/repair equipment and improve systems performance by yourself

mpd_oled - OLED status and spectrum display for Raspberry Pi

Postby adrii » 23 Apr 2018, 16:18

The mpd_oled program displays an information screen including a music frequency spectrum on a 128x64 OLED screen connected to a Raspberry Pi (or similar) running MPD. Installation instructions are provided for RuneAudio.


Image

Demonstration video


Adrian.
User avatar
adrii
 
Posts: 27
Joined: 17 Apr 2018, 11:03

Re: mpd_oled - OLED status and spectrum display for Raspberr

Postby Devox » 29 May 2018, 17:10

This looks very cool! I will test this out as soon as i get a compatible display. Thanks for sharing this! :)
User avatar
Devox
 
Posts: 15
Joined: 03 May 2014, 15:16

Re: mpd_oled - OLED status and spectrum display for Raspberr

Postby LeighP » 24 Jun 2018, 20:31

Looks great.

Are the display contents customisable? I'd prefer a 'track elapsed' bar rather than spectrum display myself.

I've just got a simple two line display running - I guess this is the next step. I'll wait until I upgrade or 'start-over' as it was a task for me working on the command line to get the display working with the MPD. I still don't know what I did (!) to get it running but now it works, I won't change it nor mess with my system except for backing my SD card up :D

Leigh....
https://github.com/rern/rAudio - the new place for rAudio.
LeighP
 
Posts: 96
Joined: 27 Jan 2018, 10:27
Location: United Kingdom

Re: mpd_oled - OLED status and spectrum display for Raspberr

Postby adrii » 18 Jul 2018, 06:41

Hi Leigh

Sorry for the considerable delay in replying (I didn't receive a notification that there was a message in the thread).

The display layout is not currently configurable, although this is something I plan to look at. However, it does already include a "track elapsed" bar, which you can see in the image as a horizontal bar at the bottom of the display.

Adrian.
User avatar
adrii
 
Posts: 27
Joined: 17 Apr 2018, 11:03

Re: mpd_oled - OLED status and spectrum display for Raspberr

Postby Spaker » 20 Oct 2018, 17:22

Spaker
 
Posts: 4
Joined: 19 Oct 2018, 06:46

Re: mpd_oled - OLED status and spectrum display for Raspberr

Postby Ripa » 13 Dec 2018, 00:38

Ripa
 
Posts: 67
Joined: 04 Dec 2017, 03:55

Re: mpd_oled - OLED status and spectrum display for Raspberr

Postby Ripa » 13 Dec 2018, 02:10

Install instructions for RuneAudio
Base system
Install RuneAudio. Ensure a command line prompt is available for entering the commands below (e.g. use SSH, default username 'root', default password 'rune').

Build and install cava
mpd_oled uses Cava, a bar spectrum audio visualizer, to calculate the spectrum

https://github.com/karlstav/cava

The commands to download, build and install Cava on RuneAudio are as follows

pacman -S autoconf automake clang make libtool fftw alsa-lib
git clone https://github.com/karlstav/cava
cd cava
./autogen.sh
CC=clang ./configure
make
make install
System settings
Configure your system to enable I2C or SPI, depending on how your OLED is connected.

I use a cheap 4 pin I2C SSH1106 display with a Raspberry Pi Zero. It is wired like this. In /boot/config.txt I have the line dtparam=i2c_arm=on. In /etc/modules-load.d/raspberrypi.conf I have the lines i2c-dev and i2c-bcm2708.

The I2C bus speed on your system may be too slow for a reasonable screen refresh. Set a higher bus speed by adding the following line to /boot/config.txt (or try a higher value for a higher screen refresh, I use 800000 with a 25 FPS screen refresh)

dtparam=i2c_arm_baudrate=400000
Then restart the Pi.

If the mpd_oled clock does not display the local time then you may need to set the system time zone. Find your timezone in the list printed by the first command below, and edit the second command to include your timezone

timedatectl list-timezones
timedatectl set-timezone Canada/Eastern
Build and install mpd_oled
Install the packages needed to build the program

pacman -S i2c-tools lm_sensors
Clone the source repository and change to the source directory

git clone https://github.com/antiprism/mpd_oled
cd mpd_oled
The MPD audio output needs to be copied to a named pipe, where Cava can read it and calculate the spectrum. This is configured in /etc/mpd.conf, however, RuneAudio regenerates this file in response to various events and so the RuneAudio code must be changed to insert the section when the file is generated. The following commands install the patch program, copy the FIFO configuration file to /usr/local/etc/mpd_oled_fifo.conf, and patch the RuneAudio code to append this file when generating /etc/mpd.conf. (Note: if, for any reason, regeneration of /etc/mpd.conf has been disabled (for example, if it has been set immutable) then edit the file directly and append the contents of mpd_oled_fifo.conf.)

pacman -S patch
cp mpd_oled_fifo.conf /usr/local/etc/
patch -d/ -p0 -N < runeaudio_mpd_fifo.patch
Reboot the machine from RuneUI, then log back in and change to the mpd_oled source directory, e.g.

cd mpd_oled
If you ever want to make any changes to the FIFO configuration, for example you might want to change buffer_time to help synchronise the spectrum display with the audio on your system, then modify /usr/local/etc/mpd_oled_fifo.conf and restart MPD, by going to the RuneUI MPD Configuration page and clicking on "SAVE AND APPLY" in the volume control section.

Now build mpd_oled

CC=clang CXX=clang++ PLAYER=RUNEAUDIO make
Check the mpd_oled program works correctly by running it while playing music. The OLED type MUST be specified with -o from the following list: 1 - Adafruit SPI 128x64, 3 - Adafruit I2C 128x64, 4 - Seeed I2C 128x64, 6 - SH1106 I2C 128x64.

E.g. the command for a generic I2C SH1106 display (OLED type 6) with a display of 10 bars and a gap of 1 pixel between bars and a framerate of 15Hz is

./mpd_oled -o 6 -b 10 -g 1 -f 15
For I2C OLEDs you may need to specify the I2C address, find this by running, e.g. i2cdetect -y 1 and specify the address with mpd_oled -a, e.g. ./mpd_oled -o6 -a 3d .... If you have a reset pin connected, specify the GPIO number with mpd_oled -r, e.g. ./mpd_oled -o6 -r 24 .... (For, SPI OLEDs, edit display.cc to include your connection details, if this works out I will provide options for these parameters.)

If your display is upside down, you can rotate it 180 degrees with option '-R'.

Once the display is working, edit the file mpd_oled.service to include your OLED type number with the mpd_oled command, and any other options.

nano mpd_oled.service
Then run

bash install.sh
This will copy the program to /usr/local/bin and add a systemd service to run it and start it running. You can start, stop, disable, etc the service with commands like

systemctl start mpd_oled
If you wish to change mpd_oled parameters later then edit mpd_oled.service to include the changes and rerun install.sh.


with the first line pacman -S autoconf automake clang make libtool fftw alsa-lib i already have an error
Ripa
 
Posts: 67
Joined: 04 Dec 2017, 03:55

Re: mpd_oled - OLED status and spectrum display for Raspberr

Postby hondagx35 » 13 Dec 2018, 17:30

User avatar
hondagx35
 
Posts: 3042
Joined: 11 Sep 2014, 22:06
Location: Germany

Re: mpd_oled - OLED status and spectrum display for Raspberr

Postby Ripa » 15 Dec 2018, 00:30

Ripa
 
Posts: 67
Joined: 04 Dec 2017, 03:55

Re: mpd_oled - OLED status and spectrum display for Raspberr

Postby Ripa » 15 Dec 2018, 08:19

Frank,

CC=clang ./configure is getting error

error.png
error.png (94.21 KiB) Viewed 8325 times
Ripa
 
Posts: 67
Joined: 04 Dec 2017, 03:55

support RuneAudio Donate with PayPal

Next

Return to DIY and tweaks

Who is online

Users browsing this forum: No registered users and 1 guest
cron