diff options
Diffstat (limited to 'gtk/gtktooltips.c')
-rw-r--r-- | gtk/gtktooltips.c | 208 |
1 files changed, 80 insertions, 128 deletions
diff --git a/gtk/gtktooltips.c b/gtk/gtktooltips.c index 00e39234f5..ca1b40402b 100644 --- a/gtk/gtktooltips.c +++ b/gtk/gtktooltips.c @@ -41,7 +41,6 @@ static void gtk_tooltips_widget_remove (GtkWidget *widget, gpointer data); static void gtk_tooltips_set_active_widget (GtkTooltips *tooltips, GtkWidget *widget); -static gint gtk_tooltips_widget_visible (GtkWidget *widget); static gint gtk_tooltips_timeout (gpointer data); static void gtk_tooltips_create_window (GtkTooltips *tooltips); static void gtk_tooltips_draw_tips (GtkTooltips *tooltips); @@ -87,13 +86,16 @@ gtk_tooltips_class_init (GtkTooltipsClass *class) static void gtk_tooltips_init (GtkTooltips *tooltips) { - tooltips->enabled = TRUE; - tooltips->delay = DEFAULT_DELAY; - tooltips->widget_list = NULL; + tooltips->tip_window = NULL; + tooltips->active_tips_data = NULL; + tooltips->tips_data_list = NULL; tooltips->gc = NULL; tooltips->foreground = NULL; tooltips->background = NULL; - tooltips->tip_window = NULL; + + tooltips->delay = DEFAULT_DELAY; + tooltips->enabled = TRUE; + tooltips->timer_tag = 0; } GtkTooltips * @@ -133,15 +135,15 @@ gtk_tooltips_destroy (GtkObject *object) g_return_if_fail (tooltips != NULL); - if (tooltips->timer_active == TRUE) + if (tooltips->timer_tag) { - tooltips->timer_active = FALSE; gtk_timeout_remove (tooltips->timer_tag); + tooltips->timer_tag = 0; } - if (tooltips->widget_list != NULL) + if (tooltips->tips_data_list != NULL) { - current = g_list_first (tooltips->widget_list); + current = g_list_first (tooltips->tips_data_list); while (current != NULL) { tooltipsdata = (GtkTooltipsData*) current->data; @@ -281,25 +283,14 @@ gtk_tooltips_disable (GtkTooltips *tooltips) { g_return_if_fail (tooltips != NULL); - tooltips->enabled = FALSE; - - if (tooltips->timer_active == TRUE) - { - gtk_timeout_remove (tooltips->timer_tag); - tooltips->timer_active = FALSE; - } + gtk_tooltips_set_active_widget (tooltips, NULL); - if (tooltips->active_widget != NULL) - { - if (tooltips->tip_window != NULL) - gtk_widget_hide (tooltips->tip_window); - tooltips->active_widget = NULL; - } + tooltips->enabled = FALSE; } void gtk_tooltips_set_delay (GtkTooltips *tooltips, - gint delay) + guint delay) { g_return_if_fail (tooltips != NULL); @@ -345,7 +336,7 @@ gtk_tooltips_set_tip (GtkTooltips *tooltips, tooltipsdata->tip_private = g_strdup (tip_private); gtk_tooltips_layout_text (tooltips, tooltipsdata); - tooltips->widget_list = g_list_append (tooltips->widget_list, + tooltips->tips_data_list = g_list_append (tooltips->tips_data_list, tooltipsdata); gtk_signal_connect_after(GTK_OBJECT (widget), "event", (GtkSignalFunc) gtk_tooltips_event_handler, @@ -390,21 +381,19 @@ gtk_tooltips_draw_tips (GtkTooltips * tooltips) GtkTooltipsData *data; GList *el; - if (tooltips->tip_window == NULL) - { - gtk_tooltips_create_window (tooltips); - } - else + if (!tooltips->tip_window) + gtk_tooltips_create_window (tooltips); + else if (GTK_WIDGET_VISIBLE (tooltips->tip_window)) gtk_widget_hide (tooltips->tip_window); style = tooltips->tip_window->style; - widget = tooltips->active_widget->widget; + widget = tooltips->active_tips_data->widget; scr_w = gdk_screen_width (); scr_h = gdk_screen_height (); - data = tooltips->active_widget; + data = tooltips->active_tips_data; if (data->font != style->font) gtk_tooltips_layout_text (tooltips, data); @@ -489,52 +478,44 @@ gtk_tooltips_timeout (gpointer data) { GtkTooltips *tooltips = (GtkTooltips *) data; - if (tooltips->active_widget != NULL && - GTK_WIDGET_DRAWABLE (tooltips->active_widget->widget)) + if (tooltips->active_tips_data != NULL && + GTK_WIDGET_DRAWABLE (tooltips->active_tips_data->widget)) gtk_tooltips_draw_tips (tooltips); return FALSE; } -static gint -gtk_tooltips_widget_visible (GtkWidget *widget) -{ - GtkWidget *current; - - current = widget; - - while (current != NULL) - { - if (!GTK_WIDGET_MAPPED (current) || !GTK_WIDGET_REALIZED (current)) - return FALSE; - current = current->parent; - } - - return TRUE; -} - static void gtk_tooltips_set_active_widget (GtkTooltips *tooltips, GtkWidget *widget) { - GtkTooltipsData *tooltipsdata; - GList *current; - - current = g_list_first (tooltips->widget_list); - tooltips->active_widget = NULL; - - while (current != NULL) + if (tooltips->tip_window) + gtk_widget_hide (tooltips->tip_window); + if (tooltips->timer_tag) { - tooltipsdata = (GtkTooltipsData*) current->data; - - if (widget == tooltipsdata->widget && - gtk_tooltips_widget_visible (tooltipsdata->widget) == TRUE) + gtk_timeout_remove (tooltips->timer_tag); + tooltips->timer_tag = 0; + } + + tooltips->active_tips_data = NULL; + + if (widget) + { + GList *list; + + for (list = tooltips->tips_data_list; list; list = list->next) { - tooltips->active_widget = tooltipsdata; - return; + GtkTooltipsData *tooltipsdata; + + tooltipsdata = list->data; + + if (tooltipsdata->widget == widget && + GTK_WIDGET_DRAWABLE (widget)) + { + tooltips->active_tips_data = tooltipsdata; + break; + } } - - current = current->next; } } @@ -543,70 +524,45 @@ gtk_tooltips_event_handler (GtkWidget *widget, GdkEvent *event) { GtkTooltips *tooltips; - GtkTooltipsData *old_widget; + GtkTooltipsData *old_tips_data; GtkWidget *event_widget; - gint returnval = FALSE; - - old_widget = gtk_tooltips_data_get (widget); - tooltips = old_widget->tooltips; - event_widget = gtk_get_event_widget (event); - - if (tooltips->enabled == FALSE || - event_widget != widget) - return returnval; if ((event->type == GDK_LEAVE_NOTIFY || event->type == GDK_ENTER_NOTIFY) && event->crossing.detail == GDK_NOTIFY_INFERIOR) - return returnval; + return FALSE; + + event_widget = gtk_get_event_widget (event); + if (event_widget != widget) + return FALSE; + + old_tips_data = gtk_tooltips_data_get (widget); + tooltips = old_tips_data->tooltips; - if (event->type == GDK_LEAVE_NOTIFY) + switch (event->type) { - if (tooltips->timer_active == TRUE) + case GDK_MOTION_NOTIFY: + /* do nothing */ + break; + + case GDK_ENTER_NOTIFY: + old_tips_data = tooltips->active_tips_data; + if (tooltips->enabled && + (!old_tips_data || old_tips_data->widget != widget)) { - gtk_timeout_remove (tooltips->timer_tag); - tooltips->timer_active = FALSE; + gtk_tooltips_set_active_widget (tooltips, widget); + + tooltips->timer_tag = gtk_timeout_add (tooltips->delay, + gtk_tooltips_timeout, + (gpointer) tooltips); } - if (tooltips->tip_window != NULL) - gtk_widget_hide (tooltips->tip_window); - tooltips->active_widget = NULL; - } - else if (event->type == GDK_MOTION_NOTIFY || event->type == GDK_ENTER_NOTIFY) - { - old_widget = tooltips->active_widget; + break; - gtk_tooltips_set_active_widget (tooltips, widget); - - if (old_widget != tooltips->active_widget) - { - if (tooltips->timer_active == TRUE) - { - gtk_timeout_remove (tooltips->timer_tag); - tooltips->timer_active = FALSE; - } - if (tooltips->active_widget != NULL) - { - if (tooltips->tip_window != NULL) - gtk_widget_hide (tooltips->tip_window); - - tooltips->timer_tag = gtk_timeout_add (tooltips->delay, - gtk_tooltips_timeout, (gpointer) tooltips); - - tooltips->timer_active = TRUE; - } - } - else if (tooltips->active_widget == NULL) - { - if (tooltips->tip_window != NULL) - gtk_widget_hide (tooltips->tip_window); - } - } - else - { - if (tooltips->tip_window != NULL) - gtk_widget_hide (tooltips->tip_window); + default: + gtk_tooltips_set_active_widget (tooltips, NULL); + break; } - return returnval; + return FALSE; } static void @@ -615,14 +571,10 @@ gtk_tooltips_widget_unmap (GtkWidget *widget, { GtkTooltipsData *tooltipsdata = (GtkTooltipsData *)data; GtkTooltips *tooltips = tooltipsdata->tooltips; - - if (tooltips->active_widget && - (tooltips->active_widget->widget == widget)) - { - if (tooltips->tip_window != NULL) - gtk_widget_hide (tooltips->tip_window); - tooltips->active_widget = NULL; - } + + if (tooltips->active_tips_data && + (tooltips->active_tips_data->widget == widget)) + gtk_tooltips_set_active_widget (tooltips, NULL); } static void @@ -633,7 +585,7 @@ gtk_tooltips_widget_remove (GtkWidget *widget, GtkTooltips *tooltips = tooltipsdata->tooltips; gtk_tooltips_widget_unmap (widget, data); - tooltips->widget_list = g_list_remove (tooltips->widget_list, - tooltipsdata); + tooltips->tips_data_list = g_list_remove (tooltips->tips_data_list, + tooltipsdata); gtk_tooltips_destroy_data (tooltipsdata); } |