GetType, GetVersion, SendText added to Remote class. Console output now written to Debug stream. ToString() method overriden for higher classes. formatter run through all files.
Powershell Wrapper for Voicemeeter API
This module offers a Powershell interface for the Voicemeeter Remote C API.
For past/future changes to this project refer to: CHANGELOG
Tested against
- Basic 1.0.8.4
- Banana 2.0.6.4
- Potato 3.0.2.4
Requirements
- Voicemeeter
- Powershell 5.1
Installation
PowerShellGet:
In Powershell as admin:
Install-Module Voicemeeter
In Powershell as current user:
Install-Module -Name Voicemeeter -Scope CurrentUser
You may be asked to install NuGet provider required by PowerShellGet if you don't have it already.
When prompted you will need to accept PSGallery as a trusted repository.
More Info:
Direct download:
git clone https://github.com/onyx-and-iris/voicemeeter-api-powershell.git
All examples in this readme assume you've installed as a module. If you decide to direct download see alternative instructions.
Use
As a script file
When you instantiate Remote class you will automatically be logged in. Use a try finally block to ensure you logout at the end of your code.
Import-Module Voicemeeter
try {
# Run the factory function for required Voicemeeter type
$vmr = Get-RemoteBanana
# Set strip and bus params
$vmr.strip[0].mono = $true
$vmr.strip[0].mono '=> $true'
$vmr.bus[1].mute = $false
$vmr.bus[1].mute '=> $false'
# Set macrobutton with id 4, mode state to 1
$vmr.button[4].state = $true
$vmr.button[4].state '=> $true'
}
finally { $vmr.Logout() }
Voicemeeter factory function can be:
- Get-RemoteBasic
- Get-RemoteBanana
- Get-RemotePotato
As a CLI
As well as storing scripts into files and running them you can invoke script blocks straight through Powershell. A quick note, since you cannot Login more than once in a single session you ought to run any commands through a subshell. Assuming you have installed as a module you could run this command:
powershell { $vmr = Get-RemoteBanana; $vmr.strip[0].mute=$true; $vmr.Logout() }
Getters should also work, for example:
# Print the value of strip 0 mute to console
powershell { $vmr = Get-RemoteBanana; Write-Host "Strip 0 mute =", $vmr.strip[0].mute; $vmr.Logout() }
# Toggle strip 0 mute
powershell { $vmr = Get-RemoteBanana; $vmr.strip[0].mute=!$vmr.strip[0].mute; $vmr.Logout() }
So you essentialy have a CLI.
Strip
The following strip commands are available:
- mute: bool
- mono: bool
- mc: bool
- k: int, from 0 to 4
- solo: bool
- A1-A5: bool
- B1-B3: bool
- limit: int, from -40 to 12
- gain: float, from -60.0 to 12.0
- comp: float, from 0.0 to 10.0
- gate: float, from 0.0 to 10.0
- label: string
- device: string
- sr: int
- gainlayer0-gainlayer7: float
for example:
$vmr.strip[5].gainlayer1 = -8.3
A,B commands depend on Voicemeeter type.
gainlayers defined for Potato version only.
mc, k for virtual strips only.
Bus
The following bus commands are available:
- mute: bool
- mono: bool
- eq: bool
- limit: int, from -40 to 12
- gain: float, from -60.0 to 12.0
- label: string
- device: string
- sr: int
- mode_: bool, any of the following: @('normal', 'amix', 'bmix', 'repeat', 'composite', 'tvmix', 'upmix21', 'upmix41', 'upmix61', 'centeronly', 'lfeonly', 'rearonly')
for example:
$vmr.bus[3].mode_repeat = $true
Strip|Bus
FadeTo(amount, time)
: float, intFadeBy(amount, time)
: float, int
Modify gain to or by the selected amount in db over a time interval in ms.
for example:
$vmr.strip[3].FadeTo(-18.7, 1000)
$vmr.bus[0].FadeBy(-10, 500)
Macrobuttons
Three modes defined: state, stateonly and trigger.
- State runs associated scripts
- Stateonly does not run associated scripts
- Index range (0, 69)
$vmr.button[3].state = $true
$vmr.button[4].stateonly = $false
$vmr.button[5].trigger = $true
VBAN
- vmr.vban.enable: Toggle VBAN on or off. Accepts a boolean value.
For each vban in/out stream the following parameters are defined:
- on: boolean
- name: string
- ip: string
- port: int from 1024 - 65535
- sr: int (11025, 16000, 22050, 24000, 32000, 44100, 48000, 64000, 88200, 96000)
- channel: int from 1 to 8
- bit: int 16 or 24
- quality: int from 0 to 4
- route: int from 0 to 8
SR, channel and bit are defined as readonly for instreams. Attempting to write to those parameters will throw an error. They are read and write for outstreams.
example:
$vmr.vban.enable = $true
$vmr.vban.instream[0].on = $true
$vmr.vban.instream[2].port = 6990
$vmr.vban.outstream[3].bit = 16
Command
Certain 'special' commands are defined by the API as performing actions rather than setting values.
The following methods are available:
- show
- hide
- restart
- shutdown
The following properties are write only and accept boolean values:
- showvbanchat
- lock
example:
$vmr.command.show
$vmr.command.lock = $true
Recorder
The following methods are available:
- play
- stop
- pause
- record
- ff
- rew
The following properties accept boolean values.
- loop
- A1 - A5
- B1 - B3
example:
$vmr.recorder.play
$vmr.recorder.loop = $true
Multiple parameters
Set many strip/bus/macrobutton/vban parameters at once, for Example
Import-Module Voicemeeter
try {
$vmr = Get-RemoteBanana
$hash = @{
strip_0 = @{mute = $true; mono = $true};
strip_2 = @{mute = $true; mono = $true};
bus_1 = @{mute = $true; mono = $true};
button_34 = @{state = $true};
button_12 = @{trigger = $false};
vban_instream_3 = @{name = 'streamname'};
vban_outstream_0 = @{on = $false};
}
$vmr.Set_Multi($hash)
}
finally { $vmr.Logout() }
Config Files
$vmr.Set_Profile(<configname>)
You may load config files in psd1 format. An example profile has been included with the package. Remember to save current settings before loading a profile. To test simply rename _profiles directory to profiles. It will be loaded into memory but not set. To set one you may do:
Import-Module Voicemeeter
try {
$vmr = Get-RemoteBanana
$vmr.Set_Profile("config")
}
finally { $vmr.Logout() }
will load a config file at profiles/banana/config.psd1 for Voicemeeter Banana.
Remote class
Access to lower level Getters and Setters are provided with these functions:
$vmr.Getter(param)
: For getting the value of a parameter expected to return a value other than string.$vmr.Getter_String(param)
: For getting the value of any parameter expected to return a string.$vmr.Setter(param, value)
: For setting the value of any parameter.
Access to lower level polling functions are provided with these functions:
$vmr.PDirty
: Returns true if a parameter has been updated.$vmr.MDirty
: Returns true if a macrobutton has been updated.
example:
$vmr.Getter('Strip[2].Mute')
$vmr.Getter_String('Bus[1].Label')
$vmr.Setter('Strip[4].Label', 'stripname')
$vmr.Setter('Strip[0].Gain', -3.6)
Run tests
Run tests using .\runall.ps1 which accepts two parameters:
- tag Run tests of this type
- num Run this number of tests
Current test types are 'higher' and 'lower'
Example:
.\runall.ps1 -tag 'higher' -num 3
Results will be logged and summary file written.