[gtk+/gestures: 86/173] swipe: Add function to retrieve the current velocity
- From: Carlos Garnacho <carlosg src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk+/gestures: 86/173] swipe: Add function to retrieve the current velocity
- Date: Fri, 16 May 2014 17:07:37 +0000 (UTC)
commit 2ef4edc2c89ab1dfe101c89c936f54fac0d457c8
Author: Carlos Garnacho <carlosg gnome org>
Date: Tue Apr 8 21:19:46 2014 +0200
swipe: Add function to retrieve the current velocity
This can be used to fetch the current velocity on update(), as opposed
to swipe() which happens after the sequence is finished.
gtk/gtkgestureswipe.c | 37 ++++++++++++++++++++++++++++++++-----
gtk/gtkgestureswipe.h | 5 +++++
2 files changed, 37 insertions(+), 5 deletions(-)
---
diff --git a/gtk/gtkgestureswipe.c b/gtk/gtkgestureswipe.c
index d04504a..e4f6e29 100644
--- a/gtk/gtkgestureswipe.c
+++ b/gtk/gtkgestureswipe.c
@@ -109,13 +109,18 @@ _gtk_gesture_swipe_calculate_velocity (GtkGestureSwipe *gesture,
gdouble *velocity_y)
{
GtkGestureSwipePrivate *priv;
+ GdkEventSequence *sequence;
+ guint32 evtime, diff_time;
EventData *start, *end;
gdouble diff_x, diff_y;
- guint32 diff_time;
priv = gtk_gesture_swipe_get_instance_private (gesture);
*velocity_x = *velocity_y = 0;
+ sequence = gtk_gesture_single_get_current_sequence (GTK_GESTURE_SINGLE (gesture));
+ gtk_gesture_get_last_update_time (GTK_GESTURE (gesture), sequence, &evtime);
+ _gtk_gesture_swipe_clear_backlog (gesture, evtime);
+
if (priv->events->len == 0)
return;
@@ -141,14 +146,14 @@ gtk_gesture_swipe_end (GtkGesture *gesture,
GtkGestureSwipe *swipe = GTK_GESTURE_SWIPE (gesture);
GtkGestureSwipePrivate *priv;
gdouble velocity_x, velocity_y;
- guint32 evtime;
+ GdkEventSequence *seq;
+
+ seq = gtk_gesture_single_get_current_sequence (GTK_GESTURE_SINGLE (gesture));
- if (gtk_gesture_get_sequence_state (gesture, sequence) == GTK_EVENT_SEQUENCE_DENIED)
+ if (gtk_gesture_get_sequence_state (gesture, seq) == GTK_EVENT_SEQUENCE_DENIED)
return;
priv = gtk_gesture_swipe_get_instance_private (swipe);
- gtk_gesture_get_last_update_time (gesture, sequence, &evtime);
- _gtk_gesture_swipe_clear_backlog (swipe, evtime);
_gtk_gesture_swipe_calculate_velocity (swipe, &velocity_x, &velocity_y);
g_signal_emit (gesture, signals[SWIPE], 0, velocity_x, velocity_y);
@@ -202,3 +207,25 @@ gtk_gesture_swipe_new (GtkWidget *widget)
"widget", widget,
NULL);
}
+
+gboolean
+gtk_gesture_swipe_get_velocity (GtkGestureSwipe *gesture,
+ gdouble *velocity_x,
+ gdouble *velocity_y)
+{
+ gdouble vel_x, vel_y;
+
+ g_return_val_if_fail (GTK_IS_GESTURE (gesture), NULL);
+
+ if (!gtk_gesture_is_recognized (GTK_GESTURE (gesture)))
+ return FALSE;
+
+ _gtk_gesture_swipe_calculate_velocity (gesture, &vel_x, &vel_y);
+
+ if (velocity_x)
+ *velocity_x = vel_x;
+ if (velocity_y)
+ *velocity_y = vel_y;
+
+ return TRUE;
+}
diff --git a/gtk/gtkgestureswipe.h b/gtk/gtkgestureswipe.h
index b8564b0..fec6132 100644
--- a/gtk/gtkgestureswipe.h
+++ b/gtk/gtkgestureswipe.h
@@ -62,6 +62,11 @@ GType gtk_gesture_swipe_get_type (void) G_GNUC_CONST;
GDK_AVAILABLE_IN_3_14
GtkGesture * gtk_gesture_swipe_new (GtkWidget *widget);
+GDK_AVAILABLE_IN_3_14
+gboolean gtk_gesture_swipe_get_velocity (GtkGestureSwipe *gesture,
+ gdouble *velocity_x,
+ gdouble *velocity_y);
+
G_END_DECLS
#endif /* __GTK_GESTURE_SWIPE_H__ */
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]