atspi: Emit property changes for focus

With this orca, actually speaks \o/.  Sadly, it only
says 'gtk modelbutton widget' so far, but its a start.
This commit is contained in:
Matthias Clasen
2020-10-12 14:11:30 -04:00
parent 45e82adf87
commit d432cbb02b

View File

@@ -22,6 +22,8 @@
#include "gtkatspicontextprivate.h"
#include "gtkaccessibleprivate.h"
#include "gtkatspicacheprivate.h"
#include "gtkatspirootprivate.h"
#include "gtkatspiprivate.h"
@@ -132,6 +134,12 @@ collect_states (GtkAtSpiContext *self,
}
}
if (gtk_widget_get_focusable (widget))
set_atspi_state (states, ATSPI_STATE_FOCUSABLE);
if (gtk_widget_has_focus (widget))
set_atspi_state (states, ATSPI_STATE_FOCUSED);
if (gtk_at_context_has_accessible_property (ctx, GTK_ACCESSIBLE_PROPERTY_ORIENTATION))
{
value = gtk_at_context_get_accessible_property (ctx, GTK_ACCESSIBLE_PROPERTY_ORIENTATION);
@@ -667,9 +675,10 @@ gtk_at_spi_context_state_change (GtkATContext *ctx,
GtkAccessibleAttributeSet *relations)
{
GtkAtSpiContext *self = GTK_AT_SPI_CONTEXT (ctx);
GtkWidget *widget = GTK_WIDGET (gtk_at_context_get_accessible (ctx));
GtkAccessibleValue *value;
if (!gtk_widget_get_realized (GTK_WIDGET (gtk_at_context_get_accessible (ctx))))
if (!gtk_widget_get_realized (widget))
return;
if (changed_states & GTK_ACCESSIBLE_STATE_CHANGE_BUSY)
@@ -815,6 +824,12 @@ gtk_at_spi_context_state_change (GtkATContext *ctx,
g_variant_unref (v);
g_free (label);
}
if (changed_platform & GTK_ACCESSIBLE_PLATFORM_CHANGE_FOCUSABLE)
emit_state_changed (self, "focusable", gtk_widget_get_focusable (widget));
if (changed_platform & GTK_ACCESSIBLE_PLATFORM_CHANGE_FOCUSED)
emit_state_changed (self, "focused", gtk_widget_has_focus (widget));
}
static void