forked from openlp/openlp
Fix renderer for text wider than the screen.
This commit is contained in:
parent
2816277af1
commit
f79b7b4e01
@ -167,32 +167,37 @@ class Renderer(object):
|
|||||||
#take the width work out approx how many characters and add 50%
|
#take the width work out approx how many characters and add 50%
|
||||||
line_width = self._rect.width() - self._right_margin
|
line_width = self._rect.width() - self._right_margin
|
||||||
#number of lines on a page - adjust for rounding up.
|
#number of lines on a page - adjust for rounding up.
|
||||||
|
print self._rect.height() , metrics.height(), int(self._rect.height() / metrics.height())
|
||||||
page_length = int(self._rect.height() / metrics.height()) - 1
|
page_length = int(self._rect.height() / metrics.height()) - 1
|
||||||
ave_line_width = line_width / metrics.averageCharWidth()
|
ave_line_width = line_width / metrics.averageCharWidth()
|
||||||
#print ave_line_width
|
# print "A", ave_line_width
|
||||||
ave_line_width = int(ave_line_width + (ave_line_width * 0.5))
|
ave_line_width = int(ave_line_width + (ave_line_width * 0.5))
|
||||||
#print ave_line_width
|
# print "B", ave_line_width
|
||||||
split_pages = []
|
split_pages = []
|
||||||
page = []
|
page = []
|
||||||
split_lines = []
|
split_lines = []
|
||||||
count = 0
|
count = 0
|
||||||
for line in text:
|
for line in text:
|
||||||
#print line , len(line)
|
# print "C", line , len(line)
|
||||||
if len(line) > ave_line_width:
|
if len(line) > ave_line_width:
|
||||||
while len(line) > 0:
|
while len(line) > 0:
|
||||||
pos = line.find(u' ', ave_line_width)
|
pos = line.find(u' ', ave_line_width)
|
||||||
#print ave_line_width, pos, line[:pos]
|
# print "D2", len(line), ave_line_width, pos, line[:pos]
|
||||||
split_text = line[:pos]
|
split_text = line[:pos]
|
||||||
#print metrics.width(split_text, -1), line_width
|
# print "E", metrics.width(split_text, -1), line_width
|
||||||
while metrics.width(split_text, -1) > line_width:
|
while metrics.width(split_text, -1) > line_width:
|
||||||
#Find the next space to the left
|
#Find the next space to the left
|
||||||
pos = line[:pos].rfind(u' ')
|
pos = line[:pos].rfind(u' ')
|
||||||
#print ave_line_width, pos, line[:pos]
|
# print "F", ave_line_width, pos, line[:pos]
|
||||||
#no more spaces found
|
#no more spaces found
|
||||||
if pos == -1:
|
if pos == 0:
|
||||||
split_text = line
|
split_text = line
|
||||||
|
while metrics.width(split_text, -1) > line_width:
|
||||||
|
split_text = split_text[:-1]
|
||||||
|
pos = len(split_text)
|
||||||
else:
|
else:
|
||||||
split_text = line[:pos]
|
split_text = line[:pos]
|
||||||
|
# print "F1", split_text, line, pos
|
||||||
split_lines.append(split_text)
|
split_lines.append(split_text)
|
||||||
line = line[pos:]
|
line = line[pos:]
|
||||||
#Text fits in a line now
|
#Text fits in a line now
|
||||||
@ -200,13 +205,14 @@ class Renderer(object):
|
|||||||
split_lines.append(line)
|
split_lines.append(line)
|
||||||
line = u''
|
line = u''
|
||||||
# count += 1
|
# count += 1
|
||||||
# if count == 50:
|
# if count == 15:
|
||||||
# a = c
|
# a = c
|
||||||
#print split_lines
|
# print "G", split_lines
|
||||||
#print line
|
# print "H", line
|
||||||
else:
|
else:
|
||||||
split_lines.append(line)
|
split_lines.append(line)
|
||||||
line = u''
|
line = u''
|
||||||
|
print "I", split_lines, page_length
|
||||||
for line in split_lines:
|
for line in split_lines:
|
||||||
page.append(line)
|
page.append(line)
|
||||||
if len(page) == page_length:
|
if len(page) == page_length:
|
||||||
@ -306,72 +312,72 @@ class Renderer(object):
|
|||||||
QtCore.Qt.SmoothTransformation)
|
QtCore.Qt.SmoothTransformation)
|
||||||
log.debug(u'render background End')
|
log.debug(u'render background End')
|
||||||
|
|
||||||
def _split_set_of_lines(self, lines, footer):
|
# def _split_set_of_lines(self, lines, footer):
|
||||||
"""
|
# """
|
||||||
Given a list of lines, decide how to split them best if they don't all
|
# Given a list of lines, decide how to split them best if they don't all
|
||||||
fit on the screen. This is done by splitting at 1/2, 1/3 or 1/4 of the
|
# fit on the screen. This is done by splitting at 1/2, 1/3 or 1/4 of the
|
||||||
set. If it doesn't fit, even at this size, just split at each
|
# set. If it doesn't fit, even at this size, just split at each
|
||||||
opportunity. We'll do this by getting the bounding box of each line,
|
# opportunity. We'll do this by getting the bounding box of each line,
|
||||||
and then summing them appropriately.
|
# and then summing them appropriately.
|
||||||
|
#
|
||||||
Returns a list of [lists of lines], one set for each screenful.
|
# Returns a list of [lists of lines], one set for each screenful.
|
||||||
|
#
|
||||||
``lines``
|
# ``lines``
|
||||||
The lines of text to split.
|
# The lines of text to split.
|
||||||
|
#
|
||||||
``footer``
|
# ``footer``
|
||||||
The footer text.
|
# The footer text.
|
||||||
"""
|
# """
|
||||||
bboxes = []
|
# bboxes = []
|
||||||
for line in lines:
|
# for line in lines:
|
||||||
bboxes.append(self._render_and_wrap_single_line(line, footer))
|
# bboxes.append(self._render_and_wrap_single_line(line, footer))
|
||||||
numlines = len(lines)
|
# numlines = len(lines)
|
||||||
bottom = self._rect.bottom()
|
# bottom = self._rect.bottom()
|
||||||
for ratio in (numlines, numlines/2, numlines/3, numlines/4):
|
# for ratio in (numlines, numlines/2, numlines/3, numlines/4):
|
||||||
good = 1
|
# good = 1
|
||||||
startline = 0
|
# startline = 0
|
||||||
endline = startline + ratio
|
# endline = startline + ratio
|
||||||
while (endline <= numlines and endline != 0):
|
# while (endline <= numlines and endline != 0):
|
||||||
by = 0
|
# by = 0
|
||||||
for (x,y) in bboxes[startline:endline]:
|
# for (x,y) in bboxes[startline:endline]:
|
||||||
by += y
|
# by += y
|
||||||
if by > bottom:
|
# if by > bottom:
|
||||||
good = 0
|
# good = 0
|
||||||
break
|
# break
|
||||||
startline += ratio
|
# startline += ratio
|
||||||
endline = startline + ratio
|
# endline = startline + ratio
|
||||||
if good == 1:
|
# if good == 1:
|
||||||
break
|
# break
|
||||||
retval = []
|
# retval = []
|
||||||
numlines_per_page = ratio
|
# numlines_per_page = ratio
|
||||||
if good:
|
# if good:
|
||||||
c = 0
|
# c = 0
|
||||||
thislines = []
|
# thislines = []
|
||||||
while c < numlines:
|
# while c < numlines:
|
||||||
thislines.append(lines[c])
|
# thislines.append(lines[c])
|
||||||
c += 1
|
# c += 1
|
||||||
if len(thislines) == numlines_per_page:
|
# if len(thislines) == numlines_per_page:
|
||||||
retval.append(thislines)
|
# retval.append(thislines)
|
||||||
thislines = []
|
# thislines = []
|
||||||
if len(thislines) > 0:
|
# if len(thislines) > 0:
|
||||||
retval.append(thislines)
|
# retval.append(thislines)
|
||||||
else:
|
# else:
|
||||||
# print "Just split where you can"
|
# # print "Just split where you can"
|
||||||
retval = []
|
# retval = []
|
||||||
startline = 0
|
# startline = 0
|
||||||
endline = startline + 1
|
# endline = startline + 1
|
||||||
while (endline <= numlines):
|
# while (endline <= numlines):
|
||||||
by = 0
|
# by = 0
|
||||||
for (x,y) in bboxes[startline:endline]:
|
# for (x,y) in bboxes[startline:endline]:
|
||||||
by += y
|
# by += y
|
||||||
if by > bottom:
|
# if by > bottom:
|
||||||
retval.append(lines[startline:endline-1])
|
# retval.append(lines[startline:endline-1])
|
||||||
startline = endline-1
|
# startline = endline-1
|
||||||
# gets incremented below
|
# # gets incremented below
|
||||||
endline = startline
|
# endline = startline
|
||||||
by = 0
|
# by = 0
|
||||||
endline += 1
|
# endline += 1
|
||||||
return retval
|
# return retval
|
||||||
|
|
||||||
def _correctAlignment(self, rect, bbox):
|
def _correctAlignment(self, rect, bbox):
|
||||||
"""
|
"""
|
||||||
|
Loading…
Reference in New Issue
Block a user