summaryrefslogtreecommitdiff
path: root/gtk/gtkprivate.h
diff options
context:
space:
mode:
authorCarlos Garcia Campos <cgarcia@igalia.com>2011-02-08 14:49:31 +0100
committerMatthias Clasen <mclasen@redhat.com>2012-03-01 16:25:21 -0500
commit9f4bfff1b030fffa0d815557ec690d208cb4cd67 (patch)
treedcab443bc3a3a73a1cc0c57bbdbac870df310ab7 /gtk/gtkprivate.h
parent6c257040a54eb91cc9323c8441b6025667dace69 (diff)
downloadgtk+-9f4bfff1b030fffa0d815557ec690d208cb4cd67.tar.gz
gtk: Add a way to do event capture
This patch adds a capture phase to GTK+'s event propagation model. Events are first propagated from the toplevel (or the grab widget, if a grab is in place) down to the target widget and then back up. The second phase is using the existing ::event signal, the new capture phase is using a private API instead of a public signal for now. This mechanism can be used in many places where we currently have to prevent child widgets from getting events by putting an input-only window over them. It will also be used to implement kinetic scrolling in subsequent patches. http://bugzilla.gnome.org/show_bug.cgi?id=641836 We automatically request more motion events in behalf of the original widget if it listens to motion hints. So the capturing widget doesn't need to handle such implementation details. We are not making event capture part of the public API for 3.4, which is why there is no ::captured-event signal.
Diffstat (limited to 'gtk/gtkprivate.h')
-rw-r--r--gtk/gtkprivate.h4
1 files changed, 4 insertions, 0 deletions
diff --git a/gtk/gtkprivate.h b/gtk/gtkprivate.h
index 63860a21a0..9114bd08b2 100644
--- a/gtk/gtkprivate.h
+++ b/gtk/gtkprivate.h
@@ -72,6 +72,10 @@ gboolean _gtk_translate_keyboard_accel_state (GdkKeymap *keymap,
gint *level,
GdkModifierType *consumed_modifiers);
+gboolean _gtk_propagate_captured_event (GtkWidget *widget,
+ GdkEvent *event,
+ GtkWidget *topmost);
+
G_END_DECLS
#endif /* __GTK_PRIVATE_H__ */