-
Notifications
You must be signed in to change notification settings - Fork 2
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
13 changed files
with
767 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,89 @@ | ||
# sonos-pi-controller | ||
A touch screen (Adafruit PiTFT 3.5") Sonos controller for Raspberry Pi. Runs in a docker container. | ||
|
||
This controller relies upon the [SoCo library](https://github.com/SoCo/SoCo) for communicating with [Sonos speakers](https://www.sonos.com/en-us/system) and the [pygame library](https://github.com/pygame/pygame) for the UI. | ||
|
||
data:image/s3,"s3://crabby-images/71922/7192233c1d614317dd86abd2c2284d7dd4431012" alt="Raspberry Pi Controller mounted to wall" | ||
data:image/s3,"s3://crabby-images/a6926/a692695193287a79549b1094d44c06affbb35136" alt="Now Playing" | ||
|
||
## Features | ||
The sonos-pi-controller includes the following features: | ||
|
||
* Familiar interface similar to the official Sonos controller | ||
* Stays synced with all your other Sonos controllers. | ||
* View album art, track name, artist, album | ||
* Select room (top right icon) | ||
* Group rooms (bottom right icon) | ||
* Select music from music library (top left icon) | ||
* Artists | ||
* Albums | ||
* Genres | ||
* Playlists (Imported Playlists) | ||
* Favorites (ex. items added to 'My Sonos') | ||
* Play & Pause | ||
* Next & Previous Track | ||
* Adjust volume (including grouped rooms) | ||
* Mute and unmute | ||
* Automatic backlight shutoff after period of inactivity | ||
|
||
## Planned Upgrades | ||
* Ability to view song queue, select a song in queue & adjust playback mode (normal, shuffle, repeat) | ||
* Replace select room icon with a queue icon | ||
* Room selection will be available via tapping on room name. | ||
|
||
## Installation & Requirements | ||
### You will need the following hardware: | ||
|
||
* Raspberry Pi 3B or armv7 compatible version | ||
* [Good starter kit if you have nothing](https://www.amazon.com/CanaKit-Raspberry-Starter-Premium-Black/dp/B07BCC8PK7), although it would be cheaper to buy what you need separately | ||
* [Adafruit PiTFT Plus 3.5" Touch Screen](https://www.amazon.com/PiTFT-Plus-480x320-Touchscreen-Raspberry/dp/B017PDWNKE) | ||
* Optional: [Case for mounting to the wall](https://www.amazon.com/gp/product/B07GPV61CJ) | ||
|
||
### Installation | ||
|
||
* Flash your Raspberry Pi with the latest Raspbian Lite (right now it's *stretch*) | ||
* Login to your Pi via ssh and install docker, docker-compose, and git. | ||
* [Here](https://www.bargelt.com/setting-up-a-headless-raspberry-pi-with-ssh-docker-docker-compose-git/) is a very helpful guide if you need help. | ||
* Attach your touchscreen to the Pi, reboot, and run the [installer script from Adafruit](https://learn.adafruit.com/adafruit-pitft-3-dot-5-touch-screen-for-raspberry-pi/easy-install-2) to setup your touchscreen. | ||
* Choose 0 degrees (portrait) for orientation | ||
* Choose PiTFT as text console. | ||
* My personal settings in `/boot/config.txt` | ||
```bash | ||
gpu_mem=16 | ||
# --- added by adafruit-pitft-helper Tue 30 Oct 10:12:27 MDT 2018 --- | ||
dtparam=spi=on | ||
dtparam=i2c1=on | ||
dtparam=i2c_arm=on | ||
dtoverlay=pitft35-resistive,rotate=0,speed=32000000,fps=60 | ||
# --- end adafruit-pitft-helper Tue 30 Oct 10:12:27 MDT 2018 --- | ||
``` | ||
* Build base Dockerfile image with pygame, pip, and SDL 1.2 support | ||
```bash | ||
docker build -t villarrealized/debian-pygame-base -f Dockerfile.base . | ||
``` | ||
* Build main Dockerfile image with | ||
```bash | ||
docker-compose build | ||
``` | ||
* Copy `sample.env` to `.env` and adjust `BACKLIGHT_TIMEOUT` to your preference. Default is 30 seconds. | ||
* Run `docker-compose up -d` and enjoy your Raspberry Pi Sonos Controller! | ||
|
||
## Screenshots | ||
data:image/s3,"s3://crabby-images/a6926/a692695193287a79549b1094d44c06affbb35136" alt="Now Playing" | ||
data:image/s3,"s3://crabby-images/a2f24/a2f240051055f87c5e5d3abcfa009c9c3bb4afc3" alt="Select Room" | ||
data:image/s3,"s3://crabby-images/e91a0/e91a0530ff4ad47f73594b257be7cbd7e4a43b1b" alt="Group Rooms" | ||
data:image/s3,"s3://crabby-images/b9f60/b9f606ff0060e3d78ac9dd67c862a7e73f3aa22a" alt="Music Library" | ||
data:image/s3,"s3://crabby-images/22652/22652c487cf6dcc77d696e20461b28cc28c1121f" alt="Select Artist" | ||
data:image/s3,"s3://crabby-images/42a4d/42a4d5a08a42440e923201c42bf2032fef01a127" alt="Select Track" | ||
data:image/s3,"s3://crabby-images/a1adb/a1adba1ae4f24fb969b203973f7471545c5ff376" alt="Select Favorite" | ||
data:image/s3,"s3://crabby-images/71922/7192233c1d614317dd86abd2c2284d7dd4431012" alt="Raspberry Pi Controller mounted to wall" | ||
|
||
|
||
## Troubleshooting | ||
If you have any issues getting started, please reach out and I will try to help. | ||
|
||
If your touchscreen is not calibrated correctly, try running the calibration program: | ||
```bash | ||
sudo TSLIB_FBDEVICE=/dev/fb1 TSLIB_TSDEVICE=/dev/input/touchscreen ts_calibrate | ||
``` | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
Almost all of the icons are from the good folks at https://icons8.com |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
A lot of the ui code was borrowed and adapted from fictorial/pygameui | ||
|
||
https://github.com/fictorial/pygameui |