we scroll to the end of the textview AFTER the scrollbar has appeared

This commit is contained in:
Yann Leboulanger 2005-04-09 20:13:55 +00:00
parent ef7f8909fc
commit 710d41e2dc
1 changed files with 8 additions and 4 deletions

View File

@ -327,8 +327,7 @@ class Chat:
gtk.SCROLL_PAGE_BACKWARD, False) gtk.SCROLL_PAGE_BACKWARD, False)
elif event.hardware_keycode == 23: # TAB elif event.hardware_keycode == 23: # TAB
if (event.state & gtk.gdk.CONTROL_MASK) and \ if (event.state & gtk.gdk.CONTROL_MASK) and \
(event.state & gtk.gdk.SHIFT_MASK): (event.state & gtk.gdk.SHIFT_MASK): # CTRL + SHIFT + TAB
# CTRL + SHIFT + TAB
current = self.notebook.get_current_page() current = self.notebook.get_current_page()
if current > 0: if current > 0:
self.notebook.set_current_page(current-1) self.notebook.set_current_page(current-1)
@ -572,6 +571,11 @@ class Chat:
self.print_with_tag_list(conversation_buffer, special_text, end_iter, \ self.print_with_tag_list(conversation_buffer, special_text, end_iter, \
all_tags) all_tags)
def scroll_to_end(self, textview):
buffer = textview.get_buffer()
textview.scroll_to_mark(buffer.get_mark('end'), 0.1, 0, 0, 0)
return False
def print_conversation_line(self, text, jid, kind, name, tim, \ def print_conversation_line(self, text, jid, kind, name, tim, \
other_tags_for_name = []): other_tags_for_name = []):
conversation_textview = self.xmls[jid].get_widget('conversation_textview') conversation_textview = self.xmls[jid].get_widget('conversation_textview')
@ -629,8 +633,8 @@ class Chat:
(kind == 'outgoing'): (kind == 'outgoing'):
#we are at the end or we are sending something #we are at the end or we are sending something
end = True end = True
conversation_textview.scroll_to_mark(conversation_buffer.\ # We scroll to the end after the scrollbar has appeared
get_mark('end'), 0.1, 0, 0, 0) gobject.timeout_add(100, self.scroll_to_end, conversation_textview)
if ((jid != self.get_active_jid()) or (not self.window.is_active()) or \ if ((jid != self.get_active_jid()) or (not self.window.is_active()) or \
(not end)) and kind == 'incoming': (not end)) and kind == 'incoming':
self.nb_unread[jid] += 1 self.nb_unread[jid] += 1