forked from openlp/openlp
VLC extension tidyups
This commit is contained in:
parent
c901ec3d75
commit
c2550777c3
@ -23,7 +23,6 @@ from contextlib import suppress
|
|||||||
from json import JSONDecoder, JSONEncoder
|
from json import JSONDecoder, JSONEncoder
|
||||||
from pathlib import Path
|
from pathlib import Path
|
||||||
|
|
||||||
|
|
||||||
_registered_classes = {}
|
_registered_classes = {}
|
||||||
|
|
||||||
|
|
||||||
|
@ -589,7 +589,7 @@ class MediaManagerItem(QtWidgets.QWidget, RegistryProperties):
|
|||||||
"""
|
"""
|
||||||
Add this item to the current service.
|
Add this item to the current service.
|
||||||
|
|
||||||
:param item: Item to be processed
|
:param QtWidgets.QListWidgetItem | QtWidgets.QTreeWidgetItem | None item: Item to be processed
|
||||||
:param replace: Replace the existing item
|
:param replace: Replace the existing item
|
||||||
:param remote: Triggered from remote
|
:param remote: Triggered from remote
|
||||||
:param position: Position to place item
|
:param position: Position to place item
|
||||||
@ -627,7 +627,7 @@ class MediaManagerItem(QtWidgets.QWidget, RegistryProperties):
|
|||||||
def build_service_item(self, item=None, remote=False, context=ServiceItemContext.Live):
|
def build_service_item(self, item=None, remote=False, context=ServiceItemContext.Live):
|
||||||
"""
|
"""
|
||||||
Common method for generating a service item
|
Common method for generating a service item
|
||||||
:param item: Service Item to be built.
|
:param QtWidgets.QListWidgetItem | QtWidgets.QTreeWidgetItem | None item: Service Item to be built.
|
||||||
:param remote: Remote triggered (False)
|
:param remote: Remote triggered (False)
|
||||||
:param context: The context on which this is called
|
:param context: The context on which this is called
|
||||||
"""
|
"""
|
||||||
|
@ -44,7 +44,7 @@ from openlp.core.lib.ui import critical_error_message_box
|
|||||||
from openlp.core.ui import DisplayControllerType
|
from openlp.core.ui import DisplayControllerType
|
||||||
from openlp.core.ui.media import MediaState, ItemMediaInfo, MediaType, parse_optical_path
|
from openlp.core.ui.media import MediaState, ItemMediaInfo, MediaType, parse_optical_path
|
||||||
from openlp.core.ui.media.endpoint import media_endpoint
|
from openlp.core.ui.media.endpoint import media_endpoint
|
||||||
from openlp.core.ui.media.vlcplayer import VlcPlayer, get_vlc
|
from openlp.core.ui.media.vlcplayer import AUDIO_EXT, VIDEO_EXT, VlcPlayer, get_vlc
|
||||||
|
|
||||||
|
|
||||||
log = logging.getLogger(__name__)
|
log = logging.getLogger(__name__)
|
||||||
@ -65,11 +65,6 @@ class MediaController(RegistryBase, LogMixin, RegistryProperties):
|
|||||||
current_media_players is an array of player instances keyed on ControllerType.
|
current_media_players is an array of player instances keyed on ControllerType.
|
||||||
|
|
||||||
"""
|
"""
|
||||||
def __init__(self, parent=None):
|
|
||||||
"""
|
|
||||||
Constructor
|
|
||||||
"""
|
|
||||||
super(MediaController, self).__init__(parent)
|
|
||||||
|
|
||||||
def setup(self):
|
def setup(self):
|
||||||
self.vlc_player = None
|
self.vlc_player = None
|
||||||
@ -95,26 +90,8 @@ class MediaController(RegistryBase, LogMixin, RegistryProperties):
|
|||||||
Registry().register_function('songs_hide', self.media_hide)
|
Registry().register_function('songs_hide', self.media_hide)
|
||||||
Registry().register_function('songs_blank', self.media_blank)
|
Registry().register_function('songs_blank', self.media_blank)
|
||||||
Registry().register_function('songs_unblank', self.media_unblank)
|
Registry().register_function('songs_unblank', self.media_unblank)
|
||||||
Registry().register_function('mediaitem_suffixes', self._generate_extensions_lists)
|
|
||||||
register_endpoint(media_endpoint)
|
register_endpoint(media_endpoint)
|
||||||
|
|
||||||
def _generate_extensions_lists(self):
|
|
||||||
"""
|
|
||||||
Set the active players and available media files
|
|
||||||
"""
|
|
||||||
suffix_list = []
|
|
||||||
self.audio_extensions_list = []
|
|
||||||
for item in self.vlc_player.audio_extensions_list:
|
|
||||||
if item not in self.audio_extensions_list:
|
|
||||||
self.audio_extensions_list.append(item)
|
|
||||||
suffix_list.append(item[2:])
|
|
||||||
self.video_extensions_list = []
|
|
||||||
for item in self.vlc_player.video_extensions_list:
|
|
||||||
if item not in self.video_extensions_list:
|
|
||||||
self.video_extensions_list.append(item)
|
|
||||||
suffix_list.append(item[2:])
|
|
||||||
self.service_manager.supported_suffixes(suffix_list)
|
|
||||||
|
|
||||||
def bootstrap_initialise(self):
|
def bootstrap_initialise(self):
|
||||||
"""
|
"""
|
||||||
Check to see if we have any media Player's available.
|
Check to see if we have any media Player's available.
|
||||||
@ -129,7 +106,8 @@ class MediaController(RegistryBase, LogMixin, RegistryProperties):
|
|||||||
else:
|
else:
|
||||||
State().missing_text('media_live', translate('OpenLP.SlideController',
|
State().missing_text('media_live', translate('OpenLP.SlideController',
|
||||||
'VLC or pymediainfo are missing, so you are unable to play any media'))
|
'VLC or pymediainfo are missing, so you are unable to play any media'))
|
||||||
self._generate_extensions_lists()
|
self.service_manager.supported_suffixes(ext[2:] for ext in AUDIO_EXT)
|
||||||
|
self.service_manager.supported_suffixes(ext[2:] for ext in VIDEO_EXT)
|
||||||
return True
|
return True
|
||||||
|
|
||||||
def bootstrap_post_set_up(self):
|
def bootstrap_post_set_up(self):
|
||||||
@ -379,7 +357,7 @@ class MediaController(RegistryBase, LogMixin, RegistryProperties):
|
|||||||
if file.is_file:
|
if file.is_file:
|
||||||
suffix = '*%s' % file.suffix.lower()
|
suffix = '*%s' % file.suffix.lower()
|
||||||
file = str(file)
|
file = str(file)
|
||||||
if suffix in self.vlc_player.video_extensions_list:
|
if suffix in VIDEO_EXT:
|
||||||
if not controller.media_info.is_background or controller.media_info.is_background and \
|
if not controller.media_info.is_background or controller.media_info.is_background and \
|
||||||
self.vlc_player.can_background:
|
self.vlc_player.can_background:
|
||||||
self.resize(display, self.vlc_player)
|
self.resize(display, self.vlc_player)
|
||||||
@ -387,7 +365,7 @@ class MediaController(RegistryBase, LogMixin, RegistryProperties):
|
|||||||
self.current_media_players[controller.controller_type] = self.vlc_player
|
self.current_media_players[controller.controller_type] = self.vlc_player
|
||||||
controller.media_info.media_type = MediaType.Video
|
controller.media_info.media_type = MediaType.Video
|
||||||
return True
|
return True
|
||||||
if suffix in self.vlc_player.audio_extensions_list:
|
if suffix in AUDIO_EXT:
|
||||||
if self.vlc_player.load(display, file):
|
if self.vlc_player.load(display, file):
|
||||||
self.current_media_players[controller.controller_type] = self.vlc_player
|
self.current_media_players[controller.controller_type] = self.vlc_player
|
||||||
controller.media_info.media_type = MediaType.Audio
|
controller.media_info.media_type = MediaType.Audio
|
||||||
|
@ -42,8 +42,6 @@ class MediaPlayer(RegistryProperties):
|
|||||||
self.can_folder = False
|
self.can_folder = False
|
||||||
self.state = {0: MediaState.Off, 1: MediaState.Off}
|
self.state = {0: MediaState.Off, 1: MediaState.Off}
|
||||||
self.has_own_widget = False
|
self.has_own_widget = False
|
||||||
self.audio_extensions_list = []
|
|
||||||
self.video_extensions_list = []
|
|
||||||
|
|
||||||
def check_available(self):
|
def check_available(self):
|
||||||
"""
|
"""
|
||||||
|
@ -109,8 +109,6 @@ class VlcPlayer(MediaPlayer):
|
|||||||
self.display_name = '&VLC'
|
self.display_name = '&VLC'
|
||||||
self.parent = parent
|
self.parent = parent
|
||||||
self.can_folder = True
|
self.can_folder = True
|
||||||
self.audio_extensions_list = AUDIO_EXT
|
|
||||||
self.video_extensions_list = VIDEO_EXT
|
|
||||||
|
|
||||||
def setup(self, output_display, live_display):
|
def setup(self, output_display, live_display):
|
||||||
"""
|
"""
|
||||||
|
@ -32,7 +32,6 @@ from openlp.core.common.mixins import RegistryProperties
|
|||||||
from openlp.core.common.registry import Registry
|
from openlp.core.common.registry import Registry
|
||||||
from openlp.core.lib.theme import BackgroundGradientType, BackgroundType
|
from openlp.core.lib.theme import BackgroundGradientType, BackgroundType
|
||||||
from openlp.core.lib.ui import critical_error_message_box
|
from openlp.core.lib.ui import critical_error_message_box
|
||||||
# TODO: Fix this. Use a "get_video_extensions" method which uses the current media player
|
|
||||||
from openlp.core.ui.media.vlcplayer import VIDEO_EXT
|
from openlp.core.ui.media.vlcplayer import VIDEO_EXT
|
||||||
from openlp.core.ui.themelayoutform import ThemeLayoutForm
|
from openlp.core.ui.themelayoutform import ThemeLayoutForm
|
||||||
from openlp.core.ui.themewizard import Ui_ThemeWizard
|
from openlp.core.ui.themewizard import Ui_ThemeWizard
|
||||||
|
@ -38,7 +38,7 @@ from openlp.core.lib.serviceitem import ItemCapabilities
|
|||||||
from openlp.core.lib.ui import critical_error_message_box
|
from openlp.core.lib.ui import critical_error_message_box
|
||||||
from openlp.core.ui.icons import UiIcons
|
from openlp.core.ui.icons import UiIcons
|
||||||
from openlp.core.ui.media import parse_optical_path, format_milliseconds
|
from openlp.core.ui.media import parse_optical_path, format_milliseconds
|
||||||
from openlp.core.ui.media.vlcplayer import get_vlc
|
from openlp.core.ui.media.vlcplayer import AUDIO_EXT, VIDEO_EXT, get_vlc
|
||||||
|
|
||||||
|
|
||||||
if get_vlc() is not None:
|
if get_vlc() is not None:
|
||||||
@ -233,8 +233,8 @@ class MediaMediaItem(MediaManagerItem, RegistryProperties):
|
|||||||
# self.populate_display_types()
|
# self.populate_display_types()
|
||||||
self.on_new_file_masks = translate('MediaPlugin.MediaItem',
|
self.on_new_file_masks = translate('MediaPlugin.MediaItem',
|
||||||
'Videos ({video});;Audio ({audio});;{files} '
|
'Videos ({video});;Audio ({audio});;{files} '
|
||||||
'(*)').format(video=' '.join(self.media_controller.video_extensions_list),
|
'(*)').format(video=' '.join(VIDEO_EXT),
|
||||||
audio=' '.join(self.media_controller.audio_extensions_list),
|
audio=' '.join(AUDIO_EXT),
|
||||||
files=UiStrings().AllFiles)
|
files=UiStrings().AllFiles)
|
||||||
|
|
||||||
def on_delete_click(self):
|
def on_delete_click(self):
|
||||||
@ -301,9 +301,9 @@ class MediaMediaItem(MediaManagerItem, RegistryProperties):
|
|||||||
media_file_paths = Settings().value(self.settings_section + '/media files')
|
media_file_paths = Settings().value(self.settings_section + '/media files')
|
||||||
media_file_paths.sort(key=lambda file_path: get_natural_key(file_path.name))
|
media_file_paths.sort(key=lambda file_path: get_natural_key(file_path.name))
|
||||||
if media_type == MediaType.Audio:
|
if media_type == MediaType.Audio:
|
||||||
extension = self.media_controller.audio_extensions_list
|
extension = AUDIO_EXT
|
||||||
else:
|
else:
|
||||||
extension = self.media_controller.video_extensions_list
|
extension = VIDEO_EXT # TODO: Rename extension to extensions
|
||||||
extension = [x[1:] for x in extension]
|
extension = [x[1:] for x in extension]
|
||||||
media = [x for x in media_file_paths if x.suffix in extension]
|
media = [x for x in media_file_paths if x.suffix in extension]
|
||||||
return media
|
return media
|
||||||
|
@ -43,7 +43,7 @@ class OpenLyricsExport(RegistryProperties):
|
|||||||
"""
|
"""
|
||||||
def __init__(self, parent, songs, save_path):
|
def __init__(self, parent, songs, save_path):
|
||||||
"""
|
"""
|
||||||
Initialise the export.
|
Initialise the export
|
||||||
|
|
||||||
:param pathlib.Path save_path: The directory to save the exported songs in
|
:param pathlib.Path save_path: The directory to save the exported songs in
|
||||||
:rtype: None
|
:rtype: None
|
||||||
|
@ -22,7 +22,6 @@
|
|||||||
"""
|
"""
|
||||||
Package to test the openlp.core.common.path package.
|
Package to test the openlp.core.common.path package.
|
||||||
"""
|
"""
|
||||||
# TODO: fix patches
|
|
||||||
import os
|
import os
|
||||||
from pathlib import Path
|
from pathlib import Path
|
||||||
from unittest import TestCase
|
from unittest import TestCase
|
||||||
|
@ -43,25 +43,6 @@ class TestMediaController(TestCase, TestMixin):
|
|||||||
Registry.create()
|
Registry.create()
|
||||||
Registry().register('service_manager', MagicMock())
|
Registry().register('service_manager', MagicMock())
|
||||||
|
|
||||||
def test_generate_extensions_lists(self):
|
|
||||||
"""
|
|
||||||
Test that the extensions are create correctly
|
|
||||||
"""
|
|
||||||
# GIVEN: A MediaController and an active player with audio and video extensions
|
|
||||||
media_controller = MediaController()
|
|
||||||
media_controller.vlc_player = VlcPlayer(None)
|
|
||||||
media_controller.vlc_player.audio_extensions_list = ['*.mp3', '*.wav', '*.wma', '*.ogg']
|
|
||||||
media_controller.vlc_player.video_extensions_list = ['*.mp4', '*.mov', '*.avi', '*.ogm']
|
|
||||||
|
|
||||||
# WHEN: calling _generate_extensions_lists
|
|
||||||
media_controller._generate_extensions_lists()
|
|
||||||
|
|
||||||
# THEN: extensions list should have been copied from the player to the mediacontroller
|
|
||||||
assert media_controller.video_extensions_list == media_controller.video_extensions_list, \
|
|
||||||
'Video extensions should be the same'
|
|
||||||
assert media_controller.audio_extensions_list == media_controller.audio_extensions_list, \
|
|
||||||
'Audio extensions should be the same'
|
|
||||||
|
|
||||||
def test_resize(self):
|
def test_resize(self):
|
||||||
"""
|
"""
|
||||||
Test that the resize method is called correctly
|
Test that the resize method is called correctly
|
||||||
|
@ -95,8 +95,6 @@ class TestVLCPlayer(TestCase, TestMixin):
|
|||||||
assert '&VLC' == vlc_player.display_name
|
assert '&VLC' == vlc_player.display_name
|
||||||
assert vlc_player.parent is None
|
assert vlc_player.parent is None
|
||||||
assert vlc_player.can_folder is True
|
assert vlc_player.can_folder is True
|
||||||
assert AUDIO_EXT == vlc_player.audio_extensions_list
|
|
||||||
assert VIDEO_EXT == vlc_player.video_extensions_list
|
|
||||||
|
|
||||||
@patch('openlp.core.ui.media.vlcplayer.is_win')
|
@patch('openlp.core.ui.media.vlcplayer.is_win')
|
||||||
@patch('openlp.core.ui.media.vlcplayer.is_macosx')
|
@patch('openlp.core.ui.media.vlcplayer.is_macosx')
|
||||||
|
Loading…
Reference in New Issue
Block a user