Various bug fixes and code improvements.

bzr-revno: 493
This commit is contained in:
Tim Bentley 2009-07-15 20:04:12 +01:00
commit 9044e5c88c
7 changed files with 130 additions and 48 deletions

View File

@ -151,10 +151,70 @@ class Renderer(object):
lines = verse.split(u'\n') lines = verse.split(u'\n')
for line in lines: for line in lines:
text.append(line) text.append(line)
split_text = self._split_set_of_lines(text, False) #print text
split_text = self.pre_render_text(text)
# print "-----------------------------"
# print split_text
# split_text = self._split_set_of_lines(text, False)
# print "-----------------------------"
# print split_text
log.debug(u'format_slide - End') log.debug(u'format_slide - End')
return split_text return split_text
def pre_render_text(self, text):
metrics = QtGui.QFontMetrics(self.mainFont)
#take the width work out approx how many characters and add 50%
line_width = self._rect.width() - self._right_margin
#number of lines on a page - adjust for rounding up.
page_length = int(self._rect.height() / metrics.height()) - 1
ave_line_width = line_width / metrics.averageCharWidth()
#print ave_line_width
ave_line_width = int(ave_line_width + (ave_line_width * 0.5))
#print ave_line_width
split_pages = []
page = []
split_lines = []
count = 0
for line in text:
#print line , len(line)
if len(line) > ave_line_width:
while len(line) > 0:
pos = line.find(u' ', ave_line_width)
#print ave_line_width, pos, line[:pos]
split_text = line[:pos]
#print metrics.width(split_text, -1), line_width
while metrics.width(split_text, -1) > line_width:
#Find the next space to the left
pos = line[:pos].rfind(u' ')
#print ave_line_width, pos, line[:pos]
#no more spaces found
if pos == -1:
split_text = line
else:
split_text = line[:pos]
split_lines.append(split_text)
line = line[pos:]
#Text fits in a line now
if len(line) <= ave_line_width:
split_lines.append(line)
line = u''
# count += 1
# if count == 50:
# a = c
#print split_lines
#print line
else:
split_lines.append(line)
line = u''
for line in split_lines:
page.append(line)
if len(page) == page_length:
split_pages.append(page)
page = []
if len(page) > 0:
split_pages.append(page)
return split_pages
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.
@ -544,7 +604,6 @@ class Renderer(object):
painter.setPen(QtGui.QColor(color)) painter.setPen(QtGui.QColor(color))
x, y = tlcorner x, y = tlcorner
metrics = QtGui.QFontMetrics(font) metrics = QtGui.QFontMetrics(font)
# xxx some fudges to make it exactly like wx! Take 'em out later
w = metrics.width(line) w = metrics.width(line)
h = metrics.height() - 2 h = metrics.height() - 2
if draw: if draw:

View File

@ -138,7 +138,7 @@ class RenderManager(object):
main_rect = None main_rect = None
footer_rect = None footer_rect = None
if theme.font_main_override == False: if theme.font_main_override == False:
main_rect = QtCore.QRect(10,0, self.width-1, self.height-1) main_rect = QtCore.QRect(10,0, self.width - 1, self.footer_start - 20)
else: else:
main_rect = QtCore.QRect(int(theme.font_main_x) , int(theme.font_main_y), main_rect = QtCore.QRect(int(theme.font_main_x) , int(theme.font_main_y),
int(theme.font_main_width)-1, int(theme.font_main_height) - 1) int(theme.font_main_width)-1, int(theme.font_main_height) - 1)

View File

