touch_screen.py 3.1 KB

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