mirror of
https://github.com/onyx-and-iris/xair-api-python.git
synced 2024-11-24 22:00:57 +00:00
from_db, to_db decorator functions added to util.
_get_{fader,level}_val, _set_{fader,level}_val removed
This commit is contained in:
parent
27d0811091
commit
467b769ea4
@ -1,3 +1,4 @@
|
|||||||
|
import functools
|
||||||
from math import exp, log
|
from math import exp, log
|
||||||
|
|
||||||
|
|
||||||
@ -17,61 +18,48 @@ def log_set(min, max, val):
|
|||||||
return log(val / min) / log(max / min)
|
return log(val / min) / log(max / min)
|
||||||
|
|
||||||
|
|
||||||
def _get_fader_val(retval):
|
def from_db(func):
|
||||||
if retval >= 1:
|
"""fader|level converter for getters"""
|
||||||
return 10
|
|
||||||
elif retval >= 0.5:
|
@functools.wraps(func)
|
||||||
return round((40 * retval) - 30, 1)
|
def wrapper(*args, **kwargs):
|
||||||
elif retval >= 0.25:
|
retval = func(*args, **kwargs)
|
||||||
return round((80 * retval) - 50, 1)
|
|
||||||
elif retval >= 0.0625:
|
if retval >= 1:
|
||||||
return round((160 * retval) - 70, 1)
|
return 10
|
||||||
elif retval >= 0:
|
elif retval >= 0.5:
|
||||||
return round((480 * retval) - 90, 1)
|
return round((40 * retval) - 30, 1)
|
||||||
else:
|
elif retval >= 0.25:
|
||||||
return -90
|
return round((80 * retval) - 50, 1)
|
||||||
|
elif retval >= 0.0625:
|
||||||
|
return round((160 * retval) - 70, 1)
|
||||||
|
elif retval >= 0:
|
||||||
|
return round((480 * retval) - 90, 1)
|
||||||
|
else:
|
||||||
|
return -90
|
||||||
|
|
||||||
|
return wrapper
|
||||||
|
|
||||||
|
|
||||||
def _set_fader_val(self, val):
|
def to_db(func):
|
||||||
if val >= 10:
|
"""fader|level converter for setters"""
|
||||||
self.setter("fader", 1)
|
|
||||||
elif val >= -10:
|
|
||||||
self.setter("fader", (val + 30) / 40)
|
|
||||||
elif val >= -30:
|
|
||||||
self.setter("fader", (val + 50) / 80)
|
|
||||||
elif val >= -60:
|
|
||||||
self.setter("fader", (val + 70) / 160)
|
|
||||||
elif val >= -90:
|
|
||||||
self.setter("fader", (val + 90) / 480)
|
|
||||||
else:
|
|
||||||
self.setter("fader", 0)
|
|
||||||
|
|
||||||
|
@functools.wraps(func)
|
||||||
|
def wrapper(*args, **kwargs):
|
||||||
|
param, val = args
|
||||||
|
if val >= 10:
|
||||||
|
val = 1
|
||||||
|
elif val >= -10:
|
||||||
|
val = (val + 30) / 40
|
||||||
|
elif val >= -30:
|
||||||
|
val = (val + 50) / 80
|
||||||
|
elif val >= -60:
|
||||||
|
val = (val + 70) / 160
|
||||||
|
elif val >= -90:
|
||||||
|
val = (val + 90) / 480
|
||||||
|
else:
|
||||||
|
val = 0
|
||||||
|
|
||||||
def _get_level_val(retval):
|
func(param, val, **kwargs)
|
||||||
if retval >= 1:
|
|
||||||
return 10
|
|
||||||
elif retval >= 0.5:
|
|
||||||
return round((40 * retval) - 30, 1)
|
|
||||||
elif retval >= 0.25:
|
|
||||||
return round((80 * retval) - 50, 1)
|
|
||||||
elif retval >= 0.0625:
|
|
||||||
return round((160 * retval) - 70, 1)
|
|
||||||
elif retval >= 0:
|
|
||||||
return round((480 * retval) - 90, 1)
|
|
||||||
else:
|
|
||||||
return -90
|
|
||||||
|
|
||||||
|
return wrapper
|
||||||
def _set_level_val(self, val):
|
|
||||||
if val >= 10:
|
|
||||||
self.setter("level", 1)
|
|
||||||
elif val >= -10:
|
|
||||||
self.setter("level", (val + 30) / 40)
|
|
||||||
elif val >= -30:
|
|
||||||
self.setter("level", (val + 50) / 80)
|
|
||||||
elif val >= -60:
|
|
||||||
self.setter("level", (val + 70) / 160)
|
|
||||||
elif val >= -90:
|
|
||||||
self.setter("level", (val + 90) / 480)
|
|
||||||
else:
|
|
||||||
self.setter("level", 0)
|
|
||||||
|
Loading…
Reference in New Issue
Block a user