diff options
author | Owen Taylor <otaylor@redhat.com> | 1999-01-28 00:57:18 +0000 |
---|---|---|
committer | Owen Taylor <otaylor@src.gnome.org> | 1999-01-28 00:57:18 +0000 |
commit | 9e5e63f0a147d0089e27c6b6af2bde70db77430c (patch) | |
tree | 8e65adde429ea8336c26a4b0cfe556fc193e9b40 /gtk/gtkmain.c | |
parent | 7934cf9aeaac0850523edecc69a6e3427df64095 (diff) | |
download | gdk-pixbuf-9e5e63f0a147d0089e27c6b6af2bde70db77430c.tar.gz |
Hack scrollwheel support into the eventloop, by treating button 4-5
Wed Jan 27 18:40:50 1999 Owen Taylor <otaylor@redhat.com>
* gtk/gtkmain.c (gtk_main_do_event): Hack scrollwheel
support into the eventloop, by treating button 4-5
presses on scrolled windows and scrollbars specially.
Put it here to keep the ugliness small and confined.
(We need to intercept the normal propagation in any case
to have this work reliably right now, since some
subwidgets will trap the button presses)
* gtk/gtkviewport.c (gtk_viewport_realize): Select for
BUTTON_PRESS to support the above hack.
Diffstat (limited to 'gtk/gtkmain.c')
-rw-r--r-- | gtk/gtkmain.c | 50 |
1 files changed, 45 insertions, 5 deletions
diff --git a/gtk/gtkmain.c b/gtk/gtkmain.c index f573c9db1..62f337fa6 100644 --- a/gtk/gtkmain.c +++ b/gtk/gtkmain.c @@ -29,6 +29,7 @@ #include "gtkmain.h" #include "gtkpreview.h" #include "gtkrc.h" +#include "gtkscrolledwindow.h" #include "gtkselection.h" #include "gtksignal.h" #include "gtktable.h" @@ -629,7 +630,7 @@ gtk_main_do_event (GdkEvent *event) { grab_widget = event_widget; } - + /* Not all events get sent to the grabbing widget. * The delete, destroy, expose, focus change and resize * events still get sent to the event widget because @@ -675,7 +676,49 @@ gtk_main_do_event (GdkEvent *event) case GDK_VISIBILITY_NOTIFY: gtk_widget_event (event_widget, event); break; - + + case GDK_BUTTON_PRESS: + case GDK_2BUTTON_PRESS: + case GDK_3BUTTON_PRESS: + /* We treat button 4-5 specially, assume we have + * a MS-style scrollwheel mouse, and try to find + * a plausible widget to scroll. We also trap + * button 4-5 double and triple clicks here, since + * they will be generated if the user scrolls quickly. + */ + if ((grab_widget == event_widget) && + (event->button.button == 4 || event->button.button == 5)) + { + GtkWidget *range = NULL; + GtkWidget *scrollwin; + + if (GTK_IS_RANGE (event_widget)) + range = event_widget; + else + { + scrollwin = gtk_widget_get_ancestor (event_widget, + GTK_TYPE_SCROLLED_WINDOW); + if (scrollwin) + range = GTK_SCROLLED_WINDOW (scrollwin)->vscrollbar; + } + + if (range && GTK_WIDGET_VISIBLE (range)) + { + if (event->type == GDK_BUTTON_PRESS) + { + GtkAdjustment *adj = GTK_RANGE (range)->adjustment; + gfloat new_value = adj->value + ((event->button.button == 4) ? + -adj->page_increment / 2: + adj->page_increment / 2); + new_value = CLAMP (new_value, adj->lower, adj->upper - adj->page_size); + gtk_adjustment_set_value (adj, new_value); + } + break; + } + } + gtk_propagate_event (grab_widget, event); + break; + case GDK_KEY_PRESS: case GDK_KEY_RELEASE: if (key_snoopers) @@ -685,9 +728,6 @@ gtk_main_do_event (GdkEvent *event) } /* else fall through */ case GDK_MOTION_NOTIFY: - case GDK_BUTTON_PRESS: - case GDK_2BUTTON_PRESS: - case GDK_3BUTTON_PRESS: case GDK_BUTTON_RELEASE: case GDK_PROXIMITY_IN: case GDK_PROXIMITY_OUT: |