touch_screen.py 2.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. import pykka
  2. import traceback
  3. import logging
  4. from threading import Thread
  5. import pygame
  6. from .screen_manager import ScreenManager
  7. from mopidy import core
  8. logger = logging.getLogger(__name__)
  9. class TouchScreen(pykka.ThreadingActor, core.CoreListener):
  10. def __init__(self, config, core):
  11. super(TouchScreen, self).__init__()
  12. self.backend = pykka.ActorRegistry.get_by_class_name("TouchScreenBackend")[0]
  13. logger.error(self.backend)
  14. self.core = core
  15. self.running = False
  16. self.screen_size = (config['touchscreen']['screen_width'], config['touchscreen']['screen_height'])
  17. self.cache_dir = config['touchscreen']['cache_dir']
  18. self.fullscreen = config['touchscreen']['fullscreen']
  19. pygame.init()
  20. pygame.mouse.set_visible(config['touchscreen']['cursor'])
  21. self.screen_manager = ScreenManager(self.screen_size,self.core, self.backend)
  22. def start_thread(self):
  23. clock = pygame.time.Clock()
  24. if self.fullscreen:
  25. screen = pygame.display.set_mode(self.screen_size, pygame.FULLSCREEN)
  26. else:
  27. screen = pygame.display.set_mode(self.screen_size)
  28. while self.running:
  29. clock.tick(15)
  30. screen.blit(self.screen_manager.update(), (0, 0))
  31. pygame.display.flip()
  32. for event in pygame.event.get():
  33. if event.type == pygame.QUIT:
  34. self.running = False
  35. if event.type == pygame.KEYUP and event.key == pygame.K_q:
  36. self.running = False
  37. self.screen_manager.event(event)
  38. pygame.quit()
  39. def on_start(self):
  40. try:
  41. self.running = True
  42. thread = Thread(target=self.start_thread)
  43. thread.start()
  44. except:
  45. traceback.print_exc()
  46. def on_stop(self):
  47. self.running = False
  48. def track_playback_started(self, tl_track):
  49. try:
  50. self.screen_manager.track_started(tl_track)
  51. except:
  52. traceback.print_exc()
  53. def volume_changed(self, volume):
  54. self.screen_manager.volume_changed(volume)
  55. def playback_state_changed(self,old_state, new_state):
  56. self.screen_manager.playback_state_changed(old_state, new_state)
  57. def tracklist_changed(self):
  58. try:
  59. self.screen_manager.tracklist_changed()
  60. except:
  61. traceback.print_exc()
  62. def options_changed(self):
  63. try:
  64. self.screen_manager.options_changed()
  65. except:
  66. traceback.print_exc()
  67. def playlists_loaded(self):
  68. self.screen_manager.playlists_loaded()