@ -71,29 +71,29 @@ class AmendThemeForm(QtGui.QDialog, Ui_AmendThemeDialog):
QtCore.SIGNAL(u'activated(int)'), self.onVerticalComboBoxSelected) QtCore.SIGNAL(u'activated(int)'), self.onVerticalComboBoxSelected)
QtCore.QObject.connect(self.FontMainSizeSpinBox, QtCore.QObject.connect(self.FontMainSizeSpinBox,
QtCore.SIGNAL(u'valueChanged(int)'), self.onFontMainSizeSpinBoxChanged) QtCore.SIGNAL(u'editingFinished()'), self.onFontMainSizeSpinBoxChanged)
QtCore.QObject.connect(self.FontFooterSizeSpinBox, QtCore.QObject.connect(self.FontFooterSizeSpinBox,
QtCore.SIGNAL(u'valueChanged(int)'), self.onFontFooterSizeSpinBoxChanged) QtCore.SIGNAL(u'editingFinished()'), self.onFontFooterSizeSpinBoxChanged)
QtCore.QObject.connect(self.FontMainDefaultCheckBox, QtCore.QObject.connect(self.FontMainDefaultCheckBox,
QtCore.SIGNAL(u'stateChanged(int)'), self.onFontMainDefaultCheckBoxChanged) QtCore.SIGNAL(u'stateChanged(int)'), self.onFontMainDefaultCheckBoxChanged)
QtCore.QObject.connect(self.FontMainXSpinBox, QtCore.QObject.connect(self.FontMainXSpinBox,
QtCore.SIGNAL(u'valueChanged(int)'), self.onFontMainXSpinBoxChanged) QtCore.SIGNAL(u'editingFinished()'), self.onFontMainXSpinBoxChanged)
QtCore.QObject.connect(self.FontMainYSpinBox, QtCore.QObject.connect(self.FontMainYSpinBox,
QtCore.SIGNAL(u'valueChanged(int)'), self.onFontMainYSpinBoxChanged) QtCore.SIGNAL(u'editingFinished()'), self.onFontMainYSpinBoxChanged)
QtCore.QObject.connect(self.FontMainWidthSpinBox, QtCore.QObject.connect(self.FontMainWidthSpinBox,
QtCore.SIGNAL(u'valueChanged(int)'), self.onFontMainWidthSpinBoxChanged) QtCore.SIGNAL(u'editingFinished()'), self.onFontMainWidthSpinBoxChanged)
QtCore.QObject.connect(self.FontMainHeightSpinBox, QtCore.QObject.connect(self.FontMainHeightSpinBox,
QtCore.SIGNAL(u'valueChanged(int)'), self.onFontMainHeightSpinBoxChanged) QtCore.SIGNAL(u'editingFinished()'), self.onFontMainHeightSpinBoxChanged)
QtCore.QObject.connect(self.FontFooterDefaultCheckBox, QtCore.QObject.connect(self.FontFooterDefaultCheckBox,
QtCore.SIGNAL(u'stateChanged(int)'), self.onFontFooterDefaultCheckBoxChanged) QtCore.SIGNAL(u'stateChanged(int)'), self.onFontFooterDefaultCheckBoxChanged)
QtCore.QObject.connect(self.FontFooterXSpinBox, QtCore.QObject.connect(self.FontFooterXSpinBox,
QtCore.SIGNAL(u'valueChanged(int)'), self.onFontFooterXSpinBoxChanged) QtCore.SIGNAL(u'editingFinished()'), self.onFontFooterXSpinBoxChanged)
QtCore.QObject.connect(self.FontFooterYSpinBox, QtCore.QObject.connect(self.FontFooterYSpinBox,
QtCore.SIGNAL(u'valueChanged(int)'), self.onFontFooterYSpinBoxChanged) QtCore.SIGNAL(u'editingFinished()'), self.onFontFooterYSpinBoxChanged)
QtCore.QObject.connect(self.FontFooterWidthSpinBox, QtCore.QObject.connect(self.FontFooterWidthSpinBox,
QtCore.SIGNAL(u'valueChanged(int)'), self.onFontFooterWidthSpinBoxChanged) QtCore.SIGNAL(u'editingFinished()'), self.onFontFooterWidthSpinBoxChanged)
QtCore.QObject.connect(self.FontFooterHeightSpinBox, QtCore.QObject.connect(self.FontFooterHeightSpinBox,
QtCore.SIGNAL(u'valueChanged(int)'), self.onFontFooterHeightSpinBoxChanged) QtCore.SIGNAL(u'editingFinished()'), self.onFontFooterHeightSpinBoxChanged)
QtCore.QObject.connect(self.OutlineCheckBox, QtCore.QObject.connect(self.OutlineCheckBox,
QtCore.SIGNAL(u'stateChanged(int)'), self.onOutlineCheckBoxChanged) QtCore.SIGNAL(u'stateChanged(int)'), self.onOutlineCheckBoxChanged)
QtCore.QObject.connect(self.ShadowCheckBox, QtCore.QObject.connect(self.ShadowCheckBox,
@ -167,8 +167,9 @@ class AmendThemeForm(QtGui.QDialog, Ui_AmendThemeDialog):
u'background-color: %s' % unicode(self.theme.font_main_color)) u'background-color: %s' % unicode(self.theme.font_main_color))
self.previewTheme(self.theme) self.previewTheme(self.theme)
def onFontMainSizeSpinBoxChanged(self, value): def onFontMainSizeSpinBoxChanged(self):
self.theme.font_main_proportion = value if self.theme.font_main_proportion != self.FontMainSizeSpinBox.value():
self.theme.font_main_proportion = self.FontMainSizeSpinBox.value()
self.previewTheme(self.theme) self.previewTheme(self.theme)
def onFontMainDefaultCheckBoxChanged(self, value): def onFontMainDefaultCheckBoxChanged(self, value):
@ -190,20 +191,24 @@ class AmendThemeForm(QtGui.QDialog, Ui_AmendThemeDialog):
self.stateChanging(self.theme) self.stateChanging(self.theme)
self.previewTheme(self.theme) self.previewTheme(self.theme)
def onFontMainXSpinBoxChanged(self, value): def onFontMainXSpinBoxChanged(self):
self.theme.font_main_x = value if self.theme.font_main_x != self.FontMainXSpinBox.value():
self.theme.font_main_x = self.FontMainXSpinBox.value()
self.previewTheme(self.theme) self.previewTheme(self.theme)
def onFontMainYSpinBoxChanged(self, value): def onFontMainYSpinBoxChanged(self):
self.theme.font_main_y = value if self.theme.font_main_y != self.FontMainYSpinBox.value():
self.theme.font_main_y = self.FontMainYSpinBox.value()
self.previewTheme(self.theme) self.previewTheme(self.theme)
def onFontMainWidthSpinBoxChanged(self, value): def onFontMainWidthSpinBoxChanged(self):
self.theme.font_main_width = value if self.theme.font_main_width != self.FontMainWidthSpinBox.value():
self.theme.font_main_width = self.FontMainWidthSpinBox.value()
self.previewTheme(self.theme) self.previewTheme(self.theme)
def onFontMainHeightSpinBoxChanged(self, value): def onFontMainHeightSpinBoxChanged(self):
self.theme.font_main_height = value if self.theme.font_main_height != self.FontMainHeightSpinBox.value():
self.theme.font_main_height = self.FontMainHeightSpinBox.value()
self.previewTheme(self.theme) self.previewTheme(self.theme)
# #
#Footer Font Tab #Footer Font Tab
@ -220,8 +225,9 @@ class AmendThemeForm(QtGui.QDialog, Ui_AmendThemeDialog):
'background-color: %s' % unicode(self.theme.font_footer_color)) 'background-color: %s' % unicode(self.theme.font_footer_color))
self.previewTheme(self.theme) self.previewTheme(self.theme)
def onFontFooterSizeSpinBoxChanged(self, value): def onFontFooterSizeSpinBoxChanged(self):
self.theme.font_footer_proportion = value if self.theme.font_footer_proportion != self.FontFooterSizeSpinBox.value():
self.theme.font_footer_proportion = self.FontFooterSizeSpinBox.value()
self.previewTheme(self.theme) self.previewTheme(self.theme)
def onFontFooterDefaultCheckBoxChanged(self, value): def onFontFooterDefaultCheckBoxChanged(self, value):
@ -245,22 +251,25 @@ class AmendThemeForm(QtGui.QDialog, Ui_AmendThemeDialog):
self.stateChanging(self.theme) self.stateChanging(self.theme)
self.previewTheme(self.theme) self.previewTheme(self.theme)
def onFontFooterXSpinBoxChanged(self, value): def onFontFooterXSpinBoxChanged(self):
self.theme.font_footer_x = value if self.theme.font_footer_x != self.FontFooterXSpinBox.value():
self.theme.font_footer_x = self.FontFooterXSpinBox.value()
self.previewTheme(self.theme) self.previewTheme(self.theme)
def onFontFooterYSpinBoxChanged(self, value): def onFontFooterYSpinBoxChanged(self):
self.theme.font_footer_y = value if self.theme.font_footer_y != self.FontFooterYSpinBox.value():
self.theme.font_footer_y = self.FontFooterYSpinBox.value()
self.previewTheme(self.theme) self.previewTheme(self.theme)
def onFontFooterWidthSpinBoxChanged(self, value): def onFontFooterWidthSpinBoxChanged(self):
self.theme.font_footer_width = value if self.theme.font_footer_width != self.FontFooterWidthSpinBox.value():
self.theme.font_footer_width = self.FontFooterWidthSpinBox.value()
self.previewTheme(self.theme) self.previewTheme(self.theme)
def onFontFooterHeightSpinBoxChanged(self, value): def onFontFooterHeightSpinBoxChanged(self):
self.theme.font_footer_height = value if self.theme.font_footer_height != self.FontFooterHeightSpinBox.value():
self.theme.font_footer_height = self.FontFooterHeightSpinBox.value()
self.previewTheme(self.theme) self.previewTheme(self.theme)
# #
#Background Tab #Background Tab
# #

