Python interface for the VBAN RT Packet Service (Sendtext)
Go to file
onyx-and-iris 89dec75b98 typo fix
2022-04-29 22:31:22 +01:00
_profiles add profiles 2022-03-23 11:28:42 +00:00
examples/gui Update README.md 2022-03-05 23:22:27 +00:00
tests del file 2022-04-29 22:24:41 +01:00
vbancmd fix doc string 2022-04-29 22:07:44 +01:00
__main__.py Update __main__.py 2022-03-04 14:30:51 +00:00
.gitattributes Initial commit 2022-02-25 14:35:32 +00:00
.gitignore Initial commit 2022-02-25 14:35:32 +00:00
LICENSE Create LICENSE 2022-03-09 06:29:59 +00:00
README.md typo fix 2022-04-29 22:31:22 +01:00
setup.py add pre-commit hook 2022-04-28 11:34:48 +01:00

License: MIT Code style: black Tests Status Tests Status Tests Status

VBAN CMD

This package offers a Python interface for Voicemeeter VBAN TEXT as well as the Voicemeeter RT Packet Service which allows a client to send and receive parameter values over a local network.

It may be used standalone or to extend the Voicemeeter Remote Python API

For sending audio across a network with VBAN you will need to look elsewhere.

Tested against

  • Basic 1.0.8.1
  • Banana 2.0.6.1
  • Potato 3.0.2.1

Prerequisites

  • Voicemeeter 1 (Basic), 2 (Banana) or 3 (Potato)
  • Python 3.9+

Installation

git clone https://github.com/onyx-and-iris/vban-cmd-python
cd vban-cmd-python

Just the interface:

pip install .

With development dependencies:

pip install -e .['development']

Usage

Use with a context manager:

Parameter coverage is not as extensive for the RT Packet Service as with the Remote API.

Example 1

import vbancmd

class ManyThings:
    def __init__(self, vban):
        self.vban = vban

    def things(self):
        # Set the mapping of the second input strip
        self.vban.strip[1].A3 = True
        print(f'Output A3 of Strip {self.vban.strip[1].label}: {self.vban.strip[1].A3}')

    def other_things(self):
        # Toggle mute for the leftmost output bus
        self.vban.bus[0].mute = not self.vban.bus[0].mute


def main():
    with vbancmd.connect(kind_id, ip=ip) as vban:
        do = ManyThings(vban)
        do.things()
        do.other_things()

if __name__ == '__main__':
    kind_id = 'potato'
    ip = '<ip address>'

    main()

Or perform setup/teardown independently:

for example:

Example 2

import vbancmd

kind_id = 'potato'
ip = '<ip address>'

vban = vbancmd.connect(kind_id, ip=ip)

# call login() at the start of your code
vban.login()

# Toggle mute for leftmost input strip
vban.strip[0].mute = not vban.strip[0].mute

# Toggle eq for leftmost output bus
vban.bus[0].eq = not vban.bus[0].eq

# call logout() at the end of your code
vban.logout()

Profiles

Profiles through config files are supported.

Three example profiles are provided with the package, one for each kind of Voicemeeter. To test one first rename _profiles directory to profiles. They will be loaded into memory but not applied. To apply one you may do: vmr.apply_profile('config'), but remember to save your current settings first.

profiles directory can be safely deleted if you don't wish to load them each time.

A config can contain any key that connect.apply() would accept. Additionally, extends can be provided to inherit from another profile. Two profiles are available by default:

  • blank, all strip off and all sliders to 0.0. mono, solo, mute, eq all disabled.
  • base, all physical strip to A1, all virtual strip to B1, all sliders to 0.0.

Sample mySetup.toml

extends = 'base'
[strip-0]
mute = 1

[strip-5]
A1 = 0
A2 = 1
A4 = 1
gain = 0.0

[strip-6]
A1 = 0
A2 = 1
A4 = 1
gain = 0.0

API

Kinds

A kind specifies a major Voicemeeter version. Currently this encompasses

  • basic
  • banana
  • potato

vbancmd.connect(kind_id, **kwargs) -> '(VbanCmd)'

Factory function for remotes. Keyword arguments include:

  • ip: remote pc you wish to send requests to.
  • streamname: default 'Command1'
  • port: default 6990
  • channel: from 0 to 255
  • bps: bitrate of stream, default 0 should be safe for most cases.

VbanCmd (higher level)

vban.type

The kind of the Voicemeeter instance.

vban.version

A tuple of the form (v1, v2, v3, v4).

vban.strip

An InputStrip tuple, containing both physical and virtual.

vban.bus

An OutputBus tuple, containing both physical and virtual.

vban.show()

Shows Voicemeeter if it's hidden. No effect otherwise.

vban.hide()

Hides Voicemeeter if it's shown. No effect otherwise.

vban.shutdown()

Closes Voicemeeter.

vban.restart()

Restarts Voicemeeter's audio engine.

vban.apply(mapping)

Updates values through a dict.
Example:

vban.apply({
    'strip-2': dict(A1=True, B1=True, gain=-6.0),
    'bus-2': dict(mute=True),
})

Strip

The following properties are gettable and settable:

  • mono: boolean
  • solo: boolean
  • mute: boolean
  • label: string
  • gain: float, -60 to 12
  • Output mapping (e.g. A1, B3, etc.): boolean, depends on the Voicemeeter kind

The following properties are settable:

  • comp: float, from 0.0 to 10.0
  • gate: float, from 0.0 to 10.0
  • limit: int, from -40 to 12

gainlayer

  • gainlayer[j].gain: float, -60 to 12

for example:

# set and get the value of the second input strip, fourth gainlayer
vban.strip[1].gainlayer[3].gain = -6.3
print(vban.strip[1].gainlayer[3].gain)

Gainlayers defined for Potato version only.

Bus

The following properties are gettable and settable:

  • mute: boolean
  • mono: boolean
  • eq: boolean
  • eq_ab: boolean
  • label: string
  • gain: float, -60 to 12

mode

Bus modes are gettable and settable

  • normal, amix, bmix, repeat, composite, tvmix, upmix21,
  • upmix41, upmix61, centeronly, lfeonly, rearonly

for example:

# set leftmost bus mode to tvmix
vban.bus[0].mode.tvmix = True

VbanCmd (lower level)

vban.pdirty

True iff a parameter has been changed. Typically this is checked periodically to update states.

vban.set_rt(id_, param, val)

Sends a string request RT Packet where the command would take the form:

f'{id_}.{param}={val}'

vban.public_packet

Returns a Voicemeeter rt data packet. Designed to be used internally by the interface but available for parsing through this read only property object. States may or may not be current, use the polling parameter pdirty to be sure.

Errors

  • errors.VMCMDErrors: Base VMCMD error class.

Tests

First make sure you installed the development dependencies

Then from tests directory:

pytest -v

Resources