forked from openlp/openlp
Render Ester 8:9 on more than 1 page
This commit is contained in:
parent
b84c4a0a3d
commit
239b62a488
@ -29,7 +29,8 @@ import logging
|
|||||||
from PyQt4 import QtCore, QtWebKit
|
from PyQt4 import QtCore, QtWebKit
|
||||||
|
|
||||||
from openlp.core.lib import ServiceItem, ImageManager, expand_tags, \
|
from openlp.core.lib import ServiceItem, ImageManager, expand_tags, \
|
||||||
build_lyrics_format_css, build_lyrics_outline_css, Receiver
|
build_lyrics_format_css, build_lyrics_outline_css, Receiver, \
|
||||||
|
ItemCapabilities
|
||||||
from openlp.core.lib.theme import ThemeLevel
|
from openlp.core.lib.theme import ThemeLevel
|
||||||
from openlp.core.ui import MainDisplay
|
from openlp.core.ui import MainDisplay
|
||||||
|
|
||||||
@ -77,8 +78,6 @@ class RenderManager(object):
|
|||||||
self.override_background = None
|
self.override_background = None
|
||||||
self.theme_data = None
|
self.theme_data = None
|
||||||
self.force_page = False
|
self.force_page = False
|
||||||
self.r_theme_name = None
|
|
||||||
self._r_theme = None
|
|
||||||
|
|
||||||
def update_display(self):
|
def update_display(self):
|
||||||
"""
|
"""
|
||||||
@ -157,19 +156,16 @@ class RenderManager(object):
|
|||||||
self.theme = self.service_theme
|
self.theme = self.service_theme
|
||||||
else:
|
else:
|
||||||
self.theme = self.global_theme
|
self.theme = self.global_theme
|
||||||
if self.theme != self.r_theme_name or self.theme_data is None \
|
log.debug(u'theme is now %s', self.theme)
|
||||||
or overrideLevels:
|
# Force the theme to be the one passed in.
|
||||||
log.debug(u'theme is now %s', self.theme)
|
if overrideLevels:
|
||||||
# Force the theme to be the one passed in.
|
self.theme_data = theme
|
||||||
if overrideLevels:
|
else:
|
||||||
self.theme_data = theme
|
self.theme_data = self.theme_manager.getThemeData(self.theme)
|
||||||
else:
|
self._calculate_default(self.screens.current[u'size'])
|
||||||
self.theme_data = self.theme_manager.getThemeData(self.theme)
|
self._build_text_rectangle(self.theme_data)
|
||||||
self._calculate_default(self.screens.current[u'size'])
|
self.image_manager.add_image(self.theme_data.theme_name,
|
||||||
self._set_theme(self.theme_data)
|
self.theme_data.background_filename)
|
||||||
self._build_text_rectangle(self.theme_data)
|
|
||||||
self.image_manager.add_image(self.theme_data.theme_name,
|
|
||||||
self.theme_data.background_filename)
|
|
||||||
return self._rect, self._rect_footer
|
return self._rect, self._rect_footer
|
||||||
|
|
||||||
def generate_preview(self, theme_data, force_page=False):
|
def generate_preview(self, theme_data, force_page=False):
|
||||||
@ -207,18 +203,29 @@ class RenderManager(object):
|
|||||||
self._calculate_default(self.screens.current[u'size'])
|
self._calculate_default(self.screens.current[u'size'])
|
||||||
return preview
|
return preview
|
||||||
|
|
||||||
def format_slide(self, words, line_break):
|
def format_slide(self, slide, line_break, item):
|
||||||
"""
|
"""
|
||||||
Calculate how much text can fit on a slide.
|
Calculate how much text can fit on a slide.
|
||||||
|
|
||||||
``words``
|
``slide``
|
||||||
The words to go on the slides.
|
The words to go on the slides.
|
||||||
|
|
||||||
``line_break``
|
``line_break``
|
||||||
Add line endings after each line of text used for bibles.
|
Add line endings after each line of text used for bibles.
|
||||||
"""
|
"""
|
||||||
log.debug(u'format slide')
|
log.debug(u'format slide')
|
||||||
return self._format_slide(words, line_break, self.force_page)
|
# clean up line endings
|
||||||
|
slide = slide.replace(u'\r\n', u'\n')
|
||||||
|
lines = self._lines(slide)
|
||||||
|
pages = self._paginate_slide(lines, line_break, self.force_page)
|
||||||
|
if len(pages) > 1:
|
||||||
|
if item.is_capable(ItemCapabilities.AllowsVirtualSplit):
|
||||||
|
lines = self._words(slide)
|
||||||
|
pages = self._paginate_slide(lines, line_break, self.force_page)
|
||||||
|
elif item.is_capable(ItemCapabilities.AllowsWordSplit):
|
||||||
|
lines = self._words(slide)
|
||||||
|
pages = self._paginate_slide(lines, False, self.force_page)
|
||||||
|
return pages
|
||||||
|
|
||||||
def _calculate_default(self, screen):
|
def _calculate_default(self, screen):
|
||||||
"""
|
"""
|
||||||
@ -261,17 +268,6 @@ class RenderManager(object):
|
|||||||
theme.font_footer_height - 1)
|
theme.font_footer_height - 1)
|
||||||
self._set_text_rectangle(main_rect, footer_rect)
|
self._set_text_rectangle(main_rect, footer_rect)
|
||||||
|
|
||||||
def _set_theme(self, theme):
|
|
||||||
"""
|
|
||||||
Set the theme to be used.
|
|
||||||
|
|
||||||
``theme``
|
|
||||||
The theme to be used.
|
|
||||||
"""
|
|
||||||
log.debug(u'set theme')
|
|
||||||
self._r_theme = theme
|
|
||||||
self.r_theme_name = theme.theme_name
|
|
||||||
|
|
||||||
def _set_text_rectangle(self, rect_main, rect_footer):
|
def _set_text_rectangle(self, rect_main, rect_footer):
|
||||||
"""
|
"""
|
||||||
Sets the rectangle within which text should be rendered.
|
Sets the rectangle within which text should be rendered.
|
||||||
@ -287,9 +283,9 @@ class RenderManager(object):
|
|||||||
self._rect_footer = rect_footer
|
self._rect_footer = rect_footer
|
||||||
self.page_width = self._rect.width()
|
self.page_width = self._rect.width()
|
||||||
self.page_height = self._rect.height()
|
self.page_height = self._rect.height()
|
||||||
if self._r_theme.font_main_shadow:
|
if self.theme_data.font_main_shadow:
|
||||||
self.page_width -= int(self._r_theme.font_main_shadow_size)
|
self.page_width -= int(self.theme_data.font_main_shadow_size)
|
||||||
self.page_height -= int(self._r_theme.font_main_shadow_size)
|
self.page_height -= int(self.theme_data.font_main_shadow_size)
|
||||||
self.web = QtWebKit.QWebView()
|
self.web = QtWebKit.QWebView()
|
||||||
self.web.setVisible(False)
|
self.web.setVisible(False)
|
||||||
self.web.resize(self.page_width, self.page_height)
|
self.web.resize(self.page_width, self.page_height)
|
||||||
@ -299,16 +295,16 @@ class RenderManager(object):
|
|||||||
u'*{margin: 0; padding: 0; border: 0;} '\
|
u'*{margin: 0; padding: 0; border: 0;} '\
|
||||||
u'#main {position:absolute; top:0px; %s %s}</style><body>' \
|
u'#main {position:absolute; top:0px; %s %s}</style><body>' \
|
||||||
u'<div id="main">' % \
|
u'<div id="main">' % \
|
||||||
(build_lyrics_format_css(self._r_theme, self.page_width,
|
(build_lyrics_format_css(self.theme_data, self.page_width,
|
||||||
self.page_height), build_lyrics_outline_css(self._r_theme))
|
self.page_height), build_lyrics_outline_css(self.theme_data))
|
||||||
|
|
||||||
def _format_slide(self, words, line_break, force_page=False):
|
def _paginate_slide(self, lines, line_break, force_page=False):
|
||||||
"""
|
"""
|
||||||
Figure out how much text can appear on a slide, using the current
|
Figure out how much text can appear on a slide, using the current
|
||||||
theme settings.
|
theme settings.
|
||||||
|
|
||||||
``words``
|
``lines``
|
||||||
The words to be fitted on the slide.
|
The words to be fitted on the slide split into lines.
|
||||||
|
|
||||||
``line_break``
|
``line_break``
|
||||||
Add line endings after each line of text used for bibles.
|
Add line endings after each line of text used for bibles.
|
||||||
@ -321,18 +317,11 @@ class RenderManager(object):
|
|||||||
line_end = u''
|
line_end = u''
|
||||||
if line_break:
|
if line_break:
|
||||||
line_end = u'<br>'
|
line_end = u'<br>'
|
||||||
words = words.replace(u'\r\n', u'\n')
|
|
||||||
verses_text = words.split(u'\n')
|
|
||||||
text = []
|
|
||||||
for verse in verses_text:
|
|
||||||
lines = verse.split(u'\n')
|
|
||||||
for line in lines:
|
|
||||||
text.append(line)
|
|
||||||
formatted = []
|
formatted = []
|
||||||
html_text = u''
|
html_text = u''
|
||||||
styled_text = u''
|
styled_text = u''
|
||||||
line_count = 0
|
line_count = 0
|
||||||
for line in text:
|
for line in lines:
|
||||||
if line_count != -1:
|
if line_count != -1:
|
||||||
line_count += 1
|
line_count += 1
|
||||||
styled_line = expand_tags(line) + line_end
|
styled_line = expand_tags(line) + line_end
|
||||||
@ -356,3 +345,31 @@ class RenderManager(object):
|
|||||||
log.debug(u'format_slide - End')
|
log.debug(u'format_slide - End')
|
||||||
return formatted
|
return formatted
|
||||||
|
|
||||||
|
def _lines(self, words):
|
||||||
|
"""
|
||||||
|
Split the slide up by physical line
|
||||||
|
"""
|
||||||
|
# this parse we do not want to use this so remove it
|
||||||
|
words = words.replace(u'[---]', u'')
|
||||||
|
verses_text = words.split(u'\n')
|
||||||
|
text = []
|
||||||
|
for verse in verses_text:
|
||||||
|
lines = verse.split(u'\n')
|
||||||
|
for line in lines:
|
||||||
|
text.append(line)
|
||||||
|
return text
|
||||||
|
|
||||||
|
def _words(self, words):
|
||||||
|
"""
|
||||||
|
Split the slide up by word so can wrap better
|
||||||
|
"""
|
||||||
|
# this parse we are wordy
|
||||||
|
words = words.replace(u'\n', u' ')
|
||||||
|
verses_text = words.split(u' ')
|
||||||
|
text = []
|
||||||
|
for verse in verses_text:
|
||||||
|
lines = verse.split(u' ')
|
||||||
|
for line in lines:
|
||||||
|
text.append(line + u' ')
|
||||||
|
return text
|
||||||
|
|
||||||
|
@ -63,6 +63,8 @@ class ItemCapabilities(object):
|
|||||||
ProvidesOwnDisplay = 10
|
ProvidesOwnDisplay = 10
|
||||||
AllowsDetailedTitleDisplay = 11
|
AllowsDetailedTitleDisplay = 11
|
||||||
AllowsVariableStartTime = 12
|
AllowsVariableStartTime = 12
|
||||||
|
AllowsVirtualSplit = 13
|
||||||
|
AllowsWordSplit = 14
|
||||||
|
|
||||||
|
|
||||||
class ServiceItem(object):
|
class ServiceItem(object):
|
||||||
@ -81,7 +83,7 @@ class ServiceItem(object):
|
|||||||
The plugin that this service item belongs to.
|
The plugin that this service item belongs to.
|
||||||
"""
|
"""
|
||||||
if plugin:
|
if plugin:
|
||||||
self.render_manager = plugin.renderManager
|
self.renderer = plugin.renderManager
|
||||||
self.name = plugin.name
|
self.name = plugin.name
|
||||||
self.title = u''
|
self.title = u''
|
||||||
self.shortname = u''
|
self.shortname = u''
|
||||||
@ -166,13 +168,13 @@ class ServiceItem(object):
|
|||||||
line_break = False
|
line_break = False
|
||||||
theme = self.theme if self.theme else None
|
theme = self.theme if self.theme else None
|
||||||
self.main, self.footer = \
|
self.main, self.footer = \
|
||||||
self.render_manager.set_override_theme(theme, useOverride)
|
self.renderer.set_override_theme(theme, useOverride)
|
||||||
self.themedata = self.render_manager._r_theme
|
self.themedata = self.renderer.theme_data
|
||||||
if self.service_item_type == ServiceItemType.Text:
|
if self.service_item_type == ServiceItemType.Text:
|
||||||
log.debug(u'Formatting slides')
|
log.debug(u'Formatting slides')
|
||||||
for slide in self._raw_frames:
|
for slide in self._raw_frames:
|
||||||
formatted = self.render_manager \
|
formatted = self.renderer \
|
||||||
.format_slide(slide[u'raw_slide'], line_break)
|
.format_slide(slide[u'raw_slide'], line_break, self)
|
||||||
for page in formatted:
|
for page in formatted:
|
||||||
self._display_frames.append(
|
self._display_frames.append(
|
||||||
{u'title': clean_tags(page),
|
{u'title': clean_tags(page),
|
||||||
@ -205,7 +207,7 @@ class ServiceItem(object):
|
|||||||
"""
|
"""
|
||||||
self.service_item_type = ServiceItemType.Image
|
self.service_item_type = ServiceItemType.Image
|
||||||
self._raw_frames.append({u'title': title, u'path': path})
|
self._raw_frames.append({u'title': title, u'path': path})
|
||||||
self.render_manager.image_manager.add_image(title, path)
|
self.renderer.image_manager.add_image(title, path)
|
||||||
self._new_item()
|
self._new_item()
|
||||||
|
|
||||||
def add_from_text(self, title, raw_slide, verse_tag=None):
|
def add_from_text(self, title, raw_slide, verse_tag=None):
|
||||||
|
@ -685,6 +685,7 @@ class BibleMediaItem(MediaManagerItem):
|
|||||||
service_item.add_capability(ItemCapabilities.NoLineBreaks)
|
service_item.add_capability(ItemCapabilities.NoLineBreaks)
|
||||||
service_item.add_capability(ItemCapabilities.AllowsPreview)
|
service_item.add_capability(ItemCapabilities.AllowsPreview)
|
||||||
service_item.add_capability(ItemCapabilities.AllowsLoop)
|
service_item.add_capability(ItemCapabilities.AllowsLoop)
|
||||||
|
service_item.add_capability(ItemCapabilities.AllowsWordSplit)
|
||||||
# Service Item: Title
|
# Service Item: Title
|
||||||
service_item.title = u', '.join(raw_title)
|
service_item.title = u', '.join(raw_title)
|
||||||
# Service Item: Theme
|
# Service Item: Theme
|
||||||
|
@ -139,6 +139,7 @@ class CustomMediaItem(MediaManagerItem):
|
|||||||
service_item.add_capability(ItemCapabilities.AllowsEdit)
|
service_item.add_capability(ItemCapabilities.AllowsEdit)
|
||||||
service_item.add_capability(ItemCapabilities.AllowsPreview)
|
service_item.add_capability(ItemCapabilities.AllowsPreview)
|
||||||
service_item.add_capability(ItemCapabilities.AllowsLoop)
|
service_item.add_capability(ItemCapabilities.AllowsLoop)
|
||||||
|
service_item.add_capability(ItemCapabilities.AllowsVirtualSplit)
|
||||||
customSlide = self.parent.manager.get_object(CustomSlide, item_id)
|
customSlide = self.parent.manager.get_object(CustomSlide, item_id)
|
||||||
title = customSlide.title
|
title = customSlide.title
|
||||||
credit = customSlide.credits
|
credit = customSlide.credits
|
||||||
|
@ -337,6 +337,7 @@ class SongMediaItem(MediaManagerItem):
|
|||||||
service_item.add_capability(ItemCapabilities.AllowsLoop)
|
service_item.add_capability(ItemCapabilities.AllowsLoop)
|
||||||
service_item.add_capability(ItemCapabilities.OnLoadUpdate)
|
service_item.add_capability(ItemCapabilities.OnLoadUpdate)
|
||||||
service_item.add_capability(ItemCapabilities.AddIfNewItem)
|
service_item.add_capability(ItemCapabilities.AddIfNewItem)
|
||||||
|
service_item.add_capability(ItemCapabilities.AllowsVirtualSplit)
|
||||||
song = self.parent.manager.get_object(Song, item_id)
|
song = self.parent.manager.get_object(Song, item_id)
|
||||||
service_item.theme = song.theme_name
|
service_item.theme = song.theme_name
|
||||||
service_item.edit_id = item_id
|
service_item.edit_id = item_id
|
||||||
|
Loading…
Reference in New Issue
Block a user