From 1da09fc6bd9050a9e7fdee882c97e9074220cce5 Mon Sep 17 00:00:00 2001 From: Nathan Ladwig Date: Wed, 18 Sep 2024 22:42:47 -0500 Subject: [PATCH] readme --- README.md | 310 +++++++++++++++++++++++++++--------------------------- 1 file changed, 153 insertions(+), 157 deletions(-) diff --git a/README.md b/README.md index ff8e23c..99f8cf7 100644 --- a/README.md +++ b/README.md @@ -2,189 +2,185 @@ ![Screenshot of ScreamRouter](/images/ScreamRouter.png) -### What is ScreamRouter - -ScreamRouter is a versatile audio routing and management system with a Python frontend/configuration layer and C++ backend, designed for network audio streaming. It supports Scream and RTP audio sources, along with Scream receivers and web-based MP3 streamers. - -### Key Features of ScreamRouter - -#### Audio Routing and Configuration -* Configure Sources by IP address -* Set up Routes between Sources and Sinks -* Customize Sinks with Bit Depth, Sample Rate, Channel Layout, IP, and Port -* Group Sources and Sinks for simultaneous control and playback -* Volume control at every level: Source, Route, Sink, and Group - -#### Audio Processing and Playback -* Custom mixer/equalizer/channel layout processor for minimal latency, implemented in both Python and C++ -* Adjustable equalization for any sink, route, source, or group -* MP3 stream exposure for browser-based listening of all sinks -* URL playback capability for sinks or sink groups -* Milkdrop Visualizations via [Butterchurn](https://github.com/jberg/butterchurn) project -* Keeps a rolling buffer of streams that can be used for time shifting/rewinding streams - -#### Integration and Compatibility -* Home Assistant Custom Component for managing configuration and media playback -* Embedded noVNC for remote computer control - -#### System Management -* Automatic YAML saving on setting changes -* Flexible plugin system for easy addition of new sources and functionalities -* API and web interface for media control commands to containers -* Advanced configuration management and solving system -* Comprehensive logging system - -#### Sources -* RTP/Linux Source -* Windows Source -* ESP32S3 USB Audio Card and Toslink Senders -* Raspberry Pi Zero W / Raspberry Pi Zero 2 USB Gadget Sound Card Sender -* Amazon Music Docker Container -* Firefox Docker Container -* Spotify Docker Container -* Plugin system, including the ability to play arbitrary URLs out - -#### Receivers -* Windows Receivers -* Raspberry Pi/Linux Receiver -* ESP32/ESP32s3 spdif/USB UAC 1.0 audio receiver -* ESP32 A1S Audiokit Receiver -* Android Receiver -* Python Scream Receiver +## Table of Contents +1. [What is ScreamRouter](#what-is-screamrouter) +2. [Key Features](#key-features) + - [Audio Routing and Configuration](#audio-routing-and-configuration) + - [Audio Processing and Playback](#audio-processing-and-playback) + - [Integration and Compatibility](#integration-and-compatibility) + - [System Management](#system-management) +3. [Sources](#sources) +4. [Receivers](#receivers) +5. [Use Cases](#use-cases) +6. [Documentation](#documentation) + - [Install/Configuration](#installconfiguration) + - [General Information](#general-information) + - [Senders](#senders) + - [Receivers](#receivers-1) + - [UI](#ui) + - [API](#api) + - [Home Assistant](#home-assistant) +7. [Accessibility](#accessibility) +8. [Example Devices](#example-devices) +9. [Technical Details](#technical-details) + - [Audio Processing Capabilities](#audio-processing-capabilities) + - [Backend Implementation](#backend-implementation) + - [Configuration Management](#configuration-management) + - [Logging System](#logging-system) + - [Network Communication](#network-communication) + - [Plugin System](#plugin-system) + +## What is ScreamRouter + +ScreamRouter is a versatile audio routing and management system with a Python frontend/configuration layer and C++ backend, designed for network audio streaming. It supports Scream and RTP audio sources, along with Scream receivers and web-based MP3 streamers. + +## Key Features + +### Audio Routing and Configuration +- Configure Sources by IP address. +- Set up Routes between Sources and Sinks. +- Customize Sinks with Bit Depth, Sample Rate, Channel Layout, IP, and Port. +- Group Sources and Sinks for simultaneous control and playback. +- Volume control at every level: Source, Route, Sink, and Group. + +### Audio Processing and Playback +- Custom mixer/equalizer/channel layout processor for minimal latency, implemented in both Python and C++. +- Adjustable equalization for any sink, route, source, or group. +- MP3 stream exposure for browser-based listening of all sinks. +- URL playback capability for sinks or sink groups. +- Milkdrop Visualizations via [Butterchurn](https://github.com/jberg/butterchurn) project. +- Keeps a rolling buffer of streams that can be used for time shifting/rewinding streams. + +### Integration and Compatibility +- Home Assistant Custom Component for managing configuration and media playback. +- Embedded noVNC for remote computer control. + +### System Management +- Automatic YAML saving on setting changes. +- Flexible plugin system for easy addition of new sources and functionalities. +- API and web interface for media control commands to containers. +- Advanced configuration management and solving system. +- Comprehensive logging system. + +## Sources +- RTP/Linux Source +- Windows Source +- ESP32S3 USB Audio Card and Toslink Senders +- Raspberry Pi Zero W / Raspberry Pi Zero 2 USB Gadget Sound Card Sender +- Amazon Music Docker Container +- Firefox Docker Container +- Spotify Docker Container +- Plugin system, including the ability to play arbitrary URLs out. + +## Receivers +- Windows Receivers +- Raspberry Pi/Linux Receiver +- ESP32/ESP32s3 spdif/USB UAC 1.0 audio receiver +- ESP32 A1S Audiokit Receiver +- Android Receiver +- Python Scream Receiver ## Use Cases ### Comprehensive Whole-House Audio Systems - Integrate multiple Scream Sources and Receivers for seamless audio distribution throughout your home. ### Advanced Volume Management - Implement granular volume control at both group and individual sink levels, ensuring optimal audio balance across your setup. ### Web-Based Audio Access - Utilize the 'Listen to Sink' feature to enable browser-based audio playback, enhancing accessibility and flexibility. ### Universal Sink Compatibility - PCM receivers are available for most popular platforms, and for ones that can't receive PCM they can use the MP3 stream. ### Programmatic Audio Control - Employ the FastAPI interface or Home Assistant integration for automated management of sink activation, deactivation, and volume adjustments. ### Home Assistant Integration - Incorporate sound effects and Text-to-Speech functionality into Home Assistant automations and play them from any speaker in your house for an enhanced smart home experience. ### Sound Quality Enhancement - Utilize built-in equalization tools to optimize audio output, particularly beneficial for improving the performance of budget-friendly speakers. ### Time-Shifting and Audio Buffering - Maintains a rolling buffer of the most recent 5 minutes of audio for each stream allowing rewinding to and replaying audio within the buffered timeframe +Maintains a rolling buffer of the most recent 5 minutes of audio for each stream allowing rewinding to and replaying audio within the buffered timeframe. ## Documentation ### Install/Configuration - -* [Docker ScreamRouter Install Guide](Readme/docker-screamrouter.md) - - Guide to running ScreamRouter in a Docker container - -* [Debian ScreamRouter Install Guide](/Readme/debian-screamrouter.md) - - Guide to running ScreamRouter on Debian +- [Docker ScreamRouter Install Guide](Readme/docker-screamrouter.md) + - Guide to running ScreamRouter in a Docker container. +- [Debian ScreamRouter Install Guide](Readme/debian-screamrouter.md) + - Guide to running ScreamRouter on Debian. ### General Information - -* [Audio Processor](Readme/processor.md) - - Details on the custom mixer/equalizer/channel layout processor - -* [Configuration](Readme/configuration.md) - - Description of ScreamRouter's routing configuration and configuration management system +- [Audio Processor](Readme/processor.md) + - Details on the custom mixer/equalizer/channel layout processor. +- [Configuration](Readme/configuration.md) + - Description of ScreamRouter's routing configuration and configuration management system. ### Senders - -* [RTP/Linux Source](Readme/rtp-source.md) - - Guide to using RTP from PulseAudio and Pipewire as an audio source - -* [Windows Source](Readme/scream-source.md) - - Information on configuring a Windows audio source - -* [Docker Sources](Readme/docker-sources.md) - - Information on Docker containers for various streaming services - -* [ESP32S3 USB Audio Card and Toslink Senders](Readme/esp32-scream-sender.md) - - Information on using an ESP32S3 as a USB sound card to stream to Scream, or an ESP32 as a TOSLINK bridge for Scream - -* [Raspberry Pi Zero W / Raspberry Pi Zero 2 USB Gadget Sound Card Sender](Readme/raspberry-pi-zero-screamsender.md) - - Information on configuring a Raspberry Pi Zero W / Raspberry Pi Zero 2 as a USB Gadget Sound Card that forwards to ScreamRouter +- [RTP/Linux Source](Readme/rtp-source.md) + - Guide to using RTP from PulseAudio and Pipewire as an audio source. +- [Windows Source](Readme/scream-source.md) + - Information on configuring a Windows audio source. +- [Docker Sources](Readme/docker-sources.md) + - Information on Docker containers for various streaming services. +- [ESP32S3 USB Audio Card and Toslink Senders](Readme/esp32-scream-sender.md) + - Information on using an ESP32S3 as a USB sound card to stream to Scream, or an ESP32 as a TOSLINK bridge for Scream. +- [Raspberry Pi Zero W / Raspberry Pi Zero 2 USB Gadget Sound Card Sender](Readme/raspberry-pi-zero-screamsender.md) + - Information on configuring a Raspberry Pi Zero W / Raspberry Pi Zero 2 as a USB Gadget Sound Card that forwards to ScreamRouter. #### Docker Containers -* [Amazon Music Docker Container for ScreamRouter](https://github.com/netham45/screamrouter-amazon-music-docker) - - Repo for running Amazon Music as a Docker container that outputs over RTP to ScreamRouter - -* [Firefox Docker Container for ScreamRouter](https://github.com/netham45/screamrouter-firefox-docker) - - Repo for running Firefox as a Docker container that outputs over RTP to ScreamRouter - -* [Spotify Docker Container for ScreamRouter](https://github.com/netham45/screamrouter-spotify-docker) - - Repo for running Sporify in a Docker container that outputs over RTP to ScreamRouter +- [Amazon Music Docker Container for ScreamRouter](https://github.com/netham45/screamrouter-amazon-music-docker) + - Repo for running Amazon Music as a Docker container that outputs over RTP to ScreamRouter. +- [Firefox Docker Container for ScreamRouter](https://github.com/netham45/screamrouter-firefox-docker) + - Repo for running Firefox as a Docker container that outputs over RTP to ScreamRouter. +- [Spotify Docker Container for ScreamRouter](https://github.com/netham45/screamrouter-spotify-docker) + - Repo for running Spotify in a Docker container that outputs over RTP to ScreamRouter. ### Receivers - -* [Windows Receivers](Readme/windows-scream-receiver.md) - - Information on configuring a Windows audio receiver - -* [Raspberry Pi/Linux Receiver](Readme/raspberry-pi-receiver.md) - - Information on configuring a Raspberry Pi or other Linux system as a Scream audio receiver and have it start on boot - -* [ESP32/ESP32s3 spdif/USB UAC 1.0 audio receiver](https://github.com/netham45/esp32-scream-receiver) - - Repo for an esp32s3 spdif/USB UAC 1.0 audio receiver - -* [ESP32 A1S Audiokit Receiver](https://github.com/netham45/esp32-audiokit-screamreader) - - Repo for an ESP32 A1S Audiokit receiver - -* [Android Receiver](https://github.com/martinellimarco/scream-android/) - - Repo for an Android receiver - -* [Python Scream Receiver](https://github.com/netham45/pyscreamreader) - - Repo for a Python receiver +- [Windows Receivers](Readme/windows-scream-receiver.md) + - Information on configuring a Windows audio receiver. +- [Raspberry Pi/Linux Receiver](Readme/raspberry-pi-receiver.md) + - Information on configuring a Raspberry Pi or other Linux system as a Scream audio receiver and have it start on boot. +- [ESP32/ESP32s3 spdif/USB UAC 1.0 audio receiver](https://github.com/netham45/esp32-scream-receiver) + - Repo for an esp32s3 spdif/USB UAC 1.0 audio receiver. +- [ESP32 A1S Audiokit Receiver](https://github.com/netham45/esp32-audiokit-screamreader) + - Repo for an ESP32 A1S Audiokit receiver. +- [Android Receiver](https://github.com/martinellimarco/scream-android/) + - Repo for an Android receiver. +- [Python Scream Receiver](https://github.com/netham45/pyscreamreader) + - Repo for a Python receiver. ### UI - -* [User Interface Guide](Readme/ui.md) - - Documentation on using the ScreamRouter web interface - -* [Chrome App](Readme/chrome-app-manifest.md) - - Guide to installing it as an app using Chrome - -* [VNC Integration](Readme/vnc.md) - - Guide to using the embedded noVNC for remote computer control +- [User Interface Guide](Readme/ui.md) + - Documentation on using the ScreamRouter web interface. +- [Chrome App](Readme/chrome-app-manifest.md) + - Guide to installing it as an app using Chrome. +- [VNC Integration](Readme/vnc.md) + - Guide to using the embedded noVNC for remote computer control. ### API - -* [Swagger Documentation](https://netham45.org/wp-content/uploads/screamrouter-docs/) - - Swagger Docs for ScreamRouter API - -* [API Structure](Readme/api.md) - - Overview of the API structure and available endpoints - -* [Plugins System](Readme/plugins.md) - - Documentation on the flexible plugin system for adding new sources and functionalities - -* [Source Command Receiver](Readme/command_receiver.md) - - Information about the command receiver module for remote control +- [Swagger Documentation](https://netham45.org/wp-content/uploads/screamrouter-docs/) + - Swagger Docs for ScreamRouter API. +- [API Structure](Readme/api.md) + - Overview of the API structure and available endpoints. +- [Plugins System](Readme/plugins.md) + - Documentation on the flexible plugin system for adding new sources and functionalities. +- [Source Command Receiver](Readme/command_receiver.md) + - Information about the command receiver module for remote control. ### Home Assistant - -* [Home Assistant Integration](Readme/homeassistant.md) - - Instructions for integrating ScreamRouter with Home Assistant +- [Home Assistant Integration](Readme/homeassistant.md) + - Instructions for integrating ScreamRouter with Home Assistant. ## Accessibility -ScreamRouter is aiming to be accessible to those with visual impairments. To this effect the UI has been designed with tooltips and alt tags on every element and can be used from a keyboard. +ScreamRouter aims to be accessible to those with visual impairments. To this effect, the UI has been designed with tooltips and alt tags on every element and can be used from a keyboard. -If you encounter any issues affecting accessibility please file an issue on Github. +If you encounter any issues affecting accessibility, please file an issue on GitHub. ## Example Devices @@ -198,52 +194,52 @@ If you encounter any issues affecting accessibility please file an issue on Gith ScreamRouter supports various audio formats and processing capabilities: -- Input formats: Scream, RTP -- Output formats: PCM, MP3 -- Sample rates: Configurable, typically 44.1kHz, 48kHz -- Bit depths: 16-bit, 24-bit, 32-bit LPCM -- Channel layouts: Stereo, 5.1 surround, 7.1 surround (configurable) -- Equalization: 18-band equalizer for each sink, route, source, or group +- Input formats: Scream, RTP. +- Output formats: PCM, MP3. +- Sample rates: Configurable, typically 44.1kHz, 48kHz. +- Bit depths: 16-bit, 24-bit, 32-bit LPCM. +- Channel layouts: Stereo, 5.1 surround, 7.1 surround (configurable). +- Equalization: 18-band equalizer for each sink, route, source, or group. ### Backend Implementation ScreamRouter uses a hybrid backend approach: -- Python: Used for high-level logic, configuration management, and some audio processing tasks -- C/C++: Implemented for performance-critical audio processing tasks, ensuring low latency +- Python: Used for high-level logic, configuration management, and some audio processing tasks. +- C/C++: Implemented for performance-critical audio processing tasks, ensuring low latency. ### Configuration Management The configuration management system includes: -- YAML-based configuration files -- Automatic saving of configuration changes -- Configuration solver for resolving complex routing scenarios +- YAML-based configuration files. +- Automatic saving of configuration changes. +- Configuration solver for resolving complex routing scenarios. ### Logging System ScreamRouter includes a comprehensive logging system for debugging and monitoring: -- Configurable log levels -- Separate logs for different components (audio processing, network, plugins, etc.) -- Rotation of log files to manage disk usage +- Configurable log levels. +- Separate logs for different components (audio processing, network, plugins, etc.). +- Rotation of log files to manage disk usage. ### Network Communication -- TCP manager for handling network communications -- Support for multicast and unicast audio streaming +- TCP manager for handling network communications. +- Support for multicast and unicast audio streaming. ### Plugin System The flexible plugin system allows for easy extension of ScreamRouter's capabilities: -- Support for adding new audio sources -- Custom audio processing plugins -- Integration with external services and devices +- Support for adding new audio sources. +- Custom audio processing plugins. +- Integration with external services and devices. Current plugins include: -- play_url: Allows playing audio from arbitrary URLs -- play_url_multiple: Enables playing multiple URLs simultaneously +- play_url: Allows playing audio from arbitrary URLs. +- play_url_multiple: Enables playing multiple URLs simultaneously. Developers can create new plugins to extend functionality further.