Flutter Engine Uber Docs
Docs for the entire Flutter Engine repo.
 
Loading...
Searching...
No Matches
fl_view_accessible.cc File Reference

Go to the source code of this file.

Classes

struct  _FlViewAccessible
 

Enumerations

enum  FlAtkLive {
  FL_ATK_LIVE_NONE ,
  FL_ATK_LIVE_POLITE ,
  FL_ATK_LIVE_ASSERTIVE
}
 

Functions

static FlAccessibleNode * create_node (FlViewAccessible *self, FlutterSemanticsNode2 *semantics)
 
static FlAccessibleNode * lookup_node (FlViewAccessible *self, int32_t id)
 
static FlAccessibleNode * get_node (FlViewAccessible *self, FlutterSemanticsNode2 *semantics)
 
static gint fl_view_accessible_get_n_children (AtkObject *accessible)
 
static AtkObject * fl_view_accessible_ref_child (AtkObject *accessible, gint i)
 
static AtkRole fl_view_accessible_get_role (AtkObject *accessible)
 
static AtkStateSet * fl_view_accessible_ref_state_set (AtkObject *accessible)
 
static void fl_view_accessible_dispose (GObject *object)
 
static void fl_view_accessible_class_init (FlViewAccessibleClass *klass)
 
static void fl_view_accessible_init (FlViewAccessible *self)
 
FlViewAccessible * fl_view_accessible_new (FlEngine *engine, FlutterViewId view_id)
 
void fl_view_accessible_handle_update_semantics (FlViewAccessible *self, const FlutterSemanticsUpdate2 *update)
 
void fl_view_accessible_send_announcement (FlViewAccessible *self, const char *message, gboolean assertive)
 

Variables

static constexpr int32_t kRootSemanticsNodeId = 0
 

Enumeration Type Documentation

◆ FlAtkLive

enum FlAtkLive
Enumerator
FL_ATK_LIVE_NONE 
FL_ATK_LIVE_POLITE 
FL_ATK_LIVE_ASSERTIVE 

Definition at line 37 of file fl_view_accessible.cc.

Function Documentation

◆ create_node()

static FlAccessibleNode * create_node ( FlViewAccessible *  self,
FlutterSemanticsNode2 semantics 
)
static

Definition at line 43 of file fl_view_accessible.cc.

44 {
45 g_autoptr(FlEngine) engine = FL_ENGINE(g_weak_ref_get(&self->engine));
46 if (engine == nullptr) {
47 return nullptr;
48 }
49
50 if (semantics->flags2->is_text_field) {
51 return fl_accessible_text_field_new(engine, self->view_id, semantics->id);
52 }
53
54 return fl_accessible_node_new(engine, self->view_id, semantics->id);
55}
FlutterEngine engine
Definition main.cc:84
g_autoptr(FlEngine) engine
FlAccessibleNode * fl_accessible_node_new(FlEngine *engine, FlutterViewId view_id, int32_t node_id)
FlAccessibleNode * fl_accessible_text_field_new(FlEngine *engine, FlutterViewId view_id, int32_t id)
bool is_text_field
Whether the semantic node represents a text field.
Definition embedder.h:313
int32_t id
The unique identifier for this node.
Definition embedder.h:1613
FlutterSemanticsFlags * flags2
Definition embedder.h:1705

References engine, fl_accessible_node_new(), fl_accessible_text_field_new(), FlutterSemanticsNode2::flags2, g_autoptr(), FlutterSemanticsNode2::id, FlutterSemanticsFlags::is_text_field, and self.

Referenced by get_node().

◆ fl_view_accessible_class_init()

static void fl_view_accessible_class_init ( FlViewAccessibleClass *  klass)
static

Definition at line 134 of file fl_view_accessible.cc.

134 {
135 ATK_OBJECT_CLASS(klass)->get_n_children = fl_view_accessible_get_n_children;
136 ATK_OBJECT_CLASS(klass)->ref_child = fl_view_accessible_ref_child;
137 ATK_OBJECT_CLASS(klass)->get_role = fl_view_accessible_get_role;
138 ATK_OBJECT_CLASS(klass)->ref_state_set = fl_view_accessible_ref_state_set;
139
140 G_OBJECT_CLASS(klass)->dispose = fl_view_accessible_dispose;
141}
static void fl_view_accessible_dispose(GObject *object)
static AtkStateSet * fl_view_accessible_ref_state_set(AtkObject *accessible)
static AtkRole fl_view_accessible_get_role(AtkObject *accessible)
static AtkObject * fl_view_accessible_ref_child(AtkObject *accessible, gint i)
static gint fl_view_accessible_get_n_children(AtkObject *accessible)

