2022-08-06 09:03:43 +01:00
|
|
|
[![PyPI version](https://badge.fury.io/py/vban-cmd.svg)](https://badge.fury.io/py/vban-cmd)
|
2022-03-09 06:30:48 +00:00
|
|
|
[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://github.com/onyx-and-iris/vban-cmd-python/blob/dev/LICENSE)
|
2023-08-19 19:56:35 +01:00
|
|
|
[![Poetry](https://img.shields.io/endpoint?url=https://python-poetry.org/badge/v0.json)](https://python-poetry.org/)
|
2025-01-17 02:51:17 +00:00
|
|
|
[![Ruff](https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/astral-sh/ruff/main/assets/badge/v2.json)](https://github.com/astral-sh/ruff)
|
2022-04-28 11:34:48 +01:00
|
|
|
![Tests Status](./tests/basic.svg?dummy=8484744)
|
|
|
|
![Tests Status](./tests/banana.svg?dummy=8484744)
|
|
|
|
![Tests Status](./tests/potato.svg?dummy=8484744)
|
2022-04-27 20:00:30 +01:00
|
|
|
|
2022-02-27 18:57:16 +00:00
|
|
|
# VBAN CMD
|
2022-04-27 20:00:30 +01:00
|
|
|
|
2023-07-15 08:17:18 +01:00
|
|
|
This python interface allows you to transmit Voicemeeter parameters over a network.
|
2022-03-06 14:44:30 +00:00
|
|
|
|
|
|
|
It may be used standalone or to extend the [Voicemeeter Remote Python API](https://github.com/onyx-and-iris/voicemeeter-api-python)
|
2022-02-27 18:57:16 +00:00
|
|
|
|
2022-08-08 14:24:02 +01:00
|
|
|
There is no support for audio transfer in this package, only parameters.
|
2022-03-02 23:28:42 +00:00
|
|
|
|
2022-04-30 16:57:47 +01:00
|
|
|
For an outline of past/future changes refer to: [CHANGELOG](CHANGELOG.md)
|
|
|
|
|
2022-03-02 23:28:42 +00:00
|
|
|
## Tested against
|
2022-04-27 20:00:30 +01:00
|
|
|
|
2023-06-25 18:40:09 +01:00
|
|
|
- Basic 1.0.8.8
|
|
|
|
- Banana 2.0.6.8
|
|
|
|
- Potato 3.0.2.8
|
2022-02-27 18:57:16 +00:00
|
|
|
|
2022-06-16 16:10:06 +01:00
|
|
|
## Requirements
|
2022-04-27 20:00:30 +01:00
|
|
|
|
2022-04-30 16:57:47 +01:00
|
|
|
- [Voicemeeter](https://voicemeeter.com/)
|
2022-09-03 16:47:38 +01:00
|
|
|
- Python 3.10 or greater
|
2022-02-27 18:57:16 +00:00
|
|
|
|
|
|
|
## Installation
|
2022-04-27 20:00:30 +01:00
|
|
|
|
2022-06-16 16:10:06 +01:00
|
|
|
`pip install vban-cmd`
|
2022-02-27 18:57:16 +00:00
|
|
|
|
2022-06-16 16:10:06 +01:00
|
|
|
## `Use`
|
2022-04-27 20:00:30 +01:00
|
|
|
|
2022-10-19 14:21:04 +01:00
|
|
|
#### Connection
|
2022-04-27 20:00:30 +01:00
|
|
|
|
2022-10-19 14:21:04 +01:00
|
|
|
Load VBAN connection info from toml config. A valid `vban.toml` might look like this:
|
|
|
|
|
|
|
|
```toml
|
|
|
|
[connection]
|
|
|
|
ip = "gamepc.local"
|
|
|
|
port = 6980
|
|
|
|
streamname = "Command1"
|
|
|
|
```
|
|
|
|
|
2023-07-11 20:27:52 +01:00
|
|
|
It should be placed in \<user home directory\> / "Documents" / "Voicemeeter" / "configs"
|
2022-10-19 14:21:04 +01:00
|
|
|
|
|
|
|
Alternatively you may pass `ip`, `port`, `streamname` as keyword arguments.
|
2022-03-02 23:28:42 +00:00
|
|
|
|
2022-06-16 16:10:06 +01:00
|
|
|
#### `__main__.py`
|
2022-04-27 20:00:30 +01:00
|
|
|
|
2022-10-19 14:21:04 +01:00
|
|
|
Simplest use case, use a context manager to request a VbanCmd class of a kind.
|
|
|
|
|
|
|
|
Login and logout are handled for you in this scenario.
|
|
|
|
|
2022-02-27 18:57:16 +00:00
|
|
|
```python
|
2022-06-16 16:10:06 +01:00
|
|
|
import vban_cmd
|
|
|
|
|
2022-02-27 18:57:16 +00:00
|
|
|
|
|
|
|
class ManyThings:
|
|
|
|
def __init__(self, vban):
|
|
|
|
self.vban = vban
|
|
|
|
|
|
|
|
def things(self):
|
2025-01-17 02:54:23 +00:00
|
|
|
self.vban.strip[0].label = 'podmic'
|
2022-06-16 16:10:06 +01:00
|
|
|
self.vban.strip[0].mute = True
|
|
|
|
print(
|
2025-01-17 02:54:23 +00:00
|
|
|
f'strip 0 ({self.vban.strip[0].label}) mute has been set to {self.vban.strip[0].mute}'
|
2022-06-16 16:10:06 +01:00
|
|
|
)
|
2022-02-27 18:57:16 +00:00
|
|
|
|
|
|
|
def other_things(self):
|
2022-10-19 14:21:04 +01:00
|
|
|
self.vban.bus[3].gain = -6.3
|
2025-01-17 02:54:23 +00:00
|
|
|
self.vban.bus[4].eq = True
|
2022-06-16 16:10:06 +01:00
|
|
|
info = (
|
2025-01-17 02:54:23 +00:00
|
|
|
f'bus 3 gain has been set to {self.vban.bus[3].gain}',
|
|
|
|
f'bus 4 eq has been set to {self.vban.bus[4].eq}',
|
2022-06-16 16:10:06 +01:00
|
|
|
)
|
2025-01-17 02:54:23 +00:00
|
|
|
print('\n'.join(info))
|
2022-02-27 18:57:16 +00:00
|
|
|
|
|
|
|
|
|
|
|
def main():
|
2025-01-17 02:54:23 +00:00
|
|
|
kind_id = 'banana'
|
2022-11-05 12:16:25 +00:00
|
|
|
|
2022-10-19 21:10:59 +01:00
|
|
|
with vban_cmd.api(
|
2025-01-17 02:54:23 +00:00
|
|
|
kind_id, ip='gamepc.local', port=6980, streamname='Command1'
|
2022-10-19 21:10:59 +01:00
|
|
|
) as vban:
|
2022-02-27 18:57:16 +00:00
|
|
|
do = ManyThings(vban)
|
|
|
|
do.things()
|
|
|
|
do.other_things()
|
|
|
|
|
2022-06-16 16:10:06 +01:00
|
|
|
# set many parameters at once
|
|
|
|
vban.apply(
|
|
|
|
{
|
2025-01-17 02:54:23 +00:00
|
|
|
'strip-2': {'A1': True, 'B1': True, 'gain': -6.0},
|
|
|
|
'bus-2': {'mute': True},
|
|
|
|
'vban-in-0': {'on': True},
|
2022-06-16 16:10:06 +01:00
|
|
|
}
|
|
|
|
)
|
2022-03-20 12:26:01 +00:00
|
|
|
|
|
|
|
|
2025-01-17 02:54:23 +00:00
|
|
|
if __name__ == '__main__':
|
2022-06-16 16:10:06 +01:00
|
|
|
main()
|
2022-03-23 11:31:28 +00:00
|
|
|
```
|
|
|
|
|
2022-06-16 16:10:06 +01:00
|
|
|
Otherwise you must remember to call `vban.login()`, `vban.logout()` at the start/end of your code.
|
2022-04-27 20:00:30 +01:00
|
|
|
|
2023-06-25 18:40:09 +01:00
|
|
|
## `KIND_ID`
|
2022-04-27 20:00:30 +01:00
|
|
|
|
2023-06-25 18:40:09 +01:00
|
|
|
Pass the kind of Voicemeeter as an argument. KIND_ID may be:
|
2022-04-27 20:00:30 +01:00
|
|
|
|
|
|
|
- `basic`
|
|
|
|
- `banana`
|
|
|
|
- `potato`
|
2022-02-27 18:57:16 +00:00
|
|
|
|
2022-06-16 16:10:06 +01:00
|
|
|
## `Available commands`
|
2022-04-27 20:00:30 +01:00
|
|
|
|
2022-07-16 21:56:20 +01:00
|
|
|
### Strip
|
2022-02-27 18:57:16 +00:00
|
|
|
|
2022-07-16 21:56:20 +01:00
|
|
|
The following properties are available.
|
2022-02-27 18:57:16 +00:00
|
|
|
|
2022-04-27 20:00:30 +01:00
|
|
|
- `mono`: boolean
|
|
|
|
- `solo`: boolean
|
|
|
|
- `mute`: boolean
|
|
|
|
- `label`: string
|
|
|
|
- `gain`: float, -60 to 12
|
2022-06-16 16:10:06 +01:00
|
|
|
- `A1 - A5`, `B1 - B3`: boolean
|
2022-04-27 20:00:30 +01:00
|
|
|
- `limit`: int, from -40 to 12
|
2022-02-27 18:57:16 +00:00
|
|
|
|
2022-06-16 16:10:06 +01:00
|
|
|
example:
|
2022-04-27 20:00:30 +01:00
|
|
|
|
2022-03-18 07:40:24 +00:00
|
|
|
```python
|
2022-06-16 16:10:06 +01:00
|
|
|
vban.strip[3].gain = 3.7
|
2022-10-06 20:28:26 +01:00
|
|
|
print(vban.strip[0].label)
|
|
|
|
```
|
|
|
|
|
|
|
|
The following methods are available.
|
|
|
|
|
|
|
|
- `appgain(name, value)`: string, float, from 0.0 to 1.0
|
|
|
|
|
|
|
|
Set the gain in db by value for the app matching name.
|
|
|
|
|
|
|
|
- `appmute(name, value)`: string, bool
|
|
|
|
|
|
|
|
Set mute state as value for the app matching name.
|
|
|
|
|
|
|
|
example:
|
|
|
|
|
|
|
|
```python
|
2025-01-17 02:54:23 +00:00
|
|
|
vban.strip[5].appmute('Spotify', True)
|
|
|
|
vban.strip[5].appgain('Spotify', 0.5)
|
2022-07-16 21:56:20 +01:00
|
|
|
```
|
|
|
|
|
2023-06-25 18:40:09 +01:00
|
|
|
##### Strip.Comp
|
|
|
|
|
|
|
|
The following properties are available.
|
|
|
|
|
|
|
|
- `knob`: float, from 0.0 to 10.0
|
|
|
|
- `gainin`: float, from -24.0 to 24.0
|
|
|
|
- `ratio`: float, from 1.0 to 8.0
|
|
|
|
- `threshold`: float, from -40.0 to -3.0
|
|
|
|
- `attack`: float, from 0.0 to 200.0
|
|
|
|
- `release`: float, from 0.0 to 5000.0
|
|
|
|
- `knee`: float, from 0.0 to 1.0
|
|
|
|
- `gainout`: float, from -24.0 to 24.0
|
|
|
|
- `makeup`: boolean
|
|
|
|
|
|
|
|
example:
|
|
|
|
|
|
|
|
```python
|
2023-06-27 15:36:53 +01:00
|
|
|
print(vban.strip[4].comp.knob)
|
2023-06-25 18:40:09 +01:00
|
|
|
```
|
|
|
|
|
|
|
|
Strip Comp properties are defined as write only.
|
|
|
|
|
2023-06-25 18:45:03 +01:00
|
|
|
`knob` defined for all versions, all other parameters potato only.
|
2023-06-25 18:40:09 +01:00
|
|
|
|
|
|
|
##### Strip.Gate
|
|
|
|
|
|
|
|
The following properties are available.
|
|
|
|
|
|
|
|
- `knob`: float, from 0.0 to 10.0
|
|
|
|
- `threshold`: float, from -60.0 to -10.0
|
|
|
|
- `damping`: float, from -60.0 to -10.0
|
|
|
|
- `bpsidechain`: int, from 100 to 4000
|
|
|
|
- `attack`: float, from 0.0 to 1000.0
|
|
|
|
- `hold`: float, from 0.0 to 5000.0
|
|
|
|
- `release`: float, from 0.0 to 5000.0
|
|
|
|
|
|
|
|
example:
|
|
|
|
|
|
|
|
```python
|
2023-06-27 15:36:53 +01:00
|
|
|
vban.strip[2].gate.attack = 300.8
|
2023-06-25 18:40:09 +01:00
|
|
|
```
|
|
|
|
|
|
|
|
Strip Gate properties are defined as write only, potato version only.
|
|
|
|
|
2023-06-25 18:45:03 +01:00
|
|
|
`knob` defined for all versions, all other parameters potato only.
|
2023-06-25 18:40:09 +01:00
|
|
|
|
|
|
|
##### Strip.Denoiser
|
|
|
|
|
|
|
|
The following properties are available.
|
|
|
|
|
|
|
|
- `knob`: float, from 0.0 to 10.0
|
|
|
|
|
|
|
|
strip.denoiser properties are defined as write only, potato version only.
|
|
|
|
|
|
|
|
##### Strip.EQ
|
|
|
|
|
|
|
|
The following properties are available.
|
|
|
|
|
|
|
|
- `on`: boolean
|
|
|
|
- `ab`: boolean
|
|
|
|
|
|
|
|
Strip EQ properties are defined as write only, potato version only.
|
|
|
|
|
2022-07-16 21:56:20 +01:00
|
|
|
##### Gainlayers
|
|
|
|
|
|
|
|
- `gain`: float, from -60.0 to 12.0
|
|
|
|
|
|
|
|
example:
|
|
|
|
|
|
|
|
```python
|
2022-08-08 14:26:57 +01:00
|
|
|
vban.strip[3].gainlayer[3].gain = 3.7
|
2022-07-16 21:56:20 +01:00
|
|
|
```
|
|
|
|
|
|
|
|
Gainlayers are defined for potato version only.
|
|
|
|
|
|
|
|
##### Levels
|
|
|
|
|
|
|
|
The following properties are available.
|
|
|
|
|
|
|
|
- `prefader`
|
|
|
|
|
|
|
|
example:
|
|
|
|
|
|
|
|
```python
|
2022-08-08 14:26:57 +01:00
|
|
|
print(vban.strip[3].levels.prefader)
|
2022-07-16 21:56:20 +01:00
|
|
|
```
|
|
|
|
|
|
|
|
Level properties will return -200.0 if no audio detected.
|
|
|
|
|
|
|
|
### Bus
|
|
|
|
|
|
|
|
The following properties are available.
|
|
|
|
|
|
|
|
- `mono`: boolean
|
|
|
|
- `mute`: boolean
|
|
|
|
- `label`: string
|
|
|
|
- `gain`: float, -60 to 12
|
|
|
|
|
|
|
|
example:
|
|
|
|
|
|
|
|
```python
|
2022-08-08 14:26:57 +01:00
|
|
|
print(vban.bus[0].label)
|
2022-07-16 21:56:20 +01:00
|
|
|
```
|
|
|
|
|
2023-06-25 18:40:09 +01:00
|
|
|
##### Bus.EQ
|
|
|
|
|
|
|
|
The following properties are available.
|
|
|
|
|
|
|
|
- `on`: boolean
|
|
|
|
- `ab`: boolean
|
|
|
|
|
2023-07-15 08:17:18 +01:00
|
|
|
```python
|
|
|
|
vban.bus[4].eq.on = true
|
|
|
|
```
|
|
|
|
|
2022-07-16 21:56:20 +01:00
|
|
|
##### Modes
|
|
|
|
|
|
|
|
The following properties are available.
|
|
|
|
|
|
|
|
- `normal`: boolean
|
|
|
|
- `amix`: boolean
|
|
|
|
- `bmix`: boolean
|
|
|
|
- `composite`: boolean
|
|
|
|
- `tvmix`: boolean
|
|
|
|
- `upmix21`: boolean
|
|
|
|
- `upmix41`: boolean
|
|
|
|
- `upmix61`: boolean
|
|
|
|
- `centeronly`: boolean
|
|
|
|
- `lfeonly`: boolean
|
|
|
|
- `rearonly`: boolean
|
|
|
|
|
|
|
|
The following methods are available.
|
|
|
|
|
|
|
|
- `get()`: Returns the current bus mode
|
|
|
|
|
|
|
|
example:
|
|
|
|
|
|
|
|
```python
|
2022-08-08 14:26:57 +01:00
|
|
|
vban.bus[4].mode.amix = True
|
2022-07-16 21:56:20 +01:00
|
|
|
|
2022-08-08 14:26:57 +01:00
|
|
|
print(vban.bus[2].mode.get())
|
2022-07-16 21:56:20 +01:00
|
|
|
```
|
|
|
|
|
|
|
|
##### Levels
|
2022-06-16 16:10:06 +01:00
|
|
|
|
2022-07-16 21:56:20 +01:00
|
|
|
The following properties are available.
|
|
|
|
|
|
|
|
- `all`
|
|
|
|
|
|
|
|
example:
|
|
|
|
|
|
|
|
```python
|
2022-08-08 14:26:57 +01:00
|
|
|
print(vban.bus[0].levels.all)
|
2022-03-18 07:40:24 +00:00
|
|
|
```
|
2022-04-27 20:00:30 +01:00
|
|
|
|
2022-07-16 21:56:20 +01:00
|
|
|
`levels.all` will return -200.0 if no audio detected.
|
|
|
|
|
2022-10-06 20:28:26 +01:00
|
|
|
### Strip | Bus
|
|
|
|
|
|
|
|
The following methods are available.
|
|
|
|
|
|
|
|
- `fadeto(amount, time)`: float, int
|
|
|
|
- `fadeby(amount, time)`: float, int
|
|
|
|
|
|
|
|
Modify gain to or by the selected amount in db over a time interval in ms.
|
|
|
|
|
|
|
|
example:
|
|
|
|
|
|
|
|
```python
|
|
|
|
vban.strip[0].fadeto(-10.3, 1000)
|
|
|
|
vban.bus[3].fadeby(-5.6, 500)
|
|
|
|
```
|
|
|
|
|
2022-06-16 16:10:06 +01:00
|
|
|
### Command
|
2022-03-18 07:40:24 +00:00
|
|
|
|
2022-06-16 16:10:06 +01:00
|
|
|
Certain 'special' commands are defined by the API as performing actions rather than setting values. The following methods are available:
|
2022-04-27 20:00:30 +01:00
|
|
|
|
2022-06-16 16:10:06 +01:00
|
|
|
- `show()` : Bring Voiceemeter GUI to the front
|
|
|
|
- `shutdown()` : Shuts down the GUI
|
|
|
|
- `restart()` : Restart the audio engine
|
2022-07-16 21:56:20 +01:00
|
|
|
- `reset()`: Applies the `reset` config. (phys strip B1, virt strip A1, gains, comp, gate 0.0, mute, mono, solo, eq false)
|
2022-04-27 20:00:30 +01:00
|
|
|
|
2022-06-16 16:10:06 +01:00
|
|
|
The following properties are write only and accept boolean values.
|
2022-02-27 18:57:16 +00:00
|
|
|
|
2022-06-16 16:10:06 +01:00
|
|
|
- `showvbanchat`: boolean
|
|
|
|
- `lock`: boolean
|
2022-04-27 20:00:30 +01:00
|
|
|
|
2022-06-16 16:10:06 +01:00
|
|
|
example:
|
2022-04-27 20:00:30 +01:00
|
|
|
|
2022-06-16 16:10:06 +01:00
|
|
|
```python
|
|
|
|
vban.command.restart()
|
|
|
|
vban.command.showvbanchat = true
|
|
|
|
```
|
|
|
|
|
|
|
|
### Multiple parameters
|
|
|
|
|
|
|
|
- `apply`
|
|
|
|
Set many strip/bus parameters at once, for example:
|
2022-03-18 07:40:24 +00:00
|
|
|
|
2022-06-16 16:10:06 +01:00
|
|
|
```python
|
2022-11-05 12:16:25 +00:00
|
|
|
vban.apply(
|
|
|
|
{
|
2025-01-17 02:54:23 +00:00
|
|
|
'strip-0': {'A1': True, 'B1': True, 'gain': -6.0},
|
|
|
|
'bus-1': {'mute': True, 'mode': 'composite'},
|
|
|
|
'bus-2': {'eq': {'on': True}},
|
|
|
|
'vban-in-0': {'on': True},
|
2022-11-05 12:16:25 +00:00
|
|
|
}
|
|
|
|
)
|
2022-06-16 16:10:06 +01:00
|
|
|
```
|
|
|
|
|
|
|
|
Or for each class you may do:
|
2022-04-27 20:00:30 +01:00
|
|
|
|
2022-03-18 07:40:24 +00:00
|
|
|
```python
|
2025-01-17 02:54:23 +00:00
|
|
|
vban.strip[0].apply({'mute': True, 'gain': 3.2, 'A1': True})
|
|
|
|
vban.vban.outstream[0].apply({'on': True, 'name': 'streamname', 'bit': 24})
|
2022-03-18 07:40:24 +00:00
|
|
|
```
|
|
|
|
|
2022-06-16 16:56:20 +01:00
|
|
|
## Config Files
|
|
|
|
|
2022-06-16 18:58:18 +01:00
|
|
|
`vban.apply_config(<configname>)`
|
2022-06-16 16:56:20 +01:00
|
|
|
|
|
|
|
You may load config files in TOML format.
|
2022-07-16 21:56:20 +01:00
|
|
|
Three example configs have been included with the package. Remember to save
|
2023-07-11 20:27:52 +01:00
|
|
|
current settings before loading a user config. To load one you may do:
|
2022-06-16 16:56:20 +01:00
|
|
|
|
|
|
|
```python
|
|
|
|
import vban_cmd
|
|
|
|
with vban_cmd.api('banana') as vban:
|
2022-06-16 18:58:18 +01:00
|
|
|
vban.apply_config('example')
|
2022-06-16 16:56:20 +01:00
|
|
|
```
|
|
|
|
|
2022-06-16 19:24:28 +01:00
|
|
|
will load a config file at configs/banana/example.toml for Voicemeeter Banana.
|
2022-06-16 16:56:20 +01:00
|
|
|
|
2023-07-11 20:27:52 +01:00
|
|
|
Your configs may be located in one of the following paths:
|
|
|
|
- \<current working directory\> / "configs" / kind_id
|
|
|
|
- \<user home directory\> / ".config" / "vban-cmd" / kind_id
|
|
|
|
- \<user home directory\> / "Documents" / "Voicemeeter" / "configs" / kind_id
|
|
|
|
|
|
|
|
If a config with the same name is located in multiple locations, only the first one found is loaded into memory, in the above order.
|
|
|
|
|
|
|
|
#### `config extends`
|
|
|
|
|
|
|
|
You may also load a config that extends another config with overrides or additional parameters.
|
|
|
|
|
|
|
|
You just need to define a key `extends` in the config TOML, that names the config to be extended.
|
|
|
|
|
|
|
|
Three example 'extender' configs are included with the repo. You may load them with:
|
|
|
|
|
|
|
|
```python
|
|
|
|
import voicemeeterlib
|
|
|
|
with voicemeeterlib.api('banana') as vm:
|
|
|
|
vm.apply_config('extender')
|
|
|
|
```
|
|
|
|
|
2022-09-28 18:15:08 +01:00
|
|
|
## Events
|
2022-08-02 09:32:23 +01:00
|
|
|
|
2022-09-28 18:15:08 +01:00
|
|
|
Level updates are considered high volume, by default they are NOT listened for. Use `subs` keyword arg to initialize event updates.
|
2022-08-02 09:32:23 +01:00
|
|
|
|
|
|
|
example:
|
|
|
|
|
|
|
|
```python
|
|
|
|
import vban_cmd
|
2025-01-17 02:54:23 +00:00
|
|
|
|
2022-08-02 09:32:23 +01:00
|
|
|
opts = {
|
2025-01-17 02:54:23 +00:00
|
|
|
'ip': '<ip address>',
|
|
|
|
'streamname': 'Command1',
|
|
|
|
'port': 6980,
|
2022-08-02 09:32:23 +01:00
|
|
|
}
|
2023-06-25 18:40:09 +01:00
|
|
|
with vban_cmd.api('banana', ldirty=True, **opts) as vban:
|
2022-08-02 09:32:23 +01:00
|
|
|
...
|
|
|
|
```
|
|
|
|
|
2022-09-28 18:15:08 +01:00
|
|
|
#### `vban.subject`
|
|
|
|
|
|
|
|
Use the Subject class to register an app as event observer.
|
|
|
|
|
|
|
|
The following methods are available:
|
|
|
|
|
|
|
|
- `add`: registers an app as an event observer
|
|
|
|
- `remove`: deregisters an app as an event observer
|
|
|
|
|
|
|
|
example:
|
|
|
|
|
|
|
|
```python
|
2022-10-06 16:45:15 +01:00
|
|
|
# register an app to receive updates
|
|
|
|
class App():
|
|
|
|
def __init__(self, vban):
|
|
|
|
vban.subject.add(self)
|
|
|
|
...
|
2022-09-28 18:15:08 +01:00
|
|
|
```
|
|
|
|
|
2022-08-06 10:51:35 +01:00
|
|
|
#### `vban.event`
|
2022-08-02 09:32:23 +01:00
|
|
|
|
2022-10-06 16:45:15 +01:00
|
|
|
Use the event class to toggle updates as necessary.
|
|
|
|
|
|
|
|
The following properties are available:
|
|
|
|
|
|
|
|
- `pdirty`: boolean
|
|
|
|
- `ldirty`: boolean
|
2022-08-02 09:32:23 +01:00
|
|
|
|
|
|
|
example:
|
|
|
|
|
|
|
|
```python
|
2022-10-06 16:45:15 +01:00
|
|
|
vban.event.ldirty = True
|
2022-08-02 09:32:23 +01:00
|
|
|
|
2022-10-06 16:45:15 +01:00
|
|
|
vban.event.pdirty = False
|
2022-10-06 18:07:41 +01:00
|
|
|
```
|
|
|
|
|
|
|
|
Or add, remove a list of events.
|
|
|
|
|
|
|
|
The following methods are available:
|
|
|
|
|
|
|
|
- `add()`
|
|
|
|
- `remove()`
|
|
|
|
- `get()`
|
|
|
|
|
|
|
|
example:
|
|
|
|
|
|
|
|
```python
|
2025-01-17 02:54:23 +00:00
|
|
|
vban.event.remove(['pdirty', 'ldirty'])
|
2022-08-02 09:32:23 +01:00
|
|
|
|
|
|
|
# get a list of currently subscribed
|
2022-08-06 10:51:35 +01:00
|
|
|
print(vban.event.get())
|
2022-08-02 09:32:23 +01:00
|
|
|
```
|
|
|
|
|
2022-09-28 20:01:17 +01:00
|
|
|
## VbanCmd class
|
|
|
|
|
2023-06-25 18:40:09 +01:00
|
|
|
`vban_cmd.api(kind_id: str, **opts)`
|
2022-09-28 20:01:17 +01:00
|
|
|
|
|
|
|
You may pass the following optional keyword arguments:
|
|
|
|
|
|
|
|
- `ip`: str, ip or hostname of remote machine
|
|
|
|
- `streamname`: str, name of the stream to connect to.
|
|
|
|
- `port`: int=6980, vban udp port of remote machine.
|
2023-07-05 02:55:42 +01:00
|
|
|
- `pdirty`: boolean=False, parameter updates
|
|
|
|
- `ldirty`: boolean=False, level updates
|
2023-07-05 03:19:57 +01:00
|
|
|
- `timeout`: int=5, amount of time (seconds) to wait for an incoming RT data packet (parameter states).
|
2023-07-05 14:08:27 +01:00
|
|
|
- `outbound`: boolean=False, set `True` if you are only interested in sending commands. (no rt packets will be received)
|
2022-09-28 20:01:17 +01:00
|
|
|
|
2022-04-29 21:57:16 +01:00
|
|
|
#### `vban.pdirty`
|
|
|
|
|
2022-06-18 14:07:50 +01:00
|
|
|
True iff a parameter has been changed.
|
2022-04-29 21:57:16 +01:00
|
|
|
|
2022-06-18 14:07:50 +01:00
|
|
|
#### `vban.ldirty`
|
2022-04-27 20:00:30 +01:00
|
|
|
|
2022-06-18 14:07:50 +01:00
|
|
|
True iff a level value has been changed.
|
|
|
|
|
|
|
|
#### `vban.sendtext(script)`
|
|
|
|
|
2022-07-16 21:56:20 +01:00
|
|
|
Sends a script block as a string request, for example:
|
2022-04-27 20:00:30 +01:00
|
|
|
|
2022-02-28 14:03:51 +00:00
|
|
|
```python
|
2025-01-17 02:54:23 +00:00
|
|
|
vban.sendtext('Strip[0].Mute=1;Bus[0].Mono=1')
|
2022-02-28 14:03:51 +00:00
|
|
|
```
|
2022-02-27 18:57:16 +00:00
|
|
|
|
2023-07-13 08:58:06 +01:00
|
|
|
## Errors
|
2022-04-27 20:00:30 +01:00
|
|
|
|
2023-08-19 19:56:35 +01:00
|
|
|
- `errors.VBANCMDError`: Base VBANCMD Exception class.
|
2023-06-27 15:36:53 +01:00
|
|
|
- `errors.VBANCMDConnectionError`: Exception raised when connection/timeout errors occur.
|
2022-02-27 18:57:16 +00:00
|
|
|
|
2023-07-13 08:50:24 +01:00
|
|
|
## Logging
|
|
|
|
|
|
|
|
It's possible to see the messages sent by the interface's setters and getters, may be useful for debugging.
|
|
|
|
|
|
|
|
example:
|
|
|
|
```python
|
2023-07-13 08:52:42 +01:00
|
|
|
import vban_cmd
|
2023-07-13 08:50:24 +01:00
|
|
|
|
|
|
|
logging.basicConfig(level=logging.DEBUG)
|
|
|
|
|
2025-01-17 02:54:23 +00:00
|
|
|
opts = {'ip': 'ip.local', 'port': 6980, 'streamname': 'Command1'}
|
2023-07-13 08:52:42 +01:00
|
|
|
with vban_cmd.api('banana', **opts) as vban:
|
2025-01-17 02:54:23 +00:00
|
|
|
...
|
2023-07-13 08:50:24 +01:00
|
|
|
```
|
|
|
|
|
2023-07-13 08:58:06 +01:00
|
|
|
## Tests
|
2022-04-27 20:00:30 +01:00
|
|
|
|
2022-02-27 18:57:16 +00:00
|
|
|
First make sure you installed the [development dependencies](https://github.com/onyx-and-iris/vban-cmd-python#installation)
|
|
|
|
|
2022-04-27 20:00:30 +01:00
|
|
|
Then from tests directory:
|
2022-02-27 18:57:16 +00:00
|
|
|
|
2022-04-27 20:00:30 +01:00
|
|
|
`pytest -v`
|
2022-02-27 18:57:16 +00:00
|
|
|
|
|
|
|
## Resources
|
2022-04-27 20:00:30 +01:00
|
|
|
|
2022-04-30 16:57:47 +01:00
|
|
|
- [Voicemeeter VBAN TEXT](https://vb-audio.com/Voicemeeter/VBANProtocol_Specifications.pdf#page=19)
|
|
|
|
|
|
|
|
- [Voicemeeter RT Packet Service](https://vb-audio.com/Voicemeeter/VBANProtocol_Specifications.pdf#page=27)
|