If the plugin is installed on a fresh Volumio, the deb package will install mpd_oled_cava to /usr/bin, however the plugin itself will copy its own cava binary to /usr/local/bin, and this is the binary that will then be used by mpd_oled. The cava binary appears to be compatible with the deb package mpd_oled binary.
If mpd_oled is installed from source on a Pi 4 then the mpd_oled and mpd_oled_cava binaries will be installed into /usr/local/bin. If the plugin was installed before the source installation then the source installation will overwrite the plugin mpd_oled_cava. If the plugin is installed after the source installation then the plugin will not overwrite the source installation mpd_oled_cava. Either way the plugin mpd_oled will end up using the source installation mpd_oled_cava.
The plugin doesn´t need to install cava separately, as the deb package already installs it, and so the plugin code that you quoted could be removed (and the plugin cava binary). When the plugin used to install cava from source, there could sometimes be breakage due to changes in cava, and so it was useful to be able to install an older version of cava and use that. This is never needed now the plugin installs the binary package, as the version of cava is fixed.
Regarding a solution to the potential problem, it should be fairly rare for anyone to install from source on Volumio 3, and so I could just include a note in the installation documentation that installing cava from source will likely create an incompatibity with the plugin. I don’t think it is worth adding a check in the plugin. but if you feel it would be useful then maybe it could be done when mpd_oled is activated, for example popping up a warning dialogue if /usr/local/bin/mpd_oled exists.
Thanks this is awesome! Took about 2 minutes to activate! and works perfectly.! I was using the manually installed version from github before but the cava thing didn’t work. Now after activating the plugin over the manually installed version it works
It’s a Raspberry Pi 3, Piano 2.1 and Kali. The amp is a Gainclone from audiosector.com and the attenuator is a Arduino based LDR volume and source selection controller from Vincent / zdr on diyaudio.com
I now have Volumio 3.396 and the MPD_OLED plugin has stopped displaying at all.
Going back to the old sd card with Volumio 2.917 it works.
What happened?
Is anyone currently having a similar problem?
In addition, when mpd_oled is installed, there is audio stuttering when using Tidal Connect, even audio stuttering when starting Volumio.
I went back to V.378 and after installing mpd_oled 1.1.1. audio playing in Tidal Connect started stuttering, after uninstalling mpd_oled it started playing fine again.
Next step.
After installing mpd_oled 1.0.18 Tidal Connect play without problems. Oled display is working without problems to.
I have someProbs with the Plugin and wonder if you could help me out.
I´m not very into Linux and this all stuff btw.
(See also Newbie Problem: Failed to open Alsa)
System as following:
RPI 3B+
IQAudio Pi DigiAmp+
mpd_display plugin with a ssh1106 SPI oled-display
Volumio and PlugIn latest version
My problem is as following, at first power up, Volumio displays an error “Failed to open “alsa” (alsa); Failed to open ALSA device “volumio”: Device or resource busy”
To get my system working, I enter System-Playback, turn off I2C and change the output device to “Headphone”, store this setting, play anything for about some seconds and switch I2C on again, select “IQAudio Pi DigiAmp+” and restart the system.
After the reboot, the system is working proberly without errors. Until I switch off. Then the procedure starts over again.
I also have tested it with a Hifiberry DAC+, same behavior.
Changing GPIO´s brings no other result.
Version 1.08 brings no changes.
Without any hat, absolutly no problems. I even setup a completely new systemimage.
A couple of things that could be reviewed (I am not currently using Volumio, and so can’t help directly)
The error is occurring at first boot, but if you change the configuration and change it back the error does not occur. In which case, perhaps there could be a race condition somewhere when modules/services/daemons are starting up (e.g. starting up the loopback module?) that could be fixed by introducing a delay somewhere.
The Pi HAT ALSA audio parameters may be incompatible with the ALSA configuration and cava (the program that processes the audio for mpd_oled). Setting the headphone jack introduces compatible parameters, and cava starts correctly, and then when the Pi HAT is re-enabled it chooses parameters that are compatible with the open loopback device.
I tried the installation mentioned above and it seems to work properly, even with restart and shutdown, at least with my HifiberryDAC+ and the SPI-OLED.
Didn´t tried the other DAC yet.
I don´t understand why the “official” plugin does not work, but that´s not my job, I guess
Hi,
Thanks for this great plugin. I got it to work on my RPi ZeroW, version 1.1.1.
I have the spotify plugin also installed and GPIO buttons.
I have a small low cost USB sound card attached to the RPi for the audio output.
So after spending some time setting up the plugins, I had my OLED display (SSD1306 I2C) show title and clock and bargraph EQ.
First thing : I had to reduce the number of bars to 2-3. Keeping the default 16 bars, the sound would cut off, every now and then, and reading quality gets really bad.
And after reboot, impossible to play a song : an error message says “volumio fail to open alsa device. device or resource is busy”
I have to disconnect physically my usb sound card and plug it again to be able to read anything. (or switch output device to hdmi and back to usb)
At last, if I want to play a song from spotify, I need to disconnect and reconnect again.
If I disable the MPD_OLED plugin, none of this happens at reboot…
Any idea ?
In the end, I don’t need the bargraph display, I just want the song info and the clock. Any possibility to disable the cava thing (even though it looks really cool) ?
Thanks a lot for your answers
My usual player is a Pi Zero W runing Moode, and only using MPD for playback, and that is pretty close to the CPU limit with mpd_oled running. I guess that Volumio 3 with Spotify running uses just a little more CPU, and that is enough to max out the processor when mpd_oled is running.
I don’t know if you can disable cava running with the Volumio 3 mpd_oled plugin, but if you use the non-plugin version of mpd_oled from github
Then you can stop cava from running by specifying that the audio copy comes from an invalid FIFO, e.g. run mpd_oled with mpd_oled -c fifo,/tmp/dummy. (The spectrum area will still be present, but with no bars displayed in it).