mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2025-01-05 02:11:08 +00:00
a11y: Pair window:activate with window:deactivate signal
Orca needs both events in order to decide whether or not to subscribe to other event/state changes in a window.
This commit is contained in:
parent
268c174506
commit
6a95ca6995
@ -879,7 +879,8 @@ emit_focus (GtkAtSpiContext *self,
|
||||
}
|
||||
|
||||
static void
|
||||
emit_window_activate (GtkAtSpiContext *self)
|
||||
emit_window_event (GtkAtSpiContext *self,
|
||||
const char *event_type)
|
||||
{
|
||||
if (self->connection == NULL)
|
||||
return;
|
||||
@ -888,9 +889,11 @@ emit_window_activate (GtkAtSpiContext *self)
|
||||
NULL,
|
||||
self->context_path,
|
||||
"org.a11y.atspi.Event.Window",
|
||||
"activate",
|
||||
event_type,
|
||||
g_variant_new ("(siiva{sv})",
|
||||
"", 0, 0, g_variant_new_string("0"), NULL),
|
||||
"", 0, 0,
|
||||
g_variant_new_string("0"),
|
||||
NULL),
|
||||
NULL);
|
||||
}
|
||||
|
||||
@ -1130,8 +1133,16 @@ gtk_at_spi_context_platform_change (GtkATContext *ctx,
|
||||
GTK_ACCESSIBLE_PLATFORM_STATE_ACTIVE);
|
||||
emit_state_changed (self, "active", state);
|
||||
|
||||
if (gtk_accessible_get_accessible_role (accessible) == GTK_ACCESSIBLE_ROLE_WINDOW && state)
|
||||
emit_window_activate (self);
|
||||
/* Orca tracks the window:activate and window:deactivate events on top
|
||||
* levels to decide whether to track other AT-SPI events
|
||||
*/
|
||||
if (gtk_accessible_get_accessible_role (accessible) == GTK_ACCESSIBLE_ROLE_WINDOW)
|
||||
{
|
||||
if (state)
|
||||
emit_window_event (self, "activate");
|
||||
else
|
||||
emit_window_event (self, "deactivate");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user