References fl_view_accessible_dispose(), fl_view_accessible_get_n_children(), fl_view_accessible_get_role(), fl_view_accessible_ref_child(), and fl_view_accessible_ref_state_set().

◆ fl_view_accessible_dispose()

static void fl_view_accessible_dispose ( GObject *  object)
static

Definition at line 124 of file fl_view_accessible.cc.

124 {
125 FlViewAccessible* self = FL_VIEW_ACCESSIBLE(object);
126
127 g_clear_pointer(&self->semantics_nodes_by_id, g_hash_table_unref);
128
129 g_weak_ref_clear(&self->engine);
130
131 G_OBJECT_CLASS(fl_view_accessible_parent_class)->dispose(object);
132}

References self.

Referenced by fl_view_accessible_class_init().

◆ fl_view_accessible_get_n_children()

static gint fl_view_accessible_get_n_children ( AtkObject *  accessible)
static

Definition at line 89 of file fl_view_accessible.cc.

89 {
90 FlViewAccessible* self = FL_VIEW_ACCESSIBLE(accessible);
91 FlAccessibleNode* node = lookup_node(self, 0);
92
93 if (node == nullptr) {
94 return 0;
95 }
96
97 return 1;
98}
FlViewAccessible * accessible
static FlAccessibleNode * lookup_node(FlViewAccessible *self, int32_t id)

References accessible, lookup_node(), and self.

Referenced by fl_view_accessible_class_init().

◆ fl_view_accessible_get_role()

static AtkRole fl_view_accessible_get_role ( AtkObject *  accessible)
static

Definition at line 113 of file fl_view_accessible.cc.

113 {
114 return ATK_ROLE_PANEL;
115}

Referenced by fl_view_accessible_class_init().

◆ fl_view_accessible_handle_update_semantics()

void fl_view_accessible_handle_update_semantics ( FlViewAccessible *  accessible,
const FlutterSemanticsUpdate2 update 
)

fl_view_accessible_handle_update_semantics: @accessible: an #FlViewAccessible. @update: semantic update information.

Handle a semantics update from Flutter.

Definition at line 157 of file fl_view_accessible.cc.

