Python interface for the VBAN RT Packet Service (Sendtext)
Go to file
2022-03-09 06:29:59 +00:00
examples/gui Update README.md 2022-03-05 23:22:27 +00:00
tests update tests 2022-03-05 20:22:10 +00:00
vbancmd Update vbancmd.py 2022-03-05 20:11:10 +00: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 Update README.md 2022-03-06 14:44:30 +00:00
setup.py remove underscore from package name 2022-03-04 14:22:29 +00:00

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 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']

Connection:

For sending a text command several configuration options are available:

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

Use with a context manager:

It is advised to use this code 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()

API

Kinds

A kind specifies a major Voicemeeter version. Currently this encompasses

  • basic
  • banana
  • potato

vbancmd.connect(kind_id, ip=ip) -> '(VbanCmd)'

Factory function for remotes.

  • ip: remote pc you wish to send requests to.

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.sendtext(cmd)

Sends a TEXT command, for example:

# Use ';' or ',' for delimiters.
vban.sendtext('Strip[0].Mute=1;Strip[3].A3=0;Bus[2].Mute=0;Bus[3].Eq.On=1')

Strip

The following properties are gettable and settable:

  • mono: boolean
  • solo: boolean
  • mute: boolean
  • label: string
  • gainlayer: float, -60 to 12
  • 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

Bus

The following properties are gettable and settable:

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

VbanCmd (lower level)

vban.set_rt(id_, param, val)

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

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

vban._get_rt()

Used for updating the RT data packet, used internally by the Interface.

vban.public_packet = vban._get_rt()

Errors

  • errors.VMCMDErrors: Base VMCMD error class.

Tests

First make sure you installed the development dependencies

To run the tests from tests directory:

nosetests --r test -v

Resources