mirror of
https://github.com/openhab/openhab-addons.git
synced 2025-01-11 23:52:00 +01:00
c3b29e0fe6
* [pulseaudio] Add pulseaudio sink as openhab audio sink (#1895) This add to the pulseaudio binding the capability to use "pulseaudio sink" as an "openhab sink" to output sound from openhab to a pulse audio server on the network. You need to load module-simple-protocol-tcp sink in addition to the usual module-cli-protocol-tcp, and enable the sink in the thing configuration. Closes #1895 Signed-off-by: Gwendal Roulleau <gwendal.roulleau@gmail.com> * Small corrections after review And getting rid of some other compilation warnings Signed-off-by: Gwendal Roulleau <gwendal.roulleau@gmail.com> * Fix some registration errors and allow the binding to load the simple module remotely Signed-off-by: Gwendal Roulleau <gwendal.roulleau@gmail.com> * Small corrections after reviews initialize audiosink in a thread with scheduler.submit clear some warning related code. Signed-off-by: Gwendal Roulleau <gwendal.roulleau@gmail.com> Better interruptexception handling * Fix two small concurrency bugs Signed-off-by: Gwendal Roulleau <gwendal.roulleau@gmail.com> Co-authored-by: Gwendal Roulleau <gwendal.roulleau@gmail.com>
62 lines
2.9 KiB
Markdown
62 lines
2.9 KiB
Markdown
# Pulseaudio Binding
|
|
|
|
This binding integrates pulseaudio devices.
|
|
|
|
## Supported Things
|
|
|
|
The Pulseaudio bridge is required as a "bridge" for accessing any other Pulseaudio devices.
|
|
|
|
You need a running pulseaudio server with module **module-cli-protocol-tcp** loaded and accessible by the server which runs your openHAB instance. The following pulseaudio devices are supported:
|
|
|
|
* Sink
|
|
* Source
|
|
* Sink-Input
|
|
* Source-Output
|
|
* Combined-Sink
|
|
|
|
## Discovery
|
|
|
|
The Pulseaudio bridge is discovered through mDNS in the local network.
|
|
|
|
## Thing Configuration
|
|
|
|
The Pulseaudio bridge requires the host (ip address or a hostname) and a port (default: 4712) as a configuration value in order for the binding to know where to access it.
|
|
You can use `pactl -s <ip-address|hostname> list-sinks | grep "name:"` to find the name of a sink.
|
|
|
|
## Channels
|
|
|
|
All devices support some of the following channels:
|
|
|
|
| Channel Type ID | Item Type | Description |
|
|
|-----------------|-----------|-------------------------------------------------------------------------|
|
|
| volume | Dimmer | Volume of an audio device in percent |
|
|
| mute | Switch | Mutes the device |
|
|
| state | String | Current state of the device (suspended, idle, running, corked, drained) |
|
|
| slaves | String | Slave sinks of a combined sink |
|
|
| routeToSink | String | Shows the sink a sink-input is currently routed to |
|
|
|
|
## Audio sink
|
|
|
|
Sink things can register themselves as audio sink in openHAB. MP3 and WAV files are supported.
|
|
Use the appropriate parameter in the sink thing to activate this possibility (activateSimpleProtocolSink).
|
|
This requires the module **module-simple-protocol-tcp** to be present on the server which runs your openHAB instance. The binding will try to command (if not discovered first) the load of this module on the pulseaudio server.
|
|
|
|
## Full Example
|
|
### pulseaudio.things
|
|
```
|
|
Bridge pulseaudio:bridge:<bridgname> "<Bridge Label>" @ "<Room>" [ host="<ipAddress>", port=4712 ] {
|
|
Things:
|
|
Thing sink multiroom "Snapcast" @ "Room" [name="alsa_card.pci-0000_00_1f.3", activateSimpleProtocolSink="true", simpleProtocolSinkPort="4711"] // the name corresponds to pactl list-sinks output
|
|
Thing source microphone "microphone" @ "Room" [name="alsa_input.pci-0000_00_14.2.analog-stereo"]
|
|
Thing sink-input openhabTTS "OH-Voice" @ "Room" [name="alsa_output.pci-0000_00_1f.3.hdmi-stereo-extra1"]
|
|
Thing source-output remotePulseSink "Other Room Speaker" @ "Other Room" [name="alsa_input.pci-0000_00_14.2.analog-stereo"]
|
|
Thing combined-sink hdmiAndAnalog "Zone 1+2" @ "Room" [name="combined"]
|
|
}
|
|
```
|
|
<!--
|
|
### pulseaudio.items
|
|
```
|
|
|
|
```
|
|
-->
|