mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2025-01-13 22:10:08 +00:00
Expose improvements for GtkNotebook. Bug #383435
2006-12-26 Carlos Garnacho <carlosg@gnome.org> Expose improvements for GtkNotebook. Bug #383435 * gtk/gtknotebook.c (gtk_notebook_expose): propagate the event to tab labels. (gtk_notebook_draw_focus): do not repaint the whole focused tab again. (gtk_notebook_draw_tab): do not send handmade expose events to tab labels.
This commit is contained in:
parent
efcf8f6b63
commit
c1077874a0
10
ChangeLog
10
ChangeLog
@ -1,3 +1,13 @@
|
||||
2006-12-26 Carlos Garnacho <carlosg@gnome.org>
|
||||
|
||||
Expose improvements for GtkNotebook. Bug #383435
|
||||
|
||||
* gtk/gtknotebook.c (gtk_notebook_expose): propagate the event to tab
|
||||
labels.
|
||||
(gtk_notebook_draw_focus): do not repaint the whole focused tab again.
|
||||
(gtk_notebook_draw_tab): do not send handmade expose events to tab
|
||||
labels.
|
||||
|
||||
2006-12-26 Matthias Clasen <mclasen@redhat.com>
|
||||
|
||||
* gtk/gtkfilesystemunix.c (execute_callbacks): Return
|
||||
|
@ -255,7 +255,8 @@ static void gtk_notebook_grab_notify (GtkWidget *widget,
|
||||
gboolean was_grabbed);
|
||||
static void gtk_notebook_state_changed (GtkWidget *widget,
|
||||
GtkStateType previous_state);
|
||||
static void gtk_notebook_draw_focus (GtkWidget *widget);
|
||||
static void gtk_notebook_draw_focus (GtkWidget *widget,
|
||||
GdkEventExpose *event);
|
||||
static gint gtk_notebook_focus (GtkWidget *widget,
|
||||
GtkDirectionType direction);
|
||||
static void gtk_notebook_style_set (GtkWidget *widget,
|
||||
@ -2004,7 +2005,6 @@ gtk_notebook_expose (GtkWidget *widget,
|
||||
{
|
||||
GtkNotebook *notebook;
|
||||
GtkNotebookPrivate *priv;
|
||||
GdkRectangle child_area;
|
||||
|
||||
g_return_val_if_fail (GTK_IS_NOTEBOOK (widget), FALSE);
|
||||
g_return_val_if_fail (event != NULL, FALSE);
|
||||
@ -2021,18 +2021,32 @@ gtk_notebook_expose (GtkWidget *widget,
|
||||
gtk_notebook_draw_tab (notebook,
|
||||
notebook->cur_page,
|
||||
&area);
|
||||
gtk_notebook_draw_focus (widget, event);
|
||||
gtk_container_propagate_expose (GTK_CONTAINER (notebook),
|
||||
notebook->cur_page->tab_label, event);
|
||||
}
|
||||
else if (GTK_WIDGET_DRAWABLE (widget))
|
||||
{
|
||||
gtk_notebook_paint (widget, &event->area);
|
||||
if (notebook->show_tabs)
|
||||
{
|
||||
if (notebook->cur_page &&
|
||||
gtk_widget_intersect (notebook->cur_page->tab_label,
|
||||
&event->area, &child_area))
|
||||
gtk_notebook_draw_focus (widget);
|
||||
}
|
||||
GtkNotebookPage *page;
|
||||
GList *pages;
|
||||
|
||||
gtk_notebook_draw_focus (widget, event);
|
||||
pages = notebook->children;
|
||||
|
||||
while (pages)
|
||||
{
|
||||
page = GTK_NOTEBOOK_PAGE (pages);
|
||||
pages = pages->next;
|
||||
|
||||
if (page->tab_label->window == event->window &&
|
||||
GTK_WIDGET_DRAWABLE (page->tab_label))
|
||||
gtk_container_propagate_expose (GTK_CONTAINER (notebook),
|
||||
page->tab_label, event);
|
||||
}
|
||||
}
|
||||
|
||||
if (notebook->cur_page)
|
||||
gtk_container_propagate_expose (GTK_CONTAINER (notebook),
|
||||
@ -2949,12 +2963,14 @@ gtk_notebook_focus_out (GtkWidget *widget,
|
||||
}
|
||||
|
||||
static void
|
||||
gtk_notebook_draw_focus (GtkWidget *widget)
|
||||
gtk_notebook_draw_focus (GtkWidget *widget,
|
||||
GdkEventExpose *event)
|
||||
{
|
||||
GtkNotebook *notebook = GTK_NOTEBOOK (widget);
|
||||
|
||||
if (GTK_WIDGET_DRAWABLE (widget) && notebook->show_tabs &&
|
||||
notebook->focus_tab)
|
||||
if (GTK_WIDGET_HAS_FOCUS (widget) && GTK_WIDGET_DRAWABLE (widget) &&
|
||||
notebook->cur_page->tab_label->window == event->window &&
|
||||
notebook->show_tabs && notebook->cur_page)
|
||||
{
|
||||
GtkNotebookPage *page;
|
||||
GdkRectangle area;
|
||||
@ -2962,14 +2978,17 @@ gtk_notebook_draw_focus (GtkWidget *widget)
|
||||
|
||||
gtk_widget_style_get (widget, "focus-line-width", &focus_width, NULL);
|
||||
|
||||
page = notebook->focus_tab->data;
|
||||
page = notebook->cur_page;
|
||||
|
||||
area.x = page->tab_label->allocation.x - focus_width;
|
||||
area.y = page->tab_label->allocation.y - focus_width;
|
||||
area.width = page->tab_label->allocation.width + 2 * focus_width;
|
||||
area.height = page->tab_label->allocation.height + 2 * focus_width;
|
||||
|
||||
gtk_notebook_draw_tab (GTK_NOTEBOOK (widget), page, &area);
|
||||
if (gtk_widget_intersect (page->tab_label, &event->area, NULL))
|
||||
gtk_paint_focus (widget->style, event->window, GTK_WIDGET_STATE (widget),
|
||||
NULL, widget, "tab",
|
||||
area.x, area.y, area.width, area.height);
|
||||
}
|
||||
}
|
||||
|
||||
@ -4557,37 +4576,6 @@ gtk_notebook_draw_tab (GtkNotebook *notebook,
|
||||
page_area.x, page_area.y,
|
||||
page_area.width, page_area.height,
|
||||
gap_side);
|
||||
|
||||
if ((GTK_WIDGET_HAS_FOCUS (widget)) &&
|
||||
notebook->focus_tab && (notebook->focus_tab->data == page))
|
||||
{
|
||||
gint focus_width;
|
||||
|
||||
gtk_widget_style_get (widget, "focus-line-width", &focus_width, NULL);
|
||||
|
||||
gtk_paint_focus (widget->style, window, GTK_WIDGET_STATE (widget),
|
||||
area, widget, "tab",
|
||||
page->tab_label->allocation.x - focus_width,
|
||||
page->tab_label->allocation.y - focus_width,
|
||||
page->tab_label->allocation.width + 2 * focus_width,
|
||||
page->tab_label->allocation.height + 2 * focus_width);
|
||||
}
|
||||
|
||||
if (gtk_widget_intersect (page->tab_label, area, &child_area) &&
|
||||
GTK_WIDGET_DRAWABLE (page->tab_label))
|
||||
{
|
||||
GdkEvent *expose_event = gdk_event_new (GDK_EXPOSE);
|
||||
|
||||
/* This is a lame hack since all this code needs rewriting anyhow */
|
||||
expose_event->expose.window = g_object_ref (page->tab_label->window);
|
||||
expose_event->expose.area = child_area;
|
||||
expose_event->expose.region = gdk_region_rectangle (&child_area);
|
||||
expose_event->expose.send_event = TRUE;
|
||||
expose_event->expose.count = 0;
|
||||
|
||||
gtk_widget_send_expose (page->tab_label, expose_event);
|
||||
gdk_event_free (expose_event);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user