mirror of
https://github.com/onyx-and-iris/nvda-addon-voicemeeter.git
synced 2026-03-20 20:09:11 +00:00
Controller no longer subclasses Binds.
add some wrapper methods to binds
This commit is contained in:
parent
c3b06cae51
commit
84ee479bf1
@ -38,8 +38,32 @@ class Binds:
|
|||||||
bind_set_parameter_float.restype = LONG
|
bind_set_parameter_float.restype = LONG
|
||||||
bind_set_parameter_float.argtypes = [ct.POINTER(CHAR), FLOAT]
|
bind_set_parameter_float.argtypes = [ct.POINTER(CHAR), FLOAT]
|
||||||
|
|
||||||
def call(self, fn, *args, ok=(0,)):
|
def _call(self, fn, *args, ok=(0,)):
|
||||||
retval = fn(*args)
|
retval = fn(*args)
|
||||||
if retval not in ok:
|
if retval not in ok:
|
||||||
raise VMAddonCAPIError(fn.__name__, retval)
|
raise VMAddonCAPIError(fn.__name__, retval)
|
||||||
return retval
|
return retval
|
||||||
|
|
||||||
|
def login(self):
|
||||||
|
return self._call(self.bind_login)
|
||||||
|
|
||||||
|
def logout(self):
|
||||||
|
return self._call(self.bind_logout)
|
||||||
|
|
||||||
|
def run_voicemeeter(self, kind_val):
|
||||||
|
return self._call(self.bind_run_voicemeeter, kind_val)
|
||||||
|
|
||||||
|
def get_voicemeeter_type(self, c_type):
|
||||||
|
return self._call(self.bind_get_voicemeeter_type, ct.byref(c_type))
|
||||||
|
|
||||||
|
def get_voicemeeter_version(self, ver):
|
||||||
|
return self._call(self.bind_get_voicemeeter_version, ct.byref(ver))
|
||||||
|
|
||||||
|
def is_parameters_dirty(self):
|
||||||
|
return self._call(self.bind_is_parameters_dirty, ok=(0, 1))
|
||||||
|
|
||||||
|
def get_parameter_float(self, param, buf):
|
||||||
|
return self._call(self.bind_get_parameter_float, param, ct.byref(buf))
|
||||||
|
|
||||||
|
def set_parameter_float(self, param, val):
|
||||||
|
return self._call(self.bind_set_parameter_float, param, val)
|
||||||
|
|||||||
@ -9,30 +9,31 @@ from .context import Context, StripStrategy
|
|||||||
from .kinds import KindId
|
from .kinds import KindId
|
||||||
|
|
||||||
|
|
||||||
class Controller(Binds):
|
class Controller:
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
|
self._binds = Binds()
|
||||||
self.ctx = Context(StripStrategy(self, 0))
|
self.ctx = Context(StripStrategy(self, 0))
|
||||||
self.bits = config.get('bits', BITS)
|
self.bits = config.get('bits', BITS)
|
||||||
|
|
||||||
def login(self):
|
def login(self):
|
||||||
retval = self.call(self.bind_login, ok=(0, 1))
|
retval = self._binds.login()
|
||||||
log.info('INFO - logged into Voicemeeter Remote API')
|
log.info('INFO - logged into Voicemeeter Remote API')
|
||||||
return retval
|
return retval
|
||||||
|
|
||||||
def logout(self):
|
def logout(self):
|
||||||
self.call(self.bind_logout)
|
self._binds.logout()
|
||||||
log.info('NFO - logged out of Voicemeeter Remote API')
|
log.info('NFO - logged out of Voicemeeter Remote API')
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def kind_id(self):
|
def kind_id(self):
|
||||||
c_type = ct.c_long()
|
c_type = ct.c_long()
|
||||||
self.call(self.bind_get_voicemeeter_type, ct.byref(c_type))
|
self._binds.get_voicemeeter_type(c_type)
|
||||||
return KindId(c_type.value).name.lower()
|
return KindId(c_type.value).name.lower()
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def version(self):
|
def version(self):
|
||||||
ver = ct.c_long()
|
ver = ct.c_long()
|
||||||
self.call(self.bind_get_voicemeeter_version, ct.byref(ver))
|
self._binds.get_voicemeeter_version(ver)
|
||||||
return '{}.{}.{}.{}'.format(
|
return '{}.{}.{}.{}'.format(
|
||||||
(ver.value & 0xFF000000) >> 24,
|
(ver.value & 0xFF000000) >> 24,
|
||||||
(ver.value & 0x00FF0000) >> 16,
|
(ver.value & 0x00FF0000) >> 16,
|
||||||
@ -44,17 +45,17 @@ class Controller(Binds):
|
|||||||
val = kind_id.value
|
val = kind_id.value
|
||||||
if self.bits == 64:
|
if self.bits == 64:
|
||||||
val += 3
|
val += 3
|
||||||
self.call(self.bind_run_voicemeeter, val)
|
self._binds.run_voicemeeter(val)
|
||||||
|
|
||||||
def __clear(self):
|
def __clear(self):
|
||||||
while self.call(self.bind_is_parameters_dirty, ok=(0, 1)) == 1:
|
while self._binds.is_parameters_dirty() == 1:
|
||||||
pass
|
pass
|
||||||
|
|
||||||
def _get(self, param):
|
def get(self, param):
|
||||||
self.__clear()
|
self.__clear()
|
||||||
buf = ct.c_float()
|
buf = ct.c_float()
|
||||||
self.call(self.bind_get_parameter_float, param.encode(), ct.byref(buf))
|
self._binds.get_parameter_float(param.encode(), buf)
|
||||||
return buf.value
|
return buf.value
|
||||||
|
|
||||||
def _set(self, param, val):
|
def set(self, param, val):
|
||||||
self.call(self.bind_set_parameter_float, param.encode(), ct.c_float(float(val)))
|
self._binds.set_parameter_float(param.encode(), ct.c_float(float(val)))
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user