[gtk+/multitouch: 25/27] gtk, scrolledwindow: Let GDK_SOURCE_MULTITOUCH devices do kinetic scrolling



commit 60c0c71e5328a10ae97a35a66fa36a9c935c61d1
Author: Carlos Garnacho <carlosg gnome org>
Date:   Wed Nov 23 21:06:39 2011 +0100

    gtk,scrolledwindow: Let GDK_SOURCE_MULTITOUCH devices do kinetic scrolling

 gtk/gtkscrolledwindow.c |   12 +++++++++---
 1 files changed, 9 insertions(+), 3 deletions(-)
---
diff --git a/gtk/gtkscrolledwindow.c b/gtk/gtkscrolledwindow.c
index 5f6e096..65a795e 100644
--- a/gtk/gtkscrolledwindow.c
+++ b/gtk/gtkscrolledwindow.c
@@ -482,8 +482,9 @@ gtk_scrolled_window_class_init (GtkScrolledWindowClass *class)
    *
    * The kinetic scrolling behavior flags. Kinetic scrolling
    * only applies to devices with source %GDK_SOURCE_TOUCH
+   * or %GDK_SOURCE_MULTITOUCH.
    *
-   * Since: 3.4
+   * Since: 3.2
    */
   g_object_class_install_property (gobject_class,
                                    PROP_KINETIC_SCROLLING,
@@ -2601,13 +2602,15 @@ gtk_scrolled_window_captured_button_press (GtkWidget *widget,
   GdkInputSource source;
   guint timeout;
 
-  if (_event->type != GDK_BUTTON_PRESS)
+  if (_event->type != GDK_BUTTON_PRESS &&
+      _event->type != GDK_TOUCH_PRESS)
     return GTK_CAPTURED_EVENT_NONE;
 
   source_device = gdk_event_get_source_device (_event);
   source = gdk_device_get_source (source_device);
 
-  if (source != GDK_SOURCE_TOUCH)
+  if (source != GDK_SOURCE_TOUCH &&
+      source != GDK_SOURCE_MULTITOUCH)
     return GTK_CAPTURED_EVENT_NONE;
 
   event = (GdkEventButton *)_event;
@@ -2701,9 +2704,11 @@ gtk_scrolled_window_captured_event (GtkWidget *widget,
   switch (event->type)
     {
     case GDK_BUTTON_PRESS:
+    case GDK_TOUCH_PRESS:
       flags = gtk_scrolled_window_captured_button_press (widget, event);
       break;
     case GDK_BUTTON_RELEASE:
+    case GDK_TOUCH_RELEASE:
       if (priv->drag_device)
         flags = gtk_scrolled_window_captured_button_release (widget, event);
       else
@@ -2713,6 +2718,7 @@ gtk_scrolled_window_captured_event (GtkWidget *widget,
         }
       break;
     case GDK_MOTION_NOTIFY:
+    case GDK_TOUCH_MOTION:
       if (priv->drag_device)
         flags = gtk_scrolled_window_captured_motion_notify (widget, event);
       break;



[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]