+Mon Dec 14 02:13:01 1998 Tim Janik <timj@gtk.org>
+
+ * gtk/gtkmenuitem.c: fixed submenu popup timeouts, we decide whether or
+ not to delay the submenu popup from a menu item deselection time stamp.
+ the code looks even more hackish than before, but in practice "feels"
+ very well.
+
1998-12-13 Federico Mena Quintero <federico@nuclecu.unam.mx>
* gtk/gtkwidget.h (struct _GtkWidgetClass): Added a "grab_focus"
+Mon Dec 14 02:13:01 1998 Tim Janik <timj@gtk.org>
+
+ * gtk/gtkmenuitem.c: fixed submenu popup timeouts, we decide whether or
+ not to delay the submenu popup from a menu item deselection time stamp.
+ the code looks even more hackish than before, but in practice "feels"
+ very well.
+
1998-12-13 Federico Mena Quintero <federico@nuclecu.unam.mx>
* gtk/gtkwidget.h (struct _GtkWidgetClass): Added a "grab_focus"
+Mon Dec 14 02:13:01 1998 Tim Janik <timj@gtk.org>
+
+ * gtk/gtkmenuitem.c: fixed submenu popup timeouts, we decide whether or
+ not to delay the submenu popup from a menu item deselection time stamp.
+ the code looks even more hackish than before, but in practice "feels"
+ very well.
+
1998-12-13 Federico Mena Quintero <federico@nuclecu.unam.mx>
* gtk/gtkwidget.h (struct _GtkWidgetClass): Added a "grab_focus"
+Mon Dec 14 02:13:01 1998 Tim Janik <timj@gtk.org>
+
+ * gtk/gtkmenuitem.c: fixed submenu popup timeouts, we decide whether or
+ not to delay the submenu popup from a menu item deselection time stamp.
+ the code looks even more hackish than before, but in practice "feels"
+ very well.
+
1998-12-13 Federico Mena Quintero <federico@nuclecu.unam.mx>
* gtk/gtkwidget.h (struct _GtkWidgetClass): Added a "grab_focus"
+Mon Dec 14 02:13:01 1998 Tim Janik <timj@gtk.org>
+
+ * gtk/gtkmenuitem.c: fixed submenu popup timeouts, we decide whether or
+ not to delay the submenu popup from a menu item deselection time stamp.
+ the code looks even more hackish than before, but in practice "feels"
+ very well.
+
1998-12-13 Federico Mena Quintero <federico@nuclecu.unam.mx>
* gtk/gtkwidget.h (struct _GtkWidgetClass): Added a "grab_focus"
+Mon Dec 14 02:13:01 1998 Tim Janik <timj@gtk.org>
+
+ * gtk/gtkmenuitem.c: fixed submenu popup timeouts, we decide whether or
+ not to delay the submenu popup from a menu item deselection time stamp.
+ the code looks even more hackish than before, but in practice "feels"
+ very well.
+
1998-12-13 Federico Mena Quintero <federico@nuclecu.unam.mx>
* gtk/gtkwidget.h (struct _GtkWidgetClass): Added a "grab_focus"
+Mon Dec 14 02:13:01 1998 Tim Janik <timj@gtk.org>
+
+ * gtk/gtkmenuitem.c: fixed submenu popup timeouts, we decide whether or
+ not to delay the submenu popup from a menu item deselection time stamp.
+ the code looks even more hackish than before, but in practice "feels"
+ very well.
+
1998-12-13 Federico Mena Quintero <federico@nuclecu.unam.mx>
* gtk/gtkwidget.h (struct _GtkWidgetClass): Added a "grab_focus"
#define BORDER_SPACING 3
-#define SELECT_TIMEOUT 20
+#define SELECT_TIMEOUT 75
#define MENU_ITEM_CLASS(w) GTK_MENU_ITEM_CLASS (GTK_OBJECT (w)->klass)
static GtkItemClass *parent_class;
static guint menu_item_signals[LAST_SIGNAL] = { 0 };
+static guint32 last_submenu_deselect_time = 0;
+
GtkType
/* if (menu_item->submenu && !GTK_WIDGET_VISIBLE (menu_item->submenu))*/
if (menu_item->submenu)
{
- /* Boy this is a hack! */
- GdkEvent *current_event = gtk_get_current_event();
- if (current_event && (current_event->type != GDK_ENTER_NOTIFY))
- gtk_menu_item_select_timeout (menu_item);
+ guint32 etime;
+ GdkEvent *event = gtk_get_current_event ();
+
+ etime = event ? gdk_event_get_time (event) : GDK_CURRENT_TIME;
+ if (etime >= last_submenu_deselect_time &&
+ last_submenu_deselect_time + SELECT_TIMEOUT > etime)
+ menu_item->timer = gtk_timeout_add (SELECT_TIMEOUT - (etime - last_submenu_deselect_time),
+ gtk_menu_item_select_timeout,
+ menu_item);
else
- menu_item->timer = gtk_timeout_add (SELECT_TIMEOUT, gtk_menu_item_select_timeout, menu_item);
+ gtk_menu_item_select_timeout (menu_item);
}
-
+
gtk_widget_set_state (GTK_WIDGET (menu_item), GTK_STATE_PRELIGHT);
gtk_widget_draw (GTK_WIDGET (menu_item), NULL);
}
if (menu_item->submenu)
{
+ guint32 etime;
+ GdkEvent *event = gtk_get_current_event ();
+
if (menu_item->timer)
- gtk_timeout_remove (menu_item->timer);
+ {
+ gtk_timeout_remove (menu_item->timer);
+ menu_item->timer = 0;
+ }
else
gtk_menu_popdown (GTK_MENU (menu_item->submenu));
+
+ etime = event ? gdk_event_get_time (event) : GDK_CURRENT_TIME;
+ if (etime > last_submenu_deselect_time)
+ last_submenu_deselect_time = etime;
}
gtk_widget_set_state (GTK_WIDGET (menu_item), GTK_STATE_NORMAL);