a11y atspi: Reuse helper to translate text coords

Instead of reimplementing translating coordinates
relative to a GtkAccessible in a way that requires
that the GtkAccessible is a GtkWidget, reuse the
existing helper function
`gtk_at_spi_translate_coordinates_from_accessible`
in the implementations of AT-SPI Text methods
GetCharacterExtents and GetRangeExtents.

This makes the implementation work for non-GtkWidget
GtkAccessibles, adds support for parent-relative
coordinates (ATSPI_COORD_TYPE_PARENT)
and also fixes an issue with incorrect extents
being reported in a quick test with the "Hypertext"
sample from gtk4-demo.

Sample for querying extents in Accerciser's IPython
console for the Hypertext sample previously gave this
result:

    In [39]: acc.queryText().getCharacterExtents(5, pyatspi.XY_WINDOW)
    Out[39]: (58, 20, -53, -1)

Now, a positive width and height are returned as expected and
the result matches the one when using the GTK 3 version
in gtk3-demo:

    In [1]: acc.queryText().getCharacterExtents(5, pyatspi.XY_WINDOW)
    Out[1]: (58, 20, 5, 19)
This commit is contained in:
Michael Weghorn 2024-04-04 12:22:45 +02:00
parent a62831562f
commit c01782b0a9

View File

@ -371,14 +371,11 @@ accessible_text_handle_method (GDBusConnection *connection,
int offset; int offset;
unsigned int coords_type; unsigned int coords_type;
graphene_rect_t extents; graphene_rect_t extents;
graphene_point_t point;
int x, y, w, h; int x, y, w, h;
GtkNative *native;
double nx, ny;
g_variant_get (parameters, "(iu)", &offset, &coords_type); g_variant_get (parameters, "(iu)", &offset, &coords_type);
if (coords_type != ATSPI_COORD_TYPE_WINDOW) if (coords_type != ATSPI_COORD_TYPE_PARENT && coords_type != ATSPI_COORD_TYPE_WINDOW)
{ {
g_dbus_method_invocation_return_error_literal (invocation, g_dbus_method_invocation_return_error_literal (invocation,
G_DBUS_ERROR, G_DBUS_ERROR,
@ -387,11 +384,7 @@ accessible_text_handle_method (GDBusConnection *connection,
return; return;
} }
native = gtk_widget_get_native (GTK_WIDGET (accessible)); if (!gtk_accessible_text_get_extents (accessible_text, offset, offset + 1, &extents))
gtk_native_get_surface_transform (native, &nx, &ny);
if (!gtk_accessible_text_get_extents (accessible_text, offset, offset + 1, &extents) ||
!gtk_widget_compute_point (GTK_WIDGET (accessible), GTK_WIDGET (native), &extents.origin, &point))
{ {
g_dbus_method_invocation_return_error_literal (invocation, g_dbus_method_invocation_return_error_literal (invocation,
G_DBUS_ERROR, G_DBUS_ERROR,
@ -400,10 +393,9 @@ accessible_text_handle_method (GDBusConnection *connection,
return; return;
} }
x = floor (point.x + nx); gtk_at_spi_translate_coordinates_from_accessible(accessible, coords_type, extents.origin.x, extents.origin.y, &x, &y);
y = floor (point.y + ny); w = extents.size.width;
w = ceilf (extents.size.width) - x; h = extents.size.height;
h = ceilf (extents.size.height) - y;
g_dbus_method_invocation_return_value (invocation, g_variant_new ("(iiii)", x, y, w, h)); g_dbus_method_invocation_return_value (invocation, g_variant_new ("(iiii)", x, y, w, h));
} }
@ -412,14 +404,11 @@ accessible_text_handle_method (GDBusConnection *connection,
int start, end; int start, end;
guint coords_type; guint coords_type;
graphene_rect_t extents; graphene_rect_t extents;
graphene_point_t point;
int x, y, w, h; int x, y, w, h;
GtkNative *native;
double nx, ny;
g_variant_get (parameters, "(iiu)", &start, &end, &coords_type); g_variant_get (parameters, "(iiu)", &start, &end, &coords_type);
if (coords_type != ATSPI_COORD_TYPE_WINDOW) if (coords_type != ATSPI_COORD_TYPE_PARENT && coords_type != ATSPI_COORD_TYPE_WINDOW)
{ {
g_dbus_method_invocation_return_error_literal (invocation, g_dbus_method_invocation_return_error_literal (invocation,
G_DBUS_ERROR, G_DBUS_ERROR,
@ -428,11 +417,7 @@ accessible_text_handle_method (GDBusConnection *connection,
return; return;
} }
native = gtk_widget_get_native (GTK_WIDGET (accessible)); if (!gtk_accessible_text_get_extents (accessible_text, start, end, &extents))
gtk_native_get_surface_transform (native, &nx, &ny);
if (!gtk_accessible_text_get_extents (accessible_text, start, end, &extents) ||
!gtk_widget_compute_point (GTK_WIDGET (accessible), GTK_WIDGET (native), &extents.origin, &point))
{ {
g_dbus_method_invocation_return_error_literal (invocation, g_dbus_method_invocation_return_error_literal (invocation,
G_DBUS_ERROR, G_DBUS_ERROR,
@ -441,10 +426,9 @@ accessible_text_handle_method (GDBusConnection *connection,
return; return;
} }
x = floor (point.x + nx); gtk_at_spi_translate_coordinates_from_accessible(accessible, coords_type, extents.origin.x, extents.origin.y, &x, &y);
y = floor (point.y + ny); w = extents.size.width;
w = ceilf (extents.size.width) - x; h = extents.size.height;
h = ceilf (extents.size.height) - y;
g_dbus_method_invocation_return_value (invocation, g_variant_new ("(iiii)", x, y, w, h)); g_dbus_method_invocation_return_value (invocation, g_variant_new ("(iiii)", x, y, w, h));
} }