159 {
160 g_return_if_fail(FL_IS_VIEW_ACCESSIBLE(self));
161
162 g_autoptr(GHashTable) pending_children =
163 g_hash_table_new_full(g_direct_hash, g_direct_equal, nullptr,
164 reinterpret_cast<GDestroyNotify>(fl_value_unref));
165 for (size_t i = 0; i < update->node_count; i++) {
166 FlutterSemanticsNode2* node = update->nodes[i];
167 FlAccessibleNode* atk_node = get_node(self, node);
168
169 fl_accessible_node_set_flags(atk_node, node->flags2);
171 fl_accessible_node_set_name(atk_node, node->label);
173 atk_node, node->rect.left + node->transform.transX,
174 node->rect.top + node->transform.transY,
175 node->rect.right - node->rect.left, node->rect.bottom - node->rect.top);
176 fl_accessible_node_set_value(atk_node, node->value);
180
183 g_hash_table_insert(pending_children, atk_node, children);
184 }
185
186 g_hash_table_foreach_remove(
187 pending_children,
188 [](gpointer key, gpointer value, gpointer user_data) -> gboolean {
189 FlViewAccessible* self = FL_VIEW_ACCESSIBLE(user_data);
190
191 FlAccessibleNode* parent = FL_ACCESSIBLE_NODE(key);
192
193 size_t child_count = fl_value_get_length(static_cast<FlValue*>(value));
194 const int32_t* children_in_traversal_order =
195 fl_value_get_int32_list(static_cast<FlValue*>(value));
196
197 g_autoptr(GPtrArray) children = g_ptr_array_new();
198 for (size_t i = 0; i < child_count; i++) {
199 FlAccessibleNode* child =
200 lookup_node(self, children_in_traversal_order[i]);
201 if (child == nullptr) {
202 continue;
203 }
204 fl_accessible_node_set_parent(child, ATK_OBJECT(parent), i);
205 g_ptr_array_add(children, child);
206 }
207 fl_accessible_node_set_children(parent, children);
208
209 return TRUE;
210 },
211 self);
212}
void fl_accessible_node_set_name(FlAccessibleNode *self, const gchar *name)
void fl_accessible_node_set_text_direction(FlAccessibleNode *self, FlutterTextDirection direction)
void fl_accessible_node_set_text_selection(FlAccessibleNode *self, gint base, gint extent)
void fl_accessible_node_set_actions(FlAccessibleNode *self, FlutterSemanticsAction actions)
void fl_accessible_node_set_children(FlAccessibleNode *self, GPtrArray *children)
void fl_accessible_node_set_extents(FlAccessibleNode *self, gint x, gint y, gint width, gint height)
void fl_accessible_node_set_value(FlAccessibleNode *self, const gchar *value)
void fl_accessible_node_set_parent(FlAccessibleNode *self, AtkObject *parent, gint index)
void fl_accessible_node_set_flags(FlAccessibleNode *self, FlutterSemanticsFlags *flags)
return TRUE
g_hash_table_insert(self->handlers, g_strdup(channel), handler_new(handler, user_data, destroy_notify))
G_MODULE_EXPORT void fl_value_unref(FlValue *self)
Definition fl_value.cc:400
G_MODULE_EXPORT FlValue * fl_value_new_int32_list(const int32_t *data, size_t data_length)
Definition fl_value.cc:309
G_MODULE_EXPORT size_t fl_value_get_length(FlValue *self)
Definition fl_value.cc:724
G_MODULE_EXPORT const int32_t * fl_value_get_int32_list(FlValue *self)
Definition fl_value.cc:696
typedefG_BEGIN_DECLS struct _FlValue FlValue
Definition fl_value.h:42
static FlAccessibleNode * get_node(FlViewAccessible *self, FlutterSemanticsNode2 *semantics)
double bottom
Definition embedder.h:645
double top
Definition embedder.h:643
double left
Definition embedder.h:642
double right
Definition embedder.h:644
const int32_t * children_in_traversal_order
Array of child node IDs in traversal order. Has length child_count.
Definition embedder.h:1665
int32_t text_selection_extent
The position at which the text selection terminates.
Definition embedder.h:1625
FlutterTextDirection text_direction
Definition embedder.h:1656
FlutterSemanticsAction actions
The set of semantics actions applicable to this node.
Definition embedder.h:1621
FlutterRect rect
The bounding box for this node in its coordinate system.
Definition embedder.h:1658
FlutterTransformation transform
Definition embedder.h:1661
size_t child_count
The number of children this node has.
Definition embedder.h:1663
const char * label
A textual description of the node.
Definition embedder.h:1643
int32_t text_selection_base
The position at which the text selection originates.
Definition embedder.h:1623
const char * value
A textual description of the current value of the node.
Definition embedder.h:1647
size_t node_count
The number of semantics node updates.
Definition embedder.h:1800
FlutterSemanticsNode2 ** nodes
Definition embedder.h:1802
double transY
vertical translation
Definition embedder.h:400
double transX
horizontal translation
Definition embedder.h:394

References FlutterSemanticsNode2::actions, FlutterRect::bottom, FlutterSemanticsNode2::child_count, FlutterSemanticsNode2::children_in_traversal_order, fl_accessible_node_set_actions(), fl_accessible_node_set_children(), fl_accessible_node_set_extents(), fl_accessible_node_set_flags(), fl_accessible_node_set_name(), fl_accessible_node_set_parent(), fl_accessible_node_set_text_direction(), fl_accessible_node_set_text_selection(), fl_accessible_node_set_value(), fl_value_get_int32_list(), fl_value_get_length(), fl_value_new_int32_list(), fl_value_unref(), FlutterSemanticsNode2::flags2, g_autoptr(), g_hash_table_insert(), get_node(), i, key, FlutterSemanticsNode2::label, FlutterRect::left, lookup_node(), FlutterSemanticsUpdate2::node_count, FlutterSemanticsUpdate2::nodes, FlutterSemanticsNode2::rect, FlutterRect::right, self, FlutterSemanticsNode2::text_direction, FlutterSemanticsNode2::text_selection_base, FlutterSemanticsNode2::text_selection_extent, FlutterRect::top, FlutterSemanticsNode2::transform, FlutterTransformation::transX, FlutterTransformation::transY, TRUE, user_data, value, and FlutterSemanticsNode2::value.

Referenced by TEST(), TEST(), and update_semantics_cb().

◆ fl_view_accessible_init()

static void fl_view_accessible_init ( FlViewAccessible *  self)
static

Definition at line 143 of file fl_view_accessible.cc.

143 {
144 self->semantics_nodes_by_id = g_hash_table_new_full(
145 g_direct_hash, g_direct_equal, nullptr, g_object_unref);
146}

References self.

◆ fl_view_accessible_new()

FlViewAccessible * fl_view_accessible_new ( FlEngine *  engine,
FlutterViewId  view_id 
)

Definition at line 148 of file fl_view_accessible.cc.

