touch_screen.py 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. import pykka
  2. import traceback
  3. import logging
  4. from threading import Thread
  5. import pygame
  6. from mopidy import core
  7. from .screen_manager import ScreenManager
  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. self.core = core
  14. self.running = False
  15. self.screen_size = (config['touchscreen']['screen_width'], config['touchscreen']['screen_height'])
  16. self.cache_dir = config['touchscreen']['cache_dir']
  17. self.fullscreen = config['touchscreen']['fullscreen']
  18. pygame.init()
  19. pygame.mouse.set_visible(config['touchscreen']['cursor'])
  20. self.screen_manager = ScreenManager(self.screen_size, self.core, self.backend, self.cache_dir)
  21. def start_thread(self):
  22. clock = pygame.time.Clock()
  23. if self.fullscreen:
  24. screen = pygame.display.set_mode(self.screen_size, pygame.FULLSCREEN)
  25. else:
  26. screen = pygame.display.set_mode(self.screen_size)
  27. while self.running:
  28. clock.tick(15)
  29. screen.blit(self.screen_manager.update(), (0, 0))
  30. pygame.display.flip()
  31. for event in pygame.event.get():
  32. if event.type == pygame.QUIT:
  33. self.running = False
  34. elif event.type == pygame.KEYUP and event.key == pygame.K_q:
  35. self.running = False
  36. else:
  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 track_playback_ended(self, tl_track, time_position):
  63. self.screen_manager.track_playback_ended(tl_track, time_position)
  64. def options_changed(self):
  65. try:
  66. self.screen_manager.options_changed()
  67. except:
  68. traceback.print_exc()
  69. def playlists_loaded(self):
  70. self.screen_manager.playlists_loaded()