diff options
-rw-r--r-- | ChangeLog | 6 | ||||
-rw-r--r-- | ChangeLog.pre-2-10 | 6 | ||||
-rw-r--r-- | ChangeLog.pre-2-8 | 6 | ||||
-rw-r--r-- | gtk/gtktreeview.c | 13 |
4 files changed, 29 insertions, 2 deletions
@@ -1,5 +1,11 @@ 2005-06-19 Kristian Rietveld <kris@gtk.org> + * gtk/gtktreeview.c (gtk_tree_view_clamp_node_visible): added a + check which avoids processing updates on bin_window and scrolling + if the node is already visible. (#170600, Billy Biggs). + +2005-06-19 Kristian Rietveld <kris@gtk.org> + * gtk/gtktreeview.c (validate_visible_area): only keep the row at the same position if the full row is visible. (#304623, Jorn Baayen). diff --git a/ChangeLog.pre-2-10 b/ChangeLog.pre-2-10 index 7da0dce54e..4a7ef36973 100644 --- a/ChangeLog.pre-2-10 +++ b/ChangeLog.pre-2-10 @@ -1,5 +1,11 @@ 2005-06-19 Kristian Rietveld <kris@gtk.org> + * gtk/gtktreeview.c (gtk_tree_view_clamp_node_visible): added a + check which avoids processing updates on bin_window and scrolling + if the node is already visible. (#170600, Billy Biggs). + +2005-06-19 Kristian Rietveld <kris@gtk.org> + * gtk/gtktreeview.c (validate_visible_area): only keep the row at the same position if the full row is visible. (#304623, Jorn Baayen). diff --git a/ChangeLog.pre-2-8 b/ChangeLog.pre-2-8 index 7da0dce54e..4a7ef36973 100644 --- a/ChangeLog.pre-2-8 +++ b/ChangeLog.pre-2-8 @@ -1,5 +1,11 @@ 2005-06-19 Kristian Rietveld <kris@gtk.org> + * gtk/gtktreeview.c (gtk_tree_view_clamp_node_visible): added a + check which avoids processing updates on bin_window and scrolling + if the node is already visible. (#170600, Billy Biggs). + +2005-06-19 Kristian Rietveld <kris@gtk.org> + * gtk/gtktreeview.c (validate_visible_area): only keep the row at the same position if the full row is visible. (#304623, Jorn Baayen). diff --git a/gtk/gtktreeview.c b/gtk/gtktreeview.c index 28e1218913..e3bf7069e3 100644 --- a/gtk/gtktreeview.c +++ b/gtk/gtktreeview.c @@ -4561,7 +4561,7 @@ validate_row (GtkTreeView *tree_view, gboolean retval = FALSE; gboolean is_separator = FALSE; gint focus_pad; - + /* double check the row needs validating */ if (! GTK_RBNODE_FLAG_SET (node, GTK_RBNODE_INVALID) && ! GTK_RBNODE_FLAG_SET (node, GTK_RBNODE_COLUMN_INVALID)) @@ -7828,13 +7828,22 @@ gtk_tree_view_clamp_node_visible (GtkTreeView *tree_view, GtkRBTree *tree, GtkRBNode *node) { + gint node_dy, height; GtkTreePath *path = NULL; if (!GTK_WIDGET_REALIZED (tree_view)) return; - path = _gtk_tree_view_find_path (tree_view, tree, node); + /* just return if the node is visible, avoiding a costly expose */ + node_dy = _gtk_rbtree_node_find_offset (tree, node); + height = ROW_HEIGHT (tree_view, GTK_RBNODE_GET_HEIGHT (node)); + if (! GTK_RBNODE_FLAG_SET (node, GTK_RBNODE_INVALID) + && node_dy >= tree_view->priv->vadjustment->value + && node_dy + height <= (tree_view->priv->vadjustment->value + + tree_view->priv->vadjustment->page_size)) + return; + path = _gtk_tree_view_find_path (tree_view, tree, node); if (path) { /* We process updates because we want to clear old selected items when we scroll. |