Compare commits

..

6 Commits

5 changed files with 39 additions and 12 deletions

View File

@@ -42,7 +42,7 @@ with voicemeeterlib.api(KIND_ID, sync=True) as vm:
window.run() window.run()
``` ```
### `KIND_ID` ### KIND_ID
May be one of the following: May be one of the following:
@@ -84,6 +84,16 @@ The `Save Settings` option opens a popup window with two buttons, `Browse` and `
If you have any questions/suggestions feel free to raise an issue or open a new discussion. If you have any questions/suggestions feel free to raise an issue or open a new discussion.
### Special Thanks
[Mario Loreti](https://www.marioloreti.net/en/) for his help in testing and offering feedback during development.
[NVAccess](https://www.nvaccess.org/) for creating the open source NVDA screen reader and its controller client.
[Vincent Burel](https://github.com/vburel2018) for creating Voicemeeter and its SDK.
[PySimpleGUI](https://github.com/PySimpleGUI) team for creating an awesome GUI framework.
[voicemeeter]: https://voicemeeter.com/ [voicemeeter]: https://voicemeeter.com/
[nvda]: https://www.nvaccess.org/ [nvda]: https://www.nvaccess.org/
[controller_client]: https://github.com/nvaccess/nvda/tree/master/extras/controllerClient [controller_client]: https://github.com/nvaccess/nvda/tree/master/extras/controllerClient

View File

@@ -1,6 +1,6 @@
[project] [project]
name = "nvda_voicemeeter" name = "nvda_voicemeeter"
version = "0.1.1" version = "0.1.3"
description = "A Voicemeeter app compatible with NVDA" description = "A Voicemeeter app compatible with NVDA"
authors = [ authors = [
{ name = "onyx-and-iris", email = "code@onyxandiris.online" }, { name = "onyx-and-iris", email = "code@onyxandiris.online" },

View File

@@ -325,12 +325,18 @@ class Builder:
"""tab3 row represents bus composite toggle""" """tab3 row represents bus composite toggle"""
def add_strip_outputs(layout): def add_strip_outputs(layout):
params = ["MONO", "EQ", "MUTE", "MODE"]
if self.vm.kind.name == "basic":
params.remove("EQ")
label = {"MODE": "BUSMODE"}
layout.append( layout.append(
[ [
psg.Button("Mono", size=(6, 2), key=f"BUS {i}||MONO"), psg.Button(
psg.Button("EQ", size=(6, 2), key=f"BUS {i}||EQ"), label.get(param, param.capitalize()),
psg.Button("Mute", size=(6, 2), key=f"BUS {i}||MUTE"), size=(12 if param == "MODE" else 6, 2),
psg.Button(f"BUSMODE", size=(12, 2), key=f"BUS {i}||MODE"), key=f"BUS {i}||{param}",
)
for param in params
] ]
) )

View File

@@ -94,7 +94,14 @@ def get_channel_identifier_list(vm) -> list:
return identifiers return identifiers
def get_bus_modes() -> list: def get_bus_modes(vm) -> list:
if vm.kind.name == "basic":
return [
"normal",
"amix",
"repeat",
"composite",
]
return [ return [
"normal", "normal",
"amix", "amix",

View File

@@ -185,8 +185,11 @@ class NVDAVMWindow(psg.Window):
self[f"STRIP {i}||{param}"].bind("<Return>", "||KEY ENTER") self[f"STRIP {i}||{param}"].bind("<Return>", "||KEY ENTER")
# Bus Params # Bus Params
params = ["MONO", "EQ", "MUTE", "MODE"]
if self.vm.kind.name == "basic":
params.remove("EQ")
for i in range(self.kind.num_bus): for i in range(self.kind.num_bus):
for param in ("MONO", "EQ", "MUTE", "MODE"): for param in params:
self[f"BUS {i}||{param}"].bind("<FocusIn>", "||FOCUS IN") self[f"BUS {i}||{param}"].bind("<FocusIn>", "||FOCUS IN")
self[f"BUS {i}||{param}"].bind("<Return>", "||KEY ENTER") self[f"BUS {i}||{param}"].bind("<Return>", "||KEY ENTER")
@@ -234,9 +237,9 @@ class NVDAVMWindow(psg.Window):
def popup_rename(self, message, title=None, tab=None): def popup_rename(self, message, title=None, tab=None):
if tab == "Physical Strip": if tab == "Physical Strip":
upper = self.kind.phys_out + 1 upper = self.kind.phys_in + 1
elif tab == "Virtual Strip": elif tab == "Virtual Strip":
upper = self.kind.virt_out + 1 upper = self.kind.virt_in + 1
elif tab == "Buses": elif tab == "Buses":
upper = self.kind.num_bus + 1 upper = self.kind.num_bus + 1
@@ -320,7 +323,8 @@ class NVDAVMWindow(psg.Window):
self[f"STRIP {index}||LABEL"].update(value=label) self[f"STRIP {index}||LABEL"].update(value=label)
self.cache["labels"][f"STRIP {index}||LABEL"] = label self.cache["labels"][f"STRIP {index}||LABEL"] = label
case "Virtual Strip": case "Virtual Strip":
label = data.get("Edit") or f"Virtual Input {index + 1}" index += self.kind.phys_in
label = data.get("Edit") or f"Virtual Input {index - self.kind.phys_in + 1}"
self.vm.strip[index].label = label self.vm.strip[index].label = label
self[f"STRIP {index}||LABEL"].update(value=label) self[f"STRIP {index}||LABEL"].update(value=label)
self.cache["labels"][f"STRIP {index}||LABEL"] = label self.cache["labels"][f"STRIP {index}||LABEL"] = label
@@ -583,7 +587,7 @@ class NVDAVMWindow(psg.Window):
f"{label} bus {param} {'on' if val else 'off'}", f"{label} bus {param} {'on' if val else 'off'}",
) )
case "MODE": case "MODE":
bus_modes = get_bus_modes() bus_modes = get_bus_modes(self.vm)
next_index = bus_modes.index(val) + 1 next_index = bus_modes.index(val) + 1
if next_index == len(bus_modes): if next_index == len(bus_modes):
next_index = 0 next_index = 0