[gtk+/wip/wayland-tablet: 15/23] gtk3-demo: Show multiple master devices on the "Event axes" demo
- From: Carlos Garnacho <carlosg src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk+/wip/wayland-tablet: 15/23] gtk3-demo: Show multiple master devices on the "Event axes" demo
- Date: Mon, 22 Jun 2015 17:16:09 +0000 (UTC)
commit 0130898d06a3ff4febcdcb2a7ba44bec09786fc3
Author: Carlos Garnacho <carlosg gnome org>
Date: Tue Feb 10 15:59:18 2015 +0100
gtk3-demo: Show multiple master devices on the "Event axes" demo
demos/gtk-demo/event_axes.c | 58 +++++++++++++++++++++++++-----------------
1 files changed, 34 insertions(+), 24 deletions(-)
---
diff --git a/demos/gtk-demo/event_axes.c b/demos/gtk-demo/event_axes.c
index 457cca6..c27919d 100644
--- a/demos/gtk-demo/event_axes.c
+++ b/demos/gtk-demo/event_axes.c
@@ -31,7 +31,7 @@ typedef struct {
} AxesInfo;
typedef struct {
- AxesInfo *pointer_info;
+ GHashTable *pointer_info; /* GdkDevice -> AxesInfo */
GHashTable *touch_info; /* GdkEventSequence -> AxesInfo */
} EventData;
@@ -77,6 +77,8 @@ event_data_new (void)
EventData *data;
data = g_new0 (EventData, 1);
+ data->pointer_info = g_hash_table_new_full (NULL, NULL, NULL,
+ (GDestroyNotify) axes_info_free);
data->touch_info = g_hash_table_new_full (NULL, NULL, NULL,
(GDestroyNotify) axes_info_free);
@@ -86,8 +88,7 @@ event_data_new (void)
static void
event_data_free (EventData *data)
{
- if (data->pointer_info)
- axes_info_free (data->pointer_info);
+ g_hash_table_destroy (data->pointer_info);
g_hash_table_destroy (data->touch_info);
g_free (data);
}
@@ -96,11 +97,12 @@ static void
update_axes_from_event (GdkEvent *event,
EventData *data)
{
- GdkDevice *source_device;
+ GdkDevice *device, *source_device;
GdkEventSequence *sequence;
gdouble x, y;
AxesInfo *info;
+ device = gdk_event_get_device (event);
source_device = gdk_event_get_source_device (event);
sequence = gdk_event_get_event_sequence (event);
@@ -111,17 +113,19 @@ update_axes_from_event (GdkEvent *event,
}
else if (event->type == GDK_LEAVE_NOTIFY)
{
- if (data->pointer_info)
- axes_info_free (data->pointer_info);
- data->pointer_info = NULL;
+ g_hash_table_remove (data->pointer_info, device);
return;
}
if (!sequence)
{
- if (!data->pointer_info)
- data->pointer_info = axes_info_new ();
- info = data->pointer_info;
+ info = g_hash_table_lookup (data->pointer_info, device);
+
+ if (!info)
+ {
+ info = axes_info_new ();
+ g_hash_table_insert (data->pointer_info, device, info);
+ }
}
else
{
@@ -144,11 +148,7 @@ update_axes_from_event (GdkEvent *event,
event->type == GDK_BUTTON_RELEASE)
{
if (sequence && event->touch.emulating_pointer)
- {
- if (data->pointer_info)
- axes_info_free (data->pointer_info);
- data->pointer_info = NULL;
- }
+ g_hash_table_remove (data->pointer_info, device);
if (info->axes)
g_free (info->axes);
@@ -340,7 +340,7 @@ draw_cb (GtkWidget *widget,
{
EventData *data = user_data;
GtkAllocation allocation;
- AxesInfo *touch_info;
+ AxesInfo *info;
GHashTableIter iter;
gpointer key, value;
gint y = 0;
@@ -348,27 +348,37 @@ draw_cb (GtkWidget *widget,
gtk_widget_get_allocation (widget, &allocation);
/* Draw Abs info */
- if (data->pointer_info)
- draw_axes_info (cr, data->pointer_info, &allocation);
+ g_hash_table_iter_init (&iter, data->pointer_info);
+
+ while (g_hash_table_iter_next (&iter, NULL, &value))
+ {
+ info = value;
+ draw_axes_info (cr, info, &allocation);
+ }
g_hash_table_iter_init (&iter, data->touch_info);
while (g_hash_table_iter_next (&iter, NULL, &value))
{
- touch_info = value;
- draw_axes_info (cr, touch_info, &allocation);
+ info = value;
+ draw_axes_info (cr, info, &allocation);
}
/* Draw name, color legend and misc data */
- if (data->pointer_info)
- draw_device_info (widget, cr, NULL, &y, data->pointer_info);
+ g_hash_table_iter_init (&iter, data->pointer_info);
+
+ while (g_hash_table_iter_next (&iter, NULL, &value))
+ {
+ info = value;
+ draw_device_info (widget, cr, NULL, &y, info);
+ }
g_hash_table_iter_init (&iter, data->touch_info);
while (g_hash_table_iter_next (&iter, &key, &value))
{
- touch_info = value;
- draw_device_info (widget, cr, key, &y, touch_info);
+ info = value;
+ draw_device_info (widget, cr, key, &y, info);
}
return FALSE;
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]