mirror of
https://github.com/onyx-and-iris/vban-cmd-python.git
synced 2025-01-18 18:40:47 +00:00
onyx-and-iris
ca9a31c94a
script will now end when OBS is closed filter out all logs but `vban_cmd.iremote` setup.py added
92 lines
2.2 KiB
Python
92 lines
2.2 KiB
Python
import time
|
|
from logging import config
|
|
|
|
import obsws_python as obsws
|
|
|
|
import vban_cmd
|
|
|
|
config.dictConfig(
|
|
{
|
|
"version": 1,
|
|
"formatters": {
|
|
"standard": {
|
|
"format": "%(asctime)s,%(msecs)d %(name)s %(levelname)s %(message)s"
|
|
}
|
|
},
|
|
"handlers": {
|
|
"stream": {
|
|
"level": "DEBUG",
|
|
"class": "logging.StreamHandler",
|
|
"formatter": "standard",
|
|
}
|
|
},
|
|
"loggers": {"vban_cmd.iremote": {"handlers": ["stream"], "level": "DEBUG"}},
|
|
}
|
|
)
|
|
|
|
|
|
class Observer:
|
|
def __init__(self, vban):
|
|
self.vban = vban
|
|
self.client = obsws.EventClient()
|
|
self.client.callback.register(
|
|
(
|
|
self.on_current_program_scene_changed,
|
|
self.on_exit_started,
|
|
)
|
|
)
|
|
self.is_running = True
|
|
|
|
def on_start(self):
|
|
self.vban.strip[0].mute = True
|
|
self.vban.strip[1].B1 = True
|
|
self.vban.strip[2].B2 = True
|
|
|
|
def on_brb(self):
|
|
self.vban.strip[7].fadeto(0, 500)
|
|
self.vban.bus[0].mute = True
|
|
|
|
def on_end(self):
|
|
self.vban.apply(
|
|
{
|
|
"strip-0": {"mute": True},
|
|
"strip-1": {"mute": True, "B1": False},
|
|
"strip-2": {"mute": True, "B1": False},
|
|
}
|
|
)
|
|
|
|
def on_live(self):
|
|
self.vban.strip[0].mute = False
|
|
self.vban.strip[7].fadeto(-6, 500)
|
|
self.vban.strip[7].A3 = True
|
|
|
|
def on_current_program_scene_changed(self, data):
|
|
def fget(scene):
|
|
run = {
|
|
"START": self.on_start,
|
|
"BRB": self.on_brb,
|
|
"END": self.on_end,
|
|
"LIVE": self.on_live,
|
|
}
|
|
return run.get(scene)
|
|
|
|
scene = data.scene_name
|
|
print(f"Switched to scene {scene}")
|
|
if fn := fget(scene):
|
|
fn()
|
|
|
|
def on_exit_started(self, _):
|
|
self.client.unsubscribe()
|
|
self.is_running = False
|
|
|
|
|
|
def main():
|
|
with vban_cmd.api("potato") as vban:
|
|
observer = Observer(vban)
|
|
while observer.is_running:
|
|
time.sleep(0.1)
|
|
|
|
|
|
if __name__ == "__main__":
|
|
main()
|