149 {
150 FlViewAccessible* self =
151 FL_VIEW_ACCESSIBLE(g_object_new(fl_view_accessible_get_type(), nullptr));
152 g_weak_ref_init(&self->engine, engine);
153 self->view_id = view_id;
154 return self;
155}
G_BEGIN_DECLS FlutterViewId view_id

References engine, self, and view_id.

Referenced by setup_engine(), TEST(), and TEST().

◆ fl_view_accessible_ref_child()

static AtkObject * fl_view_accessible_ref_child ( AtkObject *  accessible,
gint  i 
)
static

Definition at line 101 of file fl_view_accessible.cc.

101 {
102 FlViewAccessible* self = FL_VIEW_ACCESSIBLE(accessible);
103 FlAccessibleNode* node = lookup_node(self, 0);
104
105 if (i != 0 || node == nullptr) {
106 return nullptr;
107 }
108
109 return ATK_OBJECT(g_object_ref(node));
110}

References accessible, i, lookup_node(), and self.

Referenced by fl_view_accessible_class_init().

◆ fl_view_accessible_ref_state_set()

static AtkStateSet * fl_view_accessible_ref_state_set ( AtkObject *  accessible)
static

Definition at line 118 of file fl_view_accessible.cc.

118 {
119 FlViewAccessible* self = FL_VIEW_ACCESSIBLE(accessible);
120 FlAccessibleNode* node = lookup_node(self, 0);
121 return node != nullptr ? atk_object_ref_state_set(ATK_OBJECT(node)) : nullptr;
122}

References accessible, lookup_node(), and self.

Referenced by fl_view_accessible_class_init().

◆ fl_view_accessible_send_announcement()

void fl_view_accessible_send_announcement ( FlViewAccessible *  accessible,
const char *  message,
gboolean  assertive 
)

fl_view_accessible_send_announcement: @accessible: an #FlViewAccessible. @message: text to be announced. @assertive: TRUE if the message should be in an assertive voice.

Sends an annoucement to a screen reader.

Definition at line 214 of file fl_view_accessible.cc.

216 {
217 g_return_if_fail(FL_IS_VIEW_ACCESSIBLE(self));
218 if (atk_get_major_version() == 2 && atk_get_minor_version() >= 50) {
219 g_signal_emit_by_name(
220 self, "notification", message,
222 } else if (atk_get_major_version() == 2 && atk_get_minor_version() >= 46) {
223 g_signal_emit_by_name(self, "announcement", message);
224 }
225}
const char * message

References FL_ATK_LIVE_ASSERTIVE, FL_ATK_LIVE_POLITE, message, and self.

◆ get_node()

static FlAccessibleNode * get_node ( FlViewAccessible *  self,
FlutterSemanticsNode2 semantics 
)
static

Definition at line 64 of file fl_view_accessible.cc.

65 {
66 FlAccessibleNode* node = lookup_node(self, semantics->id);
67 if (node != nullptr) {
68 return node;
69 }
70
71 node = create_node(self, semantics);
72 if (semantics->id == kRootSemanticsNodeId) {
73 fl_accessible_node_set_parent(node, ATK_OBJECT(self), 0);
74 }
75 g_hash_table_insert(self->semantics_nodes_by_id,
76 GINT_TO_POINTER(semantics->id),
77 reinterpret_cast<gpointer>(node));
78
79 // Update when root node is created.
80 if (!self->root_node_created && semantics->id == kRootSemanticsNodeId) {
81 g_signal_emit_by_name(self, "children-changed::add", 0, node, nullptr);
82 self->root_node_created = true;
83 }
84
85 return node;
86}
static FlAccessibleNode * create_node(FlViewAccessible *self, FlutterSemanticsNode2 *semantics)
static constexpr int32_t kRootSemanticsNodeId

References create_node(), fl_accessible_node_set_parent(), g_hash_table_insert(), FlutterSemanticsNode2::id, kRootSemanticsNodeId, lookup_node(), and self.

Referenced by fl_view_accessible_handle_update_semantics().

◆ lookup_node()

static FlAccessibleNode * lookup_node ( FlViewAccessible *  self,
int32_t  id 
)
static

Definition at line 57 of file fl_view_accessible.cc.

57 {
58 return FL_ACCESSIBLE_NODE(
59 g_hash_table_lookup(self->semantics_nodes_by_id, GINT_TO_POINTER(id)));
60}

References self.

Referenced by fl_view_accessible_get_n_children(), fl_view_accessible_handle_update_semantics(), fl_view_accessible_ref_child(), fl_view_accessible_ref_state_set(), and get_node().

Variable Documentation

◆ kRootSemanticsNodeId

constexpr int32_t kRootSemanticsNodeId = 0
staticconstexpr

Definition at line 17 of file fl_view_accessible.cc.

Referenced by get_node().