forked from openlp/openlp
Made presenting PDF from the servicemanager work
This commit is contained in:
parent
ffa3cd32b3
commit
685258b744
@ -420,7 +420,11 @@ class ServiceItem(object):
|
||||
self._raw_frames.append(slide)
|
||||
elif self.service_item_type == ServiceItemType.Image:
|
||||
settings_section = serviceitem['serviceitem']['header']['name']
|
||||
background = None
|
||||
try:
|
||||
background = QtGui.QColor(Settings().value(settings_section + '/background color'))
|
||||
except Exception:
|
||||
pass
|
||||
if path:
|
||||
self.has_original_files = False
|
||||
for text_image in serviceitem['serviceitem']['data']:
|
||||
|
@ -733,7 +733,7 @@ class SlideController(DisplayController):
|
||||
if old_item and self.is_live and old_item.is_capable(ItemCapabilities.ProvidesOwnDisplay):
|
||||
self._reset_blank()
|
||||
Registry().execute(
|
||||
'%s_start' % service_item.name.lower(), [service_item, self.is_live, self.hide_mode(), slideno])
|
||||
'%s_start' % service_item.name.lower(), [self.service_item, self.is_live, self.hide_mode(), slideno])
|
||||
self.slideList = {}
|
||||
if self.is_live:
|
||||
self.song_menu.menu().clear()
|
||||
|
@ -238,7 +238,7 @@ class PresentationMediaItem(MediaManagerItem):
|
||||
Settings().setValue(self.settings_section + '/presentations files', self.get_file_list())
|
||||
|
||||
def generate_slide_data(self, service_item, item=None, xml_version=False,
|
||||
remote=False, context=ServiceItemContext.Service):
|
||||
remote=False, context=ServiceItemContext.Service, presentation_file=None):
|
||||
"""
|
||||
Load the relevant information for displaying the presentation in the slidecontroller. In the case of
|
||||
powerpoints, an image for each slide.
|
||||
@ -249,6 +249,8 @@ class PresentationMediaItem(MediaManagerItem):
|
||||
items = self.list_view.selectedItems()
|
||||
if len(items) > 1:
|
||||
return False
|
||||
filename = presentation_file
|
||||
if filename is None:
|
||||
filename = items[0].data(QtCore.Qt.UserRole)
|
||||
file_type = os.path.splitext(filename)[1][1:]
|
||||
if not self.display_type_combo_box.currentText():
|
||||
@ -261,6 +263,8 @@ class PresentationMediaItem(MediaManagerItem):
|
||||
# force a nonexistent theme
|
||||
service_item.theme = -1
|
||||
for bitem in items:
|
||||
filename = presentation_file
|
||||
if filename is None:
|
||||
filename = bitem.data(QtCore.Qt.UserRole)
|
||||
(path, name) = os.path.split(filename)
|
||||
service_item.title = name
|
||||
@ -298,7 +302,7 @@ class PresentationMediaItem(MediaManagerItem):
|
||||
(path, name) = os.path.split(filename)
|
||||
service_item.title = name
|
||||
if os.path.exists(filename):
|
||||
if service_item.processor == self.Automatic:
|
||||
if service_item.processor == self.automatic:
|
||||
service_item.processor = self.findControllerByType(filename)
|
||||
if not service_item.processor:
|
||||
return False
|
||||
|
@ -33,7 +33,7 @@ from PyQt4 import QtCore
|
||||
|
||||
from openlp.core.lib import Registry
|
||||
from openlp.core.ui import HideMode
|
||||
from openlp.core.lib import ServiceItemContext
|
||||
from openlp.core.lib import ServiceItemContext, ServiceItem
|
||||
|
||||
log = logging.getLogger(__name__)
|
||||
|
||||
@ -318,14 +318,26 @@ class MessageListener(object):
|
||||
hide_mode = message[2]
|
||||
file = item.get_frame_path()
|
||||
self.handler = item.processor
|
||||
#self.media_item.generate_slide_data(self, service_item, item=None, xml_version=False,remote=False, context=ServiceItemContext.Service)
|
||||
# When starting presentation from the servicemanager/slidecontroller we convert
|
||||
# PDF/XPS-serviceitems into image-serviceitems. When started from the mediamanager
|
||||
# the conversion has already been done.
|
||||
if file.endswith('.pdf') or file.endswith('.xps'):
|
||||
log.debug('Trying to convert from pdf to images for service-item')
|
||||
log.debug('Converting from pdf/xps to images for serviceitem with file %s', file)
|
||||
# Create a new image-serviceitem which will overwrite the old one
|
||||
new_item = ServiceItem()
|
||||
new_item.name = 'images'
|
||||
if is_live:
|
||||
self.media_item.generate_slide_data(self, item, None, False, False, ServiceItemContext.Live)
|
||||
self.media_item.generate_slide_data(new_item, item, False, False, ServiceItemContext.Live, file)
|
||||
else:
|
||||
self.media_item.generate_slide_data(self, item, None, False, False, ServiceItemContext.Preview)
|
||||
|
||||
self.media_item.generate_slide_data(new_item, item, False, False, ServiceItemContext.Preview, file)
|
||||
# We need to overwrite the current serviceitem to make the slidecontroller
|
||||
# present the images, so we do some copying
|
||||
service_repr = {'serviceitem': new_item.get_service_repr(True) }
|
||||
item.set_from_service(service_repr)
|
||||
item._raw_frames = new_item._raw_frames
|
||||
# When presenting PDF or XPS, we are using the image presentation code,
|
||||
# so handler & processor is set to None, and we skip adding the handler.
|
||||
self.handler = None
|
||||
if self.handler == self.media_item.automatic:
|
||||
self.handler = self.media_item.findControllerByType(file)
|
||||
if not self.handler:
|
||||
@ -334,9 +346,8 @@ class MessageListener(object):
|
||||
controller = self.live_handler
|
||||
else:
|
||||
controller = self.preview_handler
|
||||
# when presenting PDF, we're using the image presentation code,
|
||||
# When presenting PDF or XPS, we are using the image presentation code,
|
||||
# so handler & processor is set to None, and we skip adding the handler.
|
||||
log.debug('file: %s' % file)
|
||||
if self.handler == None:
|
||||
self.controller = controller
|
||||
else:
|
||||
|
Loading…
Reference in New Issue
Block a user