mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2025-01-13 14:00:09 +00:00
inspector: Add axes to event details in recorder
This is useful information if you have devices producing such events.
This commit is contained in:
parent
abf6068d91
commit
ee7541c032
@ -1360,12 +1360,51 @@ key_event_string (GdkEvent *event)
|
|||||||
return g_strdup (gdk_keyval_name (keyval));
|
return g_strdup (gdk_keyval_name (keyval));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static const char *
|
||||||
|
device_tool_name (GdkDeviceTool *tool)
|
||||||
|
{
|
||||||
|
const char *name[] = {
|
||||||
|
"Unknown",
|
||||||
|
"Pen",
|
||||||
|
"Eraser",
|
||||||
|
"Brush",
|
||||||
|
"Pencil",
|
||||||
|
"Airbrush",
|
||||||
|
"Mouse",
|
||||||
|
"Lens"
|
||||||
|
};
|
||||||
|
|
||||||
|
return name[gdk_device_tool_get_tool_type (tool)];
|
||||||
|
}
|
||||||
|
|
||||||
|
static const char *
|
||||||
|
axis_name (GdkAxisUse axis)
|
||||||
|
{
|
||||||
|
const char *name[] = {
|
||||||
|
"",
|
||||||
|
"X",
|
||||||
|
"Y",
|
||||||
|
"Delta X",
|
||||||
|
"Delta Y",
|
||||||
|
"Pressure",
|
||||||
|
"X Tilt",
|
||||||
|
"Y Tilt",
|
||||||
|
"Wheel",
|
||||||
|
"Distance",
|
||||||
|
"Rotation",
|
||||||
|
"Slider"
|
||||||
|
};
|
||||||
|
|
||||||
|
return name[axis];
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
populate_event_properties (GtkListStore *store,
|
populate_event_properties (GtkListStore *store,
|
||||||
GdkEvent *event)
|
GdkEvent *event)
|
||||||
{
|
{
|
||||||
GdkEventType type;
|
GdkEventType type;
|
||||||
GdkDevice *device;
|
GdkDevice *device;
|
||||||
|
GdkDeviceTool *tool;
|
||||||
double x, y;
|
double x, y;
|
||||||
char *tmp;
|
char *tmp;
|
||||||
GdkModifierType state;
|
GdkModifierType state;
|
||||||
@ -1381,6 +1420,10 @@ populate_event_properties (GtkListStore *store,
|
|||||||
if (device)
|
if (device)
|
||||||
add_text_row (store, "Device", gdk_device_get_name (device));
|
add_text_row (store, "Device", gdk_device_get_name (device));
|
||||||
|
|
||||||
|
tool = gdk_event_get_device_tool (event);
|
||||||
|
if (tool)
|
||||||
|
add_text_row (store, "Device Tool", device_tool_name (tool));
|
||||||
|
|
||||||
if (gdk_event_get_position (event, &x, &y))
|
if (gdk_event_get_position (event, &x, &y))
|
||||||
{
|
{
|
||||||
tmp = g_strdup_printf ("%.2f %.2f", x, y);
|
tmp = g_strdup_printf ("%.2f %.2f", x, y);
|
||||||
@ -1388,6 +1431,26 @@ populate_event_properties (GtkListStore *store,
|
|||||||
g_free (tmp);
|
g_free (tmp);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (tool)
|
||||||
|
{
|
||||||
|
GdkAxisFlags axes = gdk_device_tool_get_axes (tool);
|
||||||
|
|
||||||
|
/* We report position and scroll delta separately, so skip them here */
|
||||||
|
axes &= ~(GDK_AXIS_FLAG_X|GDK_AXIS_FLAG_Y|GDK_AXIS_FLAG_DELTA_X|GDK_AXIS_FLAG_DELTA_Y);
|
||||||
|
|
||||||
|
for (int i = 1; i < GDK_AXIS_LAST; i++)
|
||||||
|
{
|
||||||
|
if (axes & (1 << i))
|
||||||
|
{
|
||||||
|
double val;
|
||||||
|
gdk_event_get_axis (event, i, &val);
|
||||||
|
tmp = g_strdup_printf ("%.2f", val);
|
||||||
|
add_text_row (store, axis_name (i), tmp);
|
||||||
|
g_free (tmp);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
state = gdk_event_get_modifier_state (event);
|
state = gdk_event_get_modifier_state (event);
|
||||||
if (state != 0)
|
if (state != 0)
|
||||||
{
|
{
|
||||||
@ -1458,18 +1521,26 @@ populate_event_properties (GtkListStore *store,
|
|||||||
history = gdk_event_get_history (event, &n_coords);
|
history = gdk_event_get_history (event, &n_coords);
|
||||||
if (history)
|
if (history)
|
||||||
{
|
{
|
||||||
GString *s;
|
GString *s = g_string_new ("");
|
||||||
|
|
||||||
s = g_string_new ("");
|
|
||||||
|
|
||||||
for (int i = 0; i < n_coords; i++)
|
for (int i = 0; i < n_coords; i++)
|
||||||
{
|
{
|
||||||
if (i > 0)
|
if (i > 0)
|
||||||
g_string_append (s, "\n");
|
g_string_append (s, "\n");
|
||||||
if ((history[i].flags & (GDK_AXIS_FLAG_X|GDK_AXIS_FLAG_Y)) == (GDK_AXIS_FLAG_X|GDK_AXIS_FLAG_Y))
|
|
||||||
g_string_append_printf (s, "%d: %.2f %.2f", history[i].time, history[i].axes[GDK_AXIS_X], history[i].axes[GDK_AXIS_Y]);
|
g_string_append_printf (s, "%d", history[i].time);
|
||||||
if ((history[i].flags & (GDK_AXIS_FLAG_DELTA_X|GDK_AXIS_FLAG_DELTA_Y)) == (GDK_AXIS_FLAG_DELTA_X|GDK_AXIS_FLAG_DELTA_Y))
|
|
||||||
g_string_append_printf (s, "%d: %.2f %.2f", history[i].time, history[i].axes[GDK_AXIS_DELTA_X], history[i].axes[GDK_AXIS_DELTA_Y]);
|
if (history[i].flags & (GDK_AXIS_FLAG_X|GDK_AXIS_FLAG_Y))
|
||||||
|
g_string_append_printf (s, " Position %.2f %.2f", history[i].axes[GDK_AXIS_X], history[i].axes[GDK_AXIS_Y]);
|
||||||
|
|
||||||
|
if (history[i].flags & (GDK_AXIS_FLAG_DELTA_X|GDK_AXIS_FLAG_DELTA_Y))
|
||||||
|
g_string_append_printf (s, " Delta %.2f %.2f", history[i].axes[GDK_AXIS_DELTA_X], history[i].axes[GDK_AXIS_DELTA_Y]);
|
||||||
|
|
||||||
|
for (int j = GDK_AXIS_PRESSURE; j < GDK_AXIS_LAST; j++)
|
||||||
|
{
|
||||||
|
if (history[i].flags & (1 << j))
|
||||||
|
g_string_append_printf (s, " %s %.2f", axis_name (j), history[i].axes[j]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
add_text_row (store, "History", s->str);
|
add_text_row (store, "History", s->str);
|
||||||
@ -2093,4 +2164,4 @@ gtk_inspector_recorder_set_debug_nodes (GtkInspectorRecorder *recorder,
|
|||||||
g_object_notify_by_pspec (G_OBJECT (recorder), props[PROP_DEBUG_NODES]);
|
g_object_notify_by_pspec (G_OBJECT (recorder), props[PROP_DEBUG_NODES]);
|
||||||
}
|
}
|
||||||
|
|
||||||
// vim: set et sw=2 ts=2:
|
|
||||||
|
Loading…
Reference in New Issue
Block a user