Volumio 2 SnapCast plugin, to easily manage SnapCast functionality
First of all, updates and the dependencies of the plugins should be installed:
- Install updates
sudo apt-get update
- Install Build Essentials with
sudo apt-get install build-essential
- Update NPM
sudo npm update -g
- Set timezone
sudo dpkg-reconfigure tzdata
I find that I have the most success getting a snapcast system to work by:
- Installing fresh copies of Volumio to each device and then go through the first four steps highlighted above
- Once complete I start with the server, and first install volspotconnect2 through through volumios UI
- I then SSH into the server and install snapcast following the steps below
- Once running with no issue I install snapcast onto my client devices
- In the end, my server has volspotconnect2>snapcast
- My clients JUST have snapcast (with their servers turned off)
- SSH into server, be sure to enable SSH via volumio.local/DEV beforehand
- Clone repository
git clone https://github.com/Sirnut/volumio-snapcast-plugin.git
- CD into volumio-snapcast-plugin directory
cd volumio-snapcast-plugin
- Remove the volumio-snapcast-plugin.zip
rm volumio-snapcast-plugin.zip
if you don't do this, the install will fail because it will try and mv two zips, volumio-snapcast-plugin.zip and the one created by the next command (snapcast.zip) to one location in /tmp. - Install the plugin
volumio plugin install
- Wait a few minutes for message saying install was successful. or until it reaches 100, asks if you want to activate and then freezes after a large wall of text
- If able to reboot. Otherwise just power cycle if you froze AFTER installation confirmed
sudo reboot
- Login to Volumio IU & set everything like you want it
- Configure the output format (sampling, bit depth, codec, etc.).
- Configure the soundcard for the client.
- In the case of a slave device disable to the server and connect to the running server; a. This can be either a Volumio host (drop down) or any other SnapCast server (define custom host -> fill in the IP-address) b. You cannot select a stream from within the plugin at this time, you can use the Android app for this. Default the first stream will be selected; in the case of this plugin that will be the MPD stream.
- Enjoy in-sync music in high fidelity.
The package will install both the client and server, you can en- or disable any component in the plugin settings.
Please note that I did not write the SnapCast application, I merely supplied means to easily install it. You can find the SnapCast project and all the information you need here: https://github.com/badaix/snapcast
On popular demand hereby a more elaborate description of the settings. They all relate to either snapcast, MPD or any of the Spotify implementations already in place.
The image below shows how a multiroom environment using SnapCast could look like. The main device, let's call that the server, will be hosting the audio chunks to all clients in the network. All music services on the server will have a fifo or pipe output defined, meaning they will not output to ALSA anymore.
The flow of the audio is as follows: Audio service -> FIFO/PIPE -> the SnapServer component will read the FIFO file (maybe even resample) and serve it -> The SnapClient component is able to receive the audio chunks and send them to an ALSA device -> ALSA -> Amplifier -> your speakers
The clients, either on the server or on another device, will be connected to the server (and the desired stream, because the server can host multiple streams). They can be configured in a hybrid way, so you can use them as SnapClient or stand-alone instance of Volumio, depening on your moods and desires.
How do you configure a hybrid device?
- Install the SnapCast plugin
- Disable the SnapServer on the hybrid device
- Connect to your SnapServer (on the other device)
- Configure all audio services to output to ALSA (NOTE: if you are not using a mix device you might need to wait a few seconds if you switch between SnapClient and another audio service)
This section configure the server-part behavior, disabling the server will stop the snapserver-service entirely.
- Enable SnapServer: this switch toggles whether the snapserver-service should be started.
- Name of the main stream: this is the name shown in e.g. the Android app, it only has an aesthetical purpose.
- Sample rate: the rate to which any input is recalculated and streamed (default = 48000Hz).
- Bit depth: the bit depth to which any input is recalculated and streamed (default = 16 bit).
- Sound channels: the number of channels to which any input is recalculated and streamed (default = 2 = stereo).
- Codec to use: the codec used to stream the audio to the clients (default = FLAC).
This section configure the client-part behavior, disabling the client will stop the snapclient-service entirely.
- Enable SnapClient: this switch toggles whether the snapclient-service should be started.
- Volumio host: this drop-down is populated using the Volumio-DNS function, it allows for easy configuration of a Volumio host (server).
- Define a custom host: this switch exposes (or hides) a free-text box to fill any hostname or IP in to connect to.
- SnapCast host (name/IP): A textbox to define a custom host to connect to, this overwrites any selected Volumio host.
- Soundcard to use for playback: a drop-down populated using the same function as Volumio, this should show all soundcards configured in Volumio.
This section allows for (re)configuration of MPD tailored to your needs. It will modify the existing mpd.conf, so you can always reconfigure should Volumio decide to write a new one.
- Patch mpd.conf: this toggles whether the mpd.conf file should actually be patched when saving.
- MPD sample rate: the rate to which MPD recalculates for playback.
- MPD bit depth: the bit depth to which MPD recalculates for playback.
- MPD channels: the number of channels to which MPD recalculates for playback.
- ALSA output for MPD: this en- or disables ALSA output for MPD, you can simultaneously use ALSA and FIFO outputs (even to different soundcards).
- FIFO output for MPD: this en- or disables FIFO output for MPD, you can simultaneously use ALSA and FIFO outputs (even to different soundcards).
This section has the option to write (or modify) the existing ALSA configuration (asound.conf). It will gather the needed settings from the plugin (spotify FIFO and sample rate) and write the needed section in asound.conf.
- ALSA configuration file: this setting is read-only, it shows which file will be edited upon save.
The Spotify integration settings section exposes a host of settings for the chosen Spotify implementation. Some options are related to one another, but I was unable to add that dimension to the web form.
- Dedicated stream for Spotify: this en- or disables a dedicated (named) stream for the chosen Spotify implementation. If you don't want this, remember to pause any other application streaming to the same FIFO file or you will hear both outputs.
- Name of the Spotify stream: only applies if you chose to use a dedicated stream (which is implicitly chose when a standalone option is used).
- Spotify implementation: select the Spotify implementation you want to use (remember you still need to install needed plugins/binaries!). If you want to use a standalone Librespot library, you will automatically get a dedicated stream, since this uses a different approach. Either stick to the rules or don't use this option, it's more advances and requires some know-how.
- Sample rate: the sample rate for the Spotify stream, recalculated by the snapserver-service.
- Bit depth: the bit depth for the Spotify stream, recalculated by the snapserver-service. NB: this option defaults to 16 bits when not using a dedicated stream.
- Sound channels: the number of channels for the Spotify stream, recalculated by the snapserver-service. NB: this option defaults to 2 when not using a dedicated stream.
- Expose Librespot settings: shows or hides the advanced Librespot settings.
- Location of the Librespot library: the absolute location of the Librespot library you want to use.
- Username: the username you want to use for the Librespot library.
- Password: the password matching the filled in username you want to use for the Librespot library.
- Devicename: the propagated devicename to Spotify.
- Spotify bitrate: controls the sound quality used by the Librespot library.
This patches the volspotconnect templates for future use, note you will need to save (again) afterwards in the Spotify plugin for the changes to take effect.
- Selected implementation: this shows the currently selected implementation (will only refresh upon page load!). If the selected implementation is librespot, patching will not change anything.
This is a semi state-less section, only the first drop-down is populated when settings exist.
- Select the client for which you want to control the volume for: this should show all clients known to the configured server. You can control the volume using the Volumio volume knob for the selected client.
- Switch stream for a client (group): exposed additional drop-downs to switch streams.
- Client to link to a specified stream: enumerates all known clients (but used their group-id, because groups are assigned streams, not clients) on the server.
- Select the stream you want to add the client to: enumerates all known streams (e.g. MPD/Spotify) on the server.
If you have used the Android app to add clients to groups, this means the whole group is assigned a new stream.
Shows the currently configured sound settings in Volumio.
- Output device: configured device for output in Volumio (this does not affect the snapclient-service).
- Mixer: configured mixer for output in Volumio, not sure how this affects playback yet.
Any problems with the plugin should be solvable by (re)patching files and saving settings in the corresponding plugins.
The following step-by-step is just an example, you can configure way more settings if you want to.
- Install all plugins you wish to use; Snapcast, Spotify Connect (e.g. volspotconnect(1|2), Spotify for Volumio 2 (spop), a stand-alone Librespot library, Qobuz, Youtube etc...
- If you wish to use Spotify; continue, else you only need to edit the first two sections if you want to deviate from standard behavior. So, assuming you want to use Spotify too, go to the "Spotify integration settings" section:
Decide whether you want a single stream for snapcast or not; single stream means connecting to the server is enough, with dedicated streams you need to switch streams for Spotify (either with an app, or the integrated stream selection in the plugin -> not very visually clarifying). Should you decide to go for a dedicated stream for Spotify you can choose a name for it in the next option.
Let's, for the sake of argument, work with an integrated stream, since I believe this is the most common setup (this is now the default).
The sample rate applies to all implementations, bit depth and channels don't apply to the spop implementation.
Flicking the expose Librespot switch exposes settings which are only needed when you use a stand-alone Librespot library for playback. Note: this is for advanced users only, you ought to know what you are doing if you want this to work.
Once all settings have been updated you can save them.
-
Re-open the snapcast plugin and patch the corresponding plugin template.
-
Now you need to save the settings in the plugin whose template you just patched, this will activate the new configuration and restart any needed binaries.
zip -r volumio-snapcast-plugin.zip \
UIConfig.json \
config.json \
index.js \
node_modules \
package.json \
spotififo.service \
uninstall.sh \
i18n \
install.sh \
options \
templates