View File

@ -154,6 +154,8 @@ class MigrateSongs():
author = Author() author = Author()
authors_temp = self.session.query(TAuthor).get(a) authors_temp = self.session.query(TAuthor).get(a)
author.display_name = authors_temp.authorname author.display_name = authors_temp.authorname
author.first_name = u''
author.last_name = u''
song.authors.append(author) song.authors.append(author)
try: try:
self.session.add(song) self.session.add(song)

View File

@ -97,6 +97,7 @@ class AuthorsForm(QtGui.QDialog, Ui_AuthorsDialog):
self.DeleteButton.setEnabled(False) self.DeleteButton.setEnabled(False)
self.author = None self.author = None
self._validate_form() self._validate_form()
self.DisplayEdit.setFocus()
def onAuthorListWidgetItemClicked(self, index): def onAuthorListWidgetItemClicked(self, index):
""" """
@ -108,7 +109,13 @@ class AuthorsForm(QtGui.QDialog, Ui_AuthorsDialog):
item_id = (item.data(QtCore.Qt.UserRole)).toInt()[0] item_id = (item.data(QtCore.Qt.UserRole)).toInt()[0]
self.author = self.songmanager.get_author(item_id) self.author = self.songmanager.get_author(item_id)
self.DisplayEdit.setText(self.author.display_name) self.DisplayEdit.setText(self.author.display_name)
if self.author.first_name is None:
self.FirstNameEdit.setText(u'')
else:
self.FirstNameEdit.setText(self.author.first_name) self.FirstNameEdit.setText(self.author.first_name)
if self.author.last_name is None:
self.LastNameEdit.setText(u'')
else:
self.LastNameEdit.setText(self.author.last_name) self.LastNameEdit.setText(self.author.last_name)
if len(self.author.songs) > 0: if len(self.author.songs) > 0:
self.MessageLabel.setText(translate(u'AuthorForm', u'Author in use "Delete" is disabled')) self.MessageLabel.setText(translate(u'AuthorForm', u'Author in use "Delete" is disabled'))
@ -117,6 +124,7 @@ class AuthorsForm(QtGui.QDialog, Ui_AuthorsDialog):
self.MessageLabel.setText(translate(u'AuthorForm', u'Author in not used')) self.MessageLabel.setText(translate(u'AuthorForm', u'Author in not used'))
self.DeleteButton.setEnabled(True) self.DeleteButton.setEnabled(True)
self._validate_form() self._validate_form()
self.DisplayEdit.setFocus()
def _validate_form(self): def _validate_form(self):
# We need at lease a display name # We need at lease a display name

View File

@ -96,6 +96,7 @@ class SongBookForm(QtGui.QDialog, Ui_SongBookDialog):
self.AddUpdateButton.setEnabled(True) self.AddUpdateButton.setEnabled(True)
self.Book = None self.Book = None
self._validate_form() self._validate_form()
self.NameEdit.setFocus()
def onBooksListViewItemClicked(self, index): def onBooksListViewItemClicked(self, index):
""" """
@ -115,6 +116,7 @@ class SongBookForm(QtGui.QDialog, Ui_SongBookDialog):
self.MessageLabel.setText(translate(u'BookForm', u'Book in not used')) self.MessageLabel.setText(translate(u'BookForm', u'Book in not used'))
self.DeleteButton.setEnabled(True) self.DeleteButton.setEnabled(True)
self._validate_form() self._validate_form()
self.NameEdit.setFocus()
def _validate_form(self): def _validate_form(self):
# We need at lease a display name # We need at lease a display name

View File

@ -95,6 +95,7 @@ class TopicsForm(QtGui.QDialog, Ui_TopicsDialog):
self.DeleteButton.setEnabled(False) self.DeleteButton.setEnabled(False)
self.topic = None self.topic = None
self._validate_form() self._validate_form()
self.TopicNameEdit.setFocus()
def onTopicsListWidgetItemClicked(self, index): def onTopicsListWidgetItemClicked(self, index):
""" """
@ -113,6 +114,7 @@ class TopicsForm(QtGui.QDialog, Ui_TopicsDialog):
self.MessageLabel.setText(translate(u'TopicForm', u'Topic in not used')) self.MessageLabel.setText(translate(u'TopicForm', u'Topic in not used'))
self.DeleteButton.setEnabled(True) self.DeleteButton.setEnabled(True)
self._validate_form() self._validate_form()
self.TopicNameEdit.setFocus()
def _validate_form(self): def _validate_form(self):
# We need at lease a display name # We need at lease a display name