Fix renderer for text wider than the screen.

This commit is contained in:
Tim Bentley 2009-08-05 18:11:31 +01:00
parent 2816277af1
commit f79b7b4e01

View File

@ -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):
""" """