mopidy-raspberrypi-gpio/mopidy_raspberry_gpio/frontend.py

88 lines
2.5 KiB
Python

from __future__ import unicode_literals
import logging
from mopidy import core
import pykka
logger = logging.getLogger(__name__)
class RaspberryGPIOFrontend(pykka.ThreadingActor, core.CoreListener):
def __init__(self, config, core):
super(RaspberryGPIOFrontend, self).__init__()
import RPi.GPIO as GPIO
self.core = core
self.config = config["raspberry-gpio"]
self.pin_settings = {}
GPIO.setwarnings(False)
GPIO.setmode(GPIO.BCM)
# Iterate through any bcmN pins in the config
# and set them up as inputs with edge detection
for key in self.config:
if key.startswith("bcm"):
pin = int(key.replace("bcm", ""))
settings = self.config[key]
if settings is None:
continue
pull = GPIO.PUD_UP
edge = GPIO.FALLING
if settings.active == 'active_high':
pull = GPIO.PUD_DOWN
edge = GPIO.RISING
GPIO.setup(
pin,
GPIO.IN,
pull_up_down=pull)
GPIO.add_event_detect(
pin,
edge,
callback=self.gpio_event,
bouncetime=settings.bouncetime)
self.pin_settings[pin] = settings
def gpio_event(self, pin):
settings = self.pin_settings[pin]
self.dispatch_input(settings.event)
def dispatch_input(self, event):
handler_name = "handle_{}".format(event)
try:
getattr(self, handler_name)()
except AttributeError:
raise RuntimeError(
"Could not find input handler for event: {}".format(event)
)
def handle_play_pause(self):
if self.core.playback.state.get() == core.PlaybackState.PLAYING:
self.core.playback.pause()
else:
self.core.playback.play()
def handle_next(self):
self.core.playback.next()
def handle_prev(self):
self.core.playback.previous()
def handle_volume_up(self):
volume = self.core.playback.volume.get()
volume += 5
volume = min(volume, 100)
self.core.playback.volume = volume
def handle_volume_down(self):
volume = self.core.playback.volume.get()
volume -= 5
volume = max(volume, 0)
self.core.playback.volume = volume