forked from openlp/openlp
Merge branch 'fix-impress-display' into 'master'
Fix impress display Closes #30 See merge request openlp/openlp!309
This commit is contained in:
commit
ed3608bf47
@ -291,6 +291,7 @@ class Settings(QtCore.QSettings):
|
|||||||
'presentations/thumbnail_scheme': '',
|
'presentations/thumbnail_scheme': '',
|
||||||
'presentations/powerpoint slide click advance': QtCore.Qt.Unchecked,
|
'presentations/powerpoint slide click advance': QtCore.Qt.Unchecked,
|
||||||
'presentations/powerpoint control window': QtCore.Qt.Unchecked,
|
'presentations/powerpoint control window': QtCore.Qt.Unchecked,
|
||||||
|
'presentations/impress use display setting': QtCore.Qt.Unchecked,
|
||||||
'presentations/last directory': None,
|
'presentations/last directory': None,
|
||||||
'servicemanager/last directory': None,
|
'servicemanager/last directory': None,
|
||||||
'servicemanager/last file': None,
|
'servicemanager/last file': None,
|
||||||
|
@ -37,6 +37,7 @@ from PyQt5 import QtCore
|
|||||||
|
|
||||||
from openlp.core.common import delete_file, get_uno_command, get_uno_instance, is_win, trace_error_handler
|
from openlp.core.common import delete_file, get_uno_command, get_uno_instance, is_win, trace_error_handler
|
||||||
from openlp.core.common.registry import Registry
|
from openlp.core.common.registry import Registry
|
||||||
|
from openlp.core.common.settings import Settings
|
||||||
from openlp.core.display.screens import ScreenList
|
from openlp.core.display.screens import ScreenList
|
||||||
from openlp.plugins.presentations.lib.presentationcontroller import PresentationController, PresentationDocument, \
|
from openlp.plugins.presentations.lib.presentationcontroller import PresentationController, PresentationDocument, \
|
||||||
TextType
|
TextType
|
||||||
@ -312,7 +313,17 @@ class ImpressDocument(PresentationDocument):
|
|||||||
log.warning('Presentation {url} could not be loaded'.format(url=url))
|
log.warning('Presentation {url} could not be loaded'.format(url=url))
|
||||||
return False
|
return False
|
||||||
self.presentation = self.document.getPresentation()
|
self.presentation = self.document.getPresentation()
|
||||||
self.presentation.Display = ScreenList().current.number + 1
|
# OpenOffice uses a screen numbering scheme where the primary display is 1 and the external monitor 2
|
||||||
|
# but OpenLP sets screen numbers based on screen coordinates (geometry)
|
||||||
|
# so we work out what OpenOffice display to use based on which of the openlp screens is primary
|
||||||
|
# unless the user has defined in Settings to use the impress Slide Show setting for presentation display
|
||||||
|
if not Settings().value('presentations/impress use display setting'):
|
||||||
|
public_display_screen_number = ScreenList().current.number
|
||||||
|
screens = list(ScreenList())
|
||||||
|
if screens[public_display_screen_number].is_primary:
|
||||||
|
self.presentation.Display = 1
|
||||||
|
else:
|
||||||
|
self.presentation.Display = 2
|
||||||
self.control = None
|
self.control = None
|
||||||
self.create_thumbnails()
|
self.create_thumbnails()
|
||||||
self.create_titles_and_notes()
|
self.create_titles_and_notes()
|
||||||
|
@ -76,6 +76,15 @@ class PresentationTab(SettingsTab):
|
|||||||
self.ppt_window_check_box.setObjectName('ppt_window_check_box')
|
self.ppt_window_check_box.setObjectName('ppt_window_check_box')
|
||||||
self.powerpoint_layout.addWidget(self.ppt_window_check_box)
|
self.powerpoint_layout.addWidget(self.ppt_window_check_box)
|
||||||
self.left_layout.addWidget(self.powerpoint_group_box)
|
self.left_layout.addWidget(self.powerpoint_group_box)
|
||||||
|
# Impress
|
||||||
|
self.impress_group_box = QtWidgets.QGroupBox(self.left_column)
|
||||||
|
self.impress_group_box.setObjectName('impress_group_box')
|
||||||
|
self.impress_layout = QtWidgets.QVBoxLayout(self.impress_group_box)
|
||||||
|
self.impress_layout.setObjectName('impress_layout')
|
||||||
|
self.odp_display_check_box = QtWidgets.QCheckBox(self.impress_group_box)
|
||||||
|
self.odp_display_check_box.setObjectName('odp_display_check_box')
|
||||||
|
self.impress_layout.addWidget(self.odp_display_check_box)
|
||||||
|
self.left_layout.addWidget(self.impress_group_box)
|
||||||
# setup layout
|
# setup layout
|
||||||
self.left_layout.addStretch()
|
self.left_layout.addStretch()
|
||||||
self.right_column.setSizePolicy(QtWidgets.QSizePolicy.Expanding, QtWidgets.QSizePolicy.Preferred)
|
self.right_column.setSizePolicy(QtWidgets.QSizePolicy.Expanding, QtWidgets.QSizePolicy.Preferred)
|
||||||
@ -101,6 +110,10 @@ class PresentationTab(SettingsTab):
|
|||||||
translate('PresentationPlugin.PresentationTab',
|
translate('PresentationPlugin.PresentationTab',
|
||||||
'Let PowerPoint control the size and monitor of the presentations\n'
|
'Let PowerPoint control the size and monitor of the presentations\n'
|
||||||
'(This may fix PowerPoint scaling issues in Windows 8 and 10)'))
|
'(This may fix PowerPoint scaling issues in Windows 8 and 10)'))
|
||||||
|
self.impress_group_box.setTitle(translate('PresentationPlugin.PresentationTab', 'Impress options'))
|
||||||
|
self.odp_display_check_box.setText(
|
||||||
|
translate('PresentationPlugin.PresentationTab',
|
||||||
|
'Use Impress Slide Show Settings / Presentation Display setting'))
|
||||||
|
|
||||||
def set_controller_text(self, checkbox, controller):
|
def set_controller_text(self, checkbox, controller):
|
||||||
if checkbox.isEnabled():
|
if checkbox.isEnabled():
|
||||||
@ -114,18 +127,24 @@ class PresentationTab(SettingsTab):
|
|||||||
Load the settings.
|
Load the settings.
|
||||||
"""
|
"""
|
||||||
powerpoint_available = False
|
powerpoint_available = False
|
||||||
|
impress_available = False
|
||||||
for key in self.controllers:
|
for key in self.controllers:
|
||||||
controller = self.controllers[key]
|
controller = self.controllers[key]
|
||||||
checkbox = self.presenter_check_boxes[controller.name]
|
checkbox = self.presenter_check_boxes[controller.name]
|
||||||
checkbox.setChecked(self.settings.value('presentations/' + controller.name))
|
checkbox.setChecked(self.settings.value('presentations/' + controller.name))
|
||||||
if controller.name == 'Powerpoint' and controller.is_available():
|
if controller.name == 'Powerpoint' and controller.is_available():
|
||||||
powerpoint_available = True
|
powerpoint_available = True
|
||||||
|
if controller.name == 'Impress' and controller.is_available():
|
||||||
|
impress_available = True
|
||||||
self.override_app_check_box.setChecked(self.settings.value('presentations/override app'))
|
self.override_app_check_box.setChecked(self.settings.value('presentations/override app'))
|
||||||
# Load PowerPoint settings
|
# Load PowerPoint settings
|
||||||
self.ppt_slide_click_check_box.setChecked(self.settings.value('presentations/powerpoint slide click advance'))
|
self.ppt_slide_click_check_box.setChecked(self.settings.value('presentations/powerpoint slide click advance'))
|
||||||
self.ppt_slide_click_check_box.setEnabled(powerpoint_available)
|
self.ppt_slide_click_check_box.setEnabled(powerpoint_available)
|
||||||
self.ppt_window_check_box.setChecked(self.settings.value('presentations/powerpoint control window'))
|
self.ppt_window_check_box.setChecked(self.settings.value('presentations/powerpoint control window'))
|
||||||
self.ppt_window_check_box.setEnabled(powerpoint_available)
|
self.ppt_window_check_box.setEnabled(powerpoint_available)
|
||||||
|
# Load Impress settings
|
||||||
|
self.odp_display_check_box.setChecked(self.settings.value('presentations/impress use display setting'))
|
||||||
|
self.odp_display_check_box.setEnabled(impress_available)
|
||||||
|
|
||||||
def save(self):
|
def save(self):
|
||||||
"""
|
"""
|
||||||
@ -160,6 +179,11 @@ class PresentationTab(SettingsTab):
|
|||||||
if self.settings.value(setting_key) != self.ppt_window_check_box.checkState():
|
if self.settings.value(setting_key) != self.ppt_window_check_box.checkState():
|
||||||
self.settings.setValue(setting_key, self.ppt_window_check_box.checkState())
|
self.settings.setValue(setting_key, self.ppt_window_check_box.checkState())
|
||||||
changed = True
|
changed = True
|
||||||
|
# Save impress setting
|
||||||
|
setting_key = 'presentations/impress use display setting'
|
||||||
|
if self.settings.value(setting_key) != self.odp_display_check_box.checkState():
|
||||||
|
self.settings.setValue(setting_key, self.odp_display_check_box.checkState())
|
||||||
|
changed = True
|
||||||
if changed:
|
if changed:
|
||||||
self.settings_form.register_post_process('mediaitem_suffix_reset')
|
self.settings_form.register_post_process('mediaitem_suffix_reset')
|
||||||
self.settings_form.register_post_process('mediaitem_presentation_rebuild')
|
self.settings_form.register_post_process('mediaitem_presentation_rebuild')
|
||||||
|
@ -0,0 +1,89 @@
|
|||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
|
||||||
|
##########################################################################
|
||||||
|
# OpenLP - Open Source Lyrics Projection #
|
||||||
|
# ---------------------------------------------------------------------- #
|
||||||
|
# Copyright (c) 2008-2021 OpenLP Developers #
|
||||||
|
# ---------------------------------------------------------------------- #
|
||||||
|
# This program is free software: you can redistribute it and/or modify #
|
||||||
|
# it under the terms of the GNU General Public License as published by #
|
||||||
|
# the Free Software Foundation, either version 3 of the License, or #
|
||||||
|
# (at your option) any later version. #
|
||||||
|
# #
|
||||||
|
# This program is distributed in the hope that it will be useful, #
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of #
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the #
|
||||||
|
# GNU General Public License for more details. #
|
||||||
|
# #
|
||||||
|
# You should have received a copy of the GNU General Public License #
|
||||||
|
# along with this program. If not, see <https://www.gnu.org/licenses/>. #
|
||||||
|
##########################################################################
|
||||||
|
"""
|
||||||
|
This module contains tests for the settings tab for the Presentations plugin.
|
||||||
|
"""
|
||||||
|
from unittest.mock import MagicMock
|
||||||
|
|
||||||
|
from PyQt5 import QtCore, QtTest
|
||||||
|
|
||||||
|
from openlp.core.common.registry import Registry
|
||||||
|
from openlp.plugins.presentations.lib.presentationtab import PresentationTab
|
||||||
|
|
||||||
|
__default_settings__ = {
|
||||||
|
'presentations/powerpoint slide click advance': QtCore.Qt.Unchecked,
|
||||||
|
'presentations/powerpoint control window': QtCore.Qt.Unchecked,
|
||||||
|
'presentations/impress use display setting': QtCore.Qt.Unchecked
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
def Mocked_Controllers(impress_available, powerpoint_available):
|
||||||
|
impress_controller = MagicMock()
|
||||||
|
impress_controller.name = 'Impress'
|
||||||
|
impress_controller.display_name = 'Impress'
|
||||||
|
impress_controller.is_available.return_value = impress_available
|
||||||
|
powerpoint_controller = MagicMock()
|
||||||
|
powerpoint_controller.name = 'Powerpoint'
|
||||||
|
powerpoint_controller.display_name = 'Powerpoint'
|
||||||
|
powerpoint_controller.is_available.return_value = powerpoint_available
|
||||||
|
return {'Impress': impress_controller, 'Powerpoint': powerpoint_controller}
|
||||||
|
|
||||||
|
|
||||||
|
def test_check_boxes(settings):
|
||||||
|
"""
|
||||||
|
Test check box options are correctly saved
|
||||||
|
"""
|
||||||
|
# GIVEN: A presentations tab fixture
|
||||||
|
Registry().register('settings_form', MagicMock())
|
||||||
|
Registry().get('settings').extend_default_settings(__default_settings__)
|
||||||
|
form = PresentationTab(None, 'Presentations', None, Mocked_Controllers(True, True), None)
|
||||||
|
|
||||||
|
# WHEN: The presentations tab checkboxes are checked and the form saved
|
||||||
|
QtTest.QTest.mouseClick(form.ppt_slide_click_check_box, QtCore.Qt.LeftButton)
|
||||||
|
QtTest.QTest.mouseClick(form.ppt_window_check_box, QtCore.Qt.LeftButton)
|
||||||
|
QtTest.QTest.mouseClick(form.odp_display_check_box, QtCore.Qt.LeftButton)
|
||||||
|
form.activated = True
|
||||||
|
form.save()
|
||||||
|
# THEN: The updated values should be stored in the settings
|
||||||
|
assert form.settings.value('presentations/powerpoint slide click advance') == QtCore.Qt.Checked
|
||||||
|
assert form.settings.value('presentations/powerpoint control window') == QtCore.Qt.Checked
|
||||||
|
assert form.settings.value('presentations/impress use display setting') == QtCore.Qt.Checked
|
||||||
|
|
||||||
|
|
||||||
|
def test_check_boxes_when_controllers_unavailable(settings):
|
||||||
|
"""
|
||||||
|
Test settings related check box options are unchanged when controllers aren't available
|
||||||
|
"""
|
||||||
|
# GIVEN: A presentations tab fixture
|
||||||
|
Registry().register('settings_form', MagicMock())
|
||||||
|
Registry().get('settings').extend_default_settings(__default_settings__)
|
||||||
|
form = PresentationTab(None, 'Presentations', None, Mocked_Controllers(False, False), None)
|
||||||
|
|
||||||
|
# WHEN: The presentations tab checkboxes are checked and the form saved
|
||||||
|
QtTest.QTest.mouseClick(form.ppt_slide_click_check_box, QtCore.Qt.LeftButton)
|
||||||
|
QtTest.QTest.mouseClick(form.ppt_window_check_box, QtCore.Qt.LeftButton)
|
||||||
|
QtTest.QTest.mouseClick(form.odp_display_check_box, QtCore.Qt.LeftButton)
|
||||||
|
form.activated = True
|
||||||
|
form.save()
|
||||||
|
# THEN: The updated values should be unchanged
|
||||||
|
assert form.settings.value('presentations/powerpoint slide click advance') == QtCore.Qt.Unchecked
|
||||||
|
assert form.settings.value('presentations/powerpoint control window') == QtCore.Qt.Unchecked
|
||||||
|
assert form.settings.value('presentations/impress use display setting') == QtCore.Qt.Unchecked
|
Loading…
Reference in New Issue
Block a user