From cdbf6ac9eacc5fa81790fed565fff0318bbb71a7 Mon Sep 17 00:00:00 2001 From: Tim Bentley Date: Tue, 16 Feb 2016 21:14:38 +0000 Subject: [PATCH] Fix timers --- openlp/core/ui/__init__.py | 1 - openlp/core/ui/media/mediacontroller.py | 86 ++++++++++++++++--------- openlp/core/ui/slidecontroller.py | 2 +- openlp/plugins/media/lib/mediaitem.py | 7 +- openlp/plugins/media/mediaplugin.py | 7 -- 5 files changed, 60 insertions(+), 43 deletions(-) diff --git a/openlp/core/ui/__init__.py b/openlp/core/ui/__init__.py index 82426539b..c6777c756 100644 --- a/openlp/core/ui/__init__.py +++ b/openlp/core/ui/__init__.py @@ -68,7 +68,6 @@ class DisplayControllerType(object): """ Live = 0 Preview = 1 - Plugin = 2 class SingleColumnTableWidget(QtWidgets.QTableWidget): diff --git a/openlp/core/ui/media/mediacontroller.py b/openlp/core/ui/media/mediacontroller.py index 8d9c8801a..99ca101c2 100644 --- a/openlp/core/ui/media/mediacontroller.py +++ b/openlp/core/ui/media/mediacontroller.py @@ -106,10 +106,13 @@ class MediaController(RegistryMixin, OpenLPMixin, RegistryProperties): self.display_controllers = {} self.current_media_players = {} # Timer for video state - self.timer = QtCore.QTimer() - self.timer.setInterval(TICK_TIME) + self.live_timer = QtCore.QTimer() + self.live_timer.setInterval(TICK_TIME) + self.preview_timer = QtCore.QTimer() + self.preview_timer.setInterval(TICK_TIME) # Signals - self.timer.timeout.connect(self.media_state) + self.live_timer.timeout.connect(self.media_state_live) + self.preview_timer.timeout.connect(self.media_state_preview) Registry().register_function('playbackPlay', self.media_play_msg) Registry().register_function('playbackPause', self.media_pause_msg) Registry().register_function('playbackStop', self.media_stop_msg) @@ -199,12 +202,28 @@ class MediaController(RegistryMixin, OpenLPMixin, RegistryProperties): self._generate_extensions_lists() return True + def media_state_live(self): + self.tick(self.display_controllers[DisplayControllerType.Live]) + display = self._define_display(self.display_controllers[DisplayControllerType.Live]) + self.current_media_players[DisplayControllerType.Live].resize(display) + self.current_media_players[DisplayControllerType.Live].update_ui(display) + if self.current_media_players[DisplayControllerType.Live].state is not MediaState.Playing: + self.live_timer.stop() + + def media_state_preview(self): + self.tick(self.display_controllers[DisplayControllerType.Preview]) + display = self._define_display(self.display_controllers[DisplayControllerType.Preview]) + self.current_media_players[DisplayControllerType.Preview].resize(display) + self.current_media_players[DisplayControllerType.Preview].update_ui(display) + if self.current_media_players[DisplayControllerType.Preview].state is not MediaState.Playing: + self.preview_timer.stop() + def media_state(self): """ Check if there is a running media Player and do updating stuff (e.g. update the UI) """ if not list(self.current_media_players.keys()): - self.timer.stop() + self.live_timer.stop() else: any_active = False for source in list(self.current_media_players.keys()): @@ -213,8 +232,9 @@ class MediaController(RegistryMixin, OpenLPMixin, RegistryProperties): self.current_media_players[source].update_ui(display) if self.current_media_players[source].state == MediaState.Playing: any_active = True + print(source) self.tick(self.display_controllers[source]) - # There are still any active players - no need to stop timer. + # There are still any active players - no need to stop live_timer. if any_active: return # no players are active anymore @@ -224,7 +244,7 @@ class MediaController(RegistryMixin, OpenLPMixin, RegistryProperties): display.controller.seek_slider.setSliderPosition(0) display.controller.mediabar.actions['playbackPlay'].setVisible(True) display.controller.mediabar.actions['playbackPause'].setVisible(False) - self.timer.stop() + self.live_timer.stop() def get_media_display_css(self): """ @@ -629,32 +649,25 @@ class MediaController(RegistryMixin, OpenLPMixin, RegistryProperties): if first_time: if not controller.media_info.is_background: display.frame.evaluateJavaScript('show_blank("desktop");') - else: - if controller.media_info.is_background: - display.frame.evaluateJavaScript('show_blank("desktop");') - self.current_media_players[controller.controller_type].set_visible(display, True) - controller.mediabar.actions['playbackPlay'].setVisible(False) - controller.mediabar.actions['playbackPause'].setVisible(True) - controller.mediabar.actions['playbackStop'].setDisabled(False) + self.current_media_players[controller.controller_type].set_visible(display, True) + controller.mediabar.actions['playbackPlay'].setVisible(False) + controller.mediabar.actions['playbackPause'].setVisible(True) + controller.mediabar.actions['playbackStop'].setDisabled(False) if controller.is_live: if controller.hide_menu.defaultAction().isChecked() and not controller.media_info.is_background: controller.hide_menu.defaultAction().trigger() - # Start Timer for ui updates - if not self.timer.isActive(): - self.timer.start() + # Start Timer for ui updates + if not self.live_timer.isActive(): + self.live_timer.start() + else: + # Start Timer for ui updates + if not self.preview_timer.isActive(): + self.preview_timer.start() controller.seek_slider.blockSignals(False) controller.volume_slider.blockSignals(False) controller.media_info.playing = True return True - def media_pause_msg(self, msg): - """ - Responds to the request to pause a loaded video - - :param msg: First element is the controller which should be used - """ - self.media_pause(msg[0]) - def tick(self, controller): """ Add a tick while the media is playing but only count if not paused @@ -664,7 +677,7 @@ class MediaController(RegistryMixin, OpenLPMixin, RegistryProperties): start_again = False if controller.media_info.playing and controller.media_info.length > 0: if controller.media_info.timer > controller.media_info.length: - self.media_stop(controller) + self.media_stop(controller, True) if controller.media_info.loop_playback: start_again = True controller.media_info.timer += TICK_TIME @@ -677,7 +690,15 @@ class MediaController(RegistryMixin, OpenLPMixin, RegistryProperties): controller.position_label.setText(' %02d:%02d / %02d:%02d' % (minutes, seconds, total_minutes, total_seconds)) if start_again: - self.media_play(controller, False) + self.media_play(controller, True) + + def media_pause_msg(self, msg): + """ + Responds to the request to pause a loaded video + + :param msg: First element is the controller which should be used + """ + self.media_pause(msg[0]) def media_pause(self, controller): """ @@ -718,15 +739,17 @@ class MediaController(RegistryMixin, OpenLPMixin, RegistryProperties): """ self.media_stop(msg[0]) - def media_stop(self, controller): + def media_stop(self, controller, looping_background=False): """ Responds to the request to stop a loaded video :param controller: The controller that needs to be stopped + :param looping_background: The background is looping so do not blank. """ display = self._define_display(controller) if controller.controller_type in self.current_media_players: - display.frame.evaluateJavaScript('show_blank("black");') + if not looping_background: + display.frame.evaluateJavaScript('show_blank("black");') self.current_media_players[controller.controller_type].stop(display) self.current_media_players[controller.controller_type].set_visible(display, False) controller.seek_slider.setSliderPosition(0) @@ -845,14 +868,15 @@ class MediaController(RegistryMixin, OpenLPMixin, RegistryProperties): if self.current_media_players[self.live_controller.controller_type].play(display): self.current_media_players[self.live_controller.controller_type].set_visible(display, True) # Start Timer for ui updates - if not self.timer.isActive(): - self.timer.start() + if not self.live_timer.isActive(): + self.live_timer.start() def finalise(self): """ Reset all the media controllers when OpenLP shuts down """ - self.timer.stop() + self.live_timer.stop() + self.preview_timer.stop() for controller in self.display_controllers: self.media_reset(self.display_controllers[controller]) diff --git a/openlp/core/ui/slidecontroller.py b/openlp/core/ui/slidecontroller.py index 2579580df..9e2c86a3a 100644 --- a/openlp/core/ui/slidecontroller.py +++ b/openlp/core/ui/slidecontroller.py @@ -84,7 +84,7 @@ class DisplayController(QtWidgets.QWidget): super(DisplayController, self).__init__(parent) self.is_live = False self.display = None - self.controller_type = DisplayControllerType.Plugin + self.controller_type = None def send_to_plugins(self, *args): """ diff --git a/openlp/plugins/media/lib/mediaitem.py b/openlp/plugins/media/lib/mediaitem.py index 1a4fb3e07..284df0250 100644 --- a/openlp/plugins/media/lib/mediaitem.py +++ b/openlp/plugins/media/lib/mediaitem.py @@ -78,10 +78,10 @@ class MediaMediaItem(MediaManagerItem, RegistryProperties): self.single_service_item = False self.has_search = True self.media_object = None - self.display_controller = DisplayController(self.parent()) + # self.display_controller = DisplayController(self.parent()) Registry().register_function('video_background_replaced', self.video_background_replaced) Registry().register_function('mediaitem_media_rebuild', self.rebuild_players) - Registry().register_function('config_screen_changed', self.display_setup) + # Registry().register_function('config_screen_changed', self.display_setup) # Allow DnD from the desktop self.list_view.activateDnD() @@ -317,7 +317,8 @@ class MediaMediaItem(MediaManagerItem, RegistryProperties): """ Setup media controller display. """ - self.media_controller.setup_display(self.display_controller.preview_display, False) + # self.media_controller.setup_display(self.display_controller.preview_display, False) + pass def populate_display_types(self): """ diff --git a/openlp/plugins/media/mediaplugin.py b/openlp/plugins/media/mediaplugin.py index a1e54a132..daeb4dc2c 100644 --- a/openlp/plugins/media/mediaplugin.py +++ b/openlp/plugins/media/mediaplugin.py @@ -60,13 +60,6 @@ class MediaPlugin(Plugin): """ Override the inherited initialise() method in order to upgrade the media before trying to load it """ - # FIXME: Remove after 2.2 release. - # This is needed to load the list of media from the config saved before the settings rewrite. - if self.media_item_class is not None: - loaded_list = Settings().get_files_from_config(self) - # Now save the list to the config using our Settings class. - if loaded_list: - Settings().setValue('%s/%s files' % (self.settings_section, self.name), loaded_list) super().initialise() def app_startup(self):