forked from openlp/openlp
Renderer handling changes
bzr-revno: 543
This commit is contained in:
commit
90584efee6
@ -51,9 +51,9 @@ class Renderer(object):
|
|||||||
self._theme = None
|
self._theme = None
|
||||||
self._bg_image_filename = None
|
self._bg_image_filename = None
|
||||||
self._frame = None
|
self._frame = None
|
||||||
self._bg_frame = None
|
self.bg_frame = None
|
||||||
self.bg_image = None
|
self.bg_image = None
|
||||||
self._bg_frame_small = None
|
#self.bg_frame_small = None
|
||||||
|
|
||||||
def set_debug(self, debug):
|
def set_debug(self, debug):
|
||||||
"""
|
"""
|
||||||
@ -73,7 +73,7 @@ class Renderer(object):
|
|||||||
"""
|
"""
|
||||||
log.debug(u'set theme')
|
log.debug(u'set theme')
|
||||||
self._theme = theme
|
self._theme = theme
|
||||||
self._bg_frame = None
|
self.bg_frame = None
|
||||||
self.bg_image = None
|
self.bg_image = None
|
||||||
self.theme_name = theme.theme_name
|
self.theme_name = theme.theme_name
|
||||||
self._set_theme_font()
|
self._set_theme_font()
|
||||||
@ -131,14 +131,14 @@ class Renderer(object):
|
|||||||
Defaults to *False*. Whether or not to generate a preview.
|
Defaults to *False*. Whether or not to generate a preview.
|
||||||
"""
|
"""
|
||||||
if preview == True:
|
if preview == True:
|
||||||
self._bg_frame = None
|
self.bg_frame = None
|
||||||
log.debug(u'set frame dest (frame) w %d h %d', frame_width,
|
log.debug(u'set frame dest (frame) w %d h %d', frame_width,
|
||||||
frame_height)
|
frame_height)
|
||||||
self._frame = QtGui.QImage(frame_width, frame_height,
|
self._frame = QtGui.QImage(frame_width, frame_height,
|
||||||
QtGui.QImage.Format_ARGB32_Premultiplied)
|
QtGui.QImage.Format_ARGB32_Premultiplied)
|
||||||
if self._bg_image_filename is not None and self.bg_image is None:
|
if self._bg_image_filename is not None and self.bg_image is None:
|
||||||
self.scale_bg_image()
|
self.scale_bg_image()
|
||||||
if self._bg_frame is None:
|
if self.bg_frame is None:
|
||||||
self._generate_background_frame()
|
self._generate_background_frame()
|
||||||
|
|
||||||
def format_slide(self, words, footer):
|
def format_slide(self, words, footer):
|
||||||
@ -257,7 +257,7 @@ class Renderer(object):
|
|||||||
if footer_lines is not None:
|
if footer_lines is not None:
|
||||||
bbox1 = self._render_lines_unaligned(footer_lines, True)
|
bbox1 = self._render_lines_unaligned(footer_lines, True)
|
||||||
# reset the frame. first time do not worry about what you paint on.
|
# reset the frame. first time do not worry about what you paint on.
|
||||||
self._frame = QtGui.QImage(self._bg_frame)
|
self._frame = QtGui.QImage(self.bg_frame)
|
||||||
x, y = self._correctAlignment(self._rect, bbox)
|
x, y = self._correctAlignment(self._rect, bbox)
|
||||||
bbox = self._render_lines_unaligned(lines, False, (x, y), True)
|
bbox = self._render_lines_unaligned(lines, False, (x, y), True)
|
||||||
if footer_lines is not None:
|
if footer_lines is not None:
|
||||||
@ -272,11 +272,11 @@ class Renderer(object):
|
|||||||
Results are cached for performance reasons.
|
Results are cached for performance reasons.
|
||||||
"""
|
"""
|
||||||
assert(self._theme)
|
assert(self._theme)
|
||||||
self._bg_frame = QtGui.QImage(self._frame.width(), self._frame.height(),
|
self.bg_frame = QtGui.QImage(self._frame.width(), self._frame.height(),
|
||||||
QtGui.QImage.Format_ARGB32_Premultiplied)
|
QtGui.QImage.Format_ARGB32_Premultiplied)
|
||||||
log.debug(u'render background %s start', self._theme.background_type)
|
log.debug(u'render background %s start', self._theme.background_type)
|
||||||
painter = QtGui.QPainter()
|
painter = QtGui.QPainter()
|
||||||
painter.begin(self._bg_frame)
|
painter.begin(self.bg_frame)
|
||||||
if self._theme.background_mode == u'transparent':
|
if self._theme.background_mode == u'transparent':
|
||||||
painter.fillRect(self._frame.rect(), QtCore.Qt.transparent)
|
painter.fillRect(self._frame.rect(), QtCore.Qt.transparent)
|
||||||
else:
|
else:
|
||||||
@ -321,8 +321,8 @@ class Renderer(object):
|
|||||||
if self.bg_image is not None:
|
if self.bg_image is not None:
|
||||||
painter.drawImage(0, 0, self.bg_image)
|
painter.drawImage(0, 0, self.bg_image)
|
||||||
painter.end()
|
painter.end()
|
||||||
self._bg_frame_small = self._bg_frame.scaled(QtCore.QSize(280, 210),
|
# self.bg_frame_small = self.bg_frame.scaled(QtCore.QSize(280, 210),
|
||||||
QtCore.Qt.KeepAspectRatio, QtCore.Qt.SmoothTransformation)
|
# QtCore.Qt.KeepAspectRatio, QtCore.Qt.SmoothTransformation)
|
||||||
log.debug(u'render background End')
|
log.debug(u'render background End')
|
||||||
|
|
||||||
def _correctAlignment(self, rect, bbox):
|
def _correctAlignment(self, rect, bbox):
|
||||||
|
@ -61,14 +61,11 @@ class ServiceItem(object):
|
|||||||
self.items = []
|
self.items = []
|
||||||
self.iconic_representation = None
|
self.iconic_representation = None
|
||||||
self.raw_slides = None
|
self.raw_slides = None
|
||||||
self.frame_titles = []
|
|
||||||
self.command_files = []
|
|
||||||
self.frames = []
|
self.frames = []
|
||||||
self.raw_footer = None
|
self.raw_footer = None
|
||||||
self.theme = None
|
self.theme = None
|
||||||
self.service_item_path = None
|
self.service_item_path = None
|
||||||
self.service_item_type = None
|
self.service_item_type = None
|
||||||
#log.debug(u'Service item created for %s ', self.shortname)
|
|
||||||
self.service_frames = []
|
self.service_frames = []
|
||||||
|
|
||||||
def addIcon(self, icon):
|
def addIcon(self, icon):
|
||||||
@ -95,12 +92,19 @@ class ServiceItem(object):
|
|||||||
self.RenderManager.set_override_theme(None)
|
self.RenderManager.set_override_theme(None)
|
||||||
else:
|
else:
|
||||||
self.RenderManager.set_override_theme(self.theme)
|
self.RenderManager.set_override_theme(self.theme)
|
||||||
|
firstTime = True
|
||||||
for slide in self.service_frames:
|
for slide in self.service_frames:
|
||||||
formated = self.RenderManager.format_slide(slide[u'raw_slide'])
|
formated = self.RenderManager.format_slide(slide[u'raw_slide'])
|
||||||
for format in formated:
|
for format in formated:
|
||||||
|
frame = None
|
||||||
|
if firstTime:
|
||||||
frame = self.RenderManager.generate_slide(format,
|
frame = self.RenderManager.generate_slide(format,
|
||||||
self.raw_footer)
|
self.raw_footer)
|
||||||
self.frames.append({u'title': slide[u'title'],
|
firstTime = False
|
||||||
|
lines = u''
|
||||||
|
for line in format:
|
||||||
|
lines += line + u'\n'
|
||||||
|
self.frames.append({u'title': slide[u'title'],u'text':lines,
|
||||||
u'image': frame})
|
u'image': frame})
|
||||||
elif self.service_item_type == ServiceType.Command:
|
elif self.service_item_type == ServiceType.Command:
|
||||||
self.frames = self.service_frames
|
self.frames = self.service_frames
|
||||||
@ -112,6 +116,17 @@ class ServiceItem(object):
|
|||||||
else:
|
else:
|
||||||
log.error(u'Invalid value renderer :%s' % self.service_item_type)
|
log.error(u'Invalid value renderer :%s' % self.service_item_type)
|
||||||
|
|
||||||
|
def render_individual(self, row):
|
||||||
|
log.debug(u'render individual')
|
||||||
|
if self.theme == None:
|
||||||
|
self.RenderManager.set_override_theme(None)
|
||||||
|
else:
|
||||||
|
self.RenderManager.set_override_theme(self.theme)
|
||||||
|
format = self.frames[row][u'text'].split(u'\n')
|
||||||
|
frame = self.RenderManager.generate_slide(format,
|
||||||
|
self.raw_footer)
|
||||||
|
return frame
|
||||||
|
|
||||||
def add_from_image(self, path, frame_title, image):
|
def add_from_image(self, path, frame_title, image):
|
||||||
"""
|
"""
|
||||||
Add an image slide to the service item.
|
Add an image slide to the service item.
|
||||||
@ -127,7 +142,7 @@ class ServiceItem(object):
|
|||||||
"""
|
"""
|
||||||
self.service_item_type = ServiceType.Image
|
self.service_item_type = ServiceType.Image
|
||||||
self.service_item_path = path
|
self.service_item_path = path
|
||||||
self.service_frames.append({u'title': frame_title, u'image': image})
|
self.service_frames.append({u'title': frame_title, u'text':None, u'image': image})
|
||||||
|
|
||||||
def add_from_text(self, frame_title, raw_slide):
|
def add_from_text(self, frame_title, raw_slide):
|
||||||
"""
|
"""
|
||||||
|
@ -166,7 +166,7 @@ class SlideController(QtGui.QWidget):
|
|||||||
self.Toolbar.setSizePolicy(sizeToolbarPolicy)
|
self.Toolbar.setSizePolicy(sizeToolbarPolicy)
|
||||||
# Screen preview area
|
# Screen preview area
|
||||||
self.PreviewFrame = QtGui.QFrame(self.Splitter)
|
self.PreviewFrame = QtGui.QFrame(self.Splitter)
|
||||||
self.PreviewFrame.setGeometry(QtCore.QRect(0, 0, self.settingsmanager.slidecontroller_image, 225))
|
self.PreviewFrame.setGeometry(QtCore.QRect(0, 0, 300, 225))
|
||||||
self.PreviewFrame.setSizePolicy(QtGui.QSizePolicy(
|
self.PreviewFrame.setSizePolicy(QtGui.QSizePolicy(
|
||||||
QtGui.QSizePolicy.Preferred, QtGui.QSizePolicy.Minimum))
|
QtGui.QSizePolicy.Preferred, QtGui.QSizePolicy.Minimum))
|
||||||
self.PreviewFrame.setFrameShape(QtGui.QFrame.StyledPanel)
|
self.PreviewFrame.setFrameShape(QtGui.QFrame.StyledPanel)
|
||||||
@ -293,12 +293,15 @@ class SlideController(QtGui.QWidget):
|
|||||||
self.PreviewListWidget.setColumnWidth(0, slide_width)
|
self.PreviewListWidget.setColumnWidth(0, slide_width)
|
||||||
for framenumber, frame in enumerate(self.serviceitem.frames):
|
for framenumber, frame in enumerate(self.serviceitem.frames):
|
||||||
self.PreviewListWidget.setRowCount(self.PreviewListWidget.rowCount() + 1)
|
self.PreviewListWidget.setRowCount(self.PreviewListWidget.rowCount() + 1)
|
||||||
pixmap = self.parent.RenderManager.resize_image(frame[u'image'], slide_width, slide_height)
|
|
||||||
item = QtGui.QTableWidgetItem()
|
item = QtGui.QTableWidgetItem()
|
||||||
label = QtGui.QLabel()
|
label = QtGui.QLabel()
|
||||||
label.setMargin(8)
|
label.setMargin(8)
|
||||||
|
if frame[u'text'] == None:
|
||||||
|
pixmap = self.parent.RenderManager.resize_image(frame[u'image'], slide_width, slide_height)
|
||||||
label.setScaledContents(True)
|
label.setScaledContents(True)
|
||||||
label.setPixmap(QtGui.QPixmap.fromImage(pixmap))
|
label.setPixmap(QtGui.QPixmap.fromImage(pixmap))
|
||||||
|
else:
|
||||||
|
label.setText(frame[u'text'])
|
||||||
self.PreviewListWidget.setCellWidget(framenumber, 0, label)
|
self.PreviewListWidget.setCellWidget(framenumber, 0, label)
|
||||||
self.PreviewListWidget.setItem(framenumber, 0, item)
|
self.PreviewListWidget.setItem(framenumber, 0, item)
|
||||||
self.PreviewListWidget.setRowHeight(framenumber, slide_height)
|
self.PreviewListWidget.setRowHeight(framenumber, slide_height)
|
||||||
@ -335,9 +338,12 @@ class SlideController(QtGui.QWidget):
|
|||||||
row = self.PreviewListWidget.currentRow()
|
row = self.PreviewListWidget.currentRow()
|
||||||
if row > -1 and row < self.PreviewListWidget.rowCount():
|
if row > -1 and row < self.PreviewListWidget.rowCount():
|
||||||
label = self.PreviewListWidget.cellWidget(row, 0)
|
label = self.PreviewListWidget.cellWidget(row, 0)
|
||||||
smallframe = label.pixmap()
|
|
||||||
frame = self.serviceitem.frames[row][u'image']
|
frame = self.serviceitem.frames[row][u'image']
|
||||||
self.SlidePreview.setPixmap(smallframe)
|
before = time.time()
|
||||||
|
if frame == None:
|
||||||
|
frame = self.serviceitem.render_individual(row)
|
||||||
|
self.SlidePreview.setPixmap(QtGui.QPixmap.fromImage(frame))
|
||||||
|
log.info(u'Slide Rendering took %4s' % (time.time() - before))
|
||||||
if self.isLive:
|
if self.isLive:
|
||||||
self.parent.mainDisplay.frameView(frame)
|
self.parent.mainDisplay.frameView(frame)
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user