Flutter Linux Embedder
fl_accessible_node.h File Reference
#include <atk/atk.h>
#include <gio/gio.h>
#include "flutter/shell/platform/embedder/embedder.h"
#include "flutter/shell/platform/linux/public/flutter_linux/fl_engine.h"

Go to the source code of this file.

Classes

struct  _FlAccessibleNodeClass
 

Functions

G_BEGIN_DECLS G_DECLARE_DERIVABLE_TYPE (FlAccessibleNode, fl_accessible_node, FL, ACCESSIBLE_NODE, AtkObject)
 
FlAccessibleNode * fl_accessible_node_new (FlEngine *engine, FlutterViewId view_id, int32_t node_id)
 
void fl_accessible_node_set_parent (FlAccessibleNode *node, AtkObject *parent, gint index)
 
void fl_accessible_node_set_children (FlAccessibleNode *node, GPtrArray *children)
 
: a node name.

fl_accessible_node_set_name: @node: an #FlAccessibleNode.

Sets the name of this node as reported to the a11y consumer.

void fl_accessible_node_set_name (FlAccessibleNode *node, const gchar *name)
 
void fl_accessible_node_set_extents (FlAccessibleNode *node, gint x, gint y, gint width, gint height)
 
void fl_accessible_node_set_flags (FlAccessibleNode *node, FlutterSemanticsFlags *flags)
 
void fl_accessible_node_set_actions (FlAccessibleNode *node, FlutterSemanticsAction actions)
 
void fl_accessible_node_set_value (FlAccessibleNode *node, const gchar *value)
 
void fl_accessible_node_set_text_selection (FlAccessibleNode *node, gint base, gint extent)
 
void fl_accessible_node_set_text_direction (FlAccessibleNode *node, FlutterTextDirection direction)
 
void fl_accessible_node_perform_action (FlAccessibleNode *node, FlutterSemanticsAction action, GBytes *data)
 

Function Documentation

◆ fl_accessible_node_new()

FlAccessibleNode* fl_accessible_node_new ( FlEngine *  engine,
FlutterViewId  view_id,
int32_t  node_id 
)

fl_accessible_node_new: @engine: the #FlEngine this node came from. @view_id: the view ID this object represents. @node_id: the semantics node ID this object represents.

Creates a new accessibility object that exposes Flutter accessibility information to ATK.

Returns: a new #FlAccessibleNode.

Definition at line 529 of file fl_accessible_node.cc.

531  {
532  FlAccessibleNode* self = FL_ACCESSIBLE_NODE(
533  g_object_new(fl_accessible_node_get_type(), "engine", engine, "view-id",
534  view_id, "node-id", node_id, nullptr));
535  return self;
536 }
G_BEGIN_DECLS FlutterViewId view_id

References view_id.

Referenced by create_node(), and TEST().

◆ fl_accessible_node_perform_action()

void fl_accessible_node_perform_action ( FlAccessibleNode *  node,
FlutterSemanticsAction  action,
GBytes *  data 
)

fl_accessible_node_dispatch_action: @node: an #FlAccessibleNode. @action: the action being dispatched. @data: (allow-none): data associated with the action.

Performs a semantic action for this node.

Definition at line 630 of file fl_accessible_node.cc.

632  {
633  g_return_if_fail(FL_IS_ACCESSIBLE_NODE(self));
634 
635  return FL_ACCESSIBLE_NODE_GET_CLASS(self)->perform_action(self, action, data);
636 }
FlutterSemanticsAction action

References action.

Referenced by fl_accessible_node_do_action(), fl_accessible_text_field_copy_text(), fl_accessible_text_field_cut_text(), fl_accessible_text_field_paste_text(), perform_set_selection_action(), and perform_set_text_action().

◆ fl_accessible_node_set_actions()

void fl_accessible_node_set_actions ( FlAccessibleNode *  node,
FlutterSemanticsAction  actions 
)

fl_accessible_node_set_actions: @node: an #FlAccessibleNode. @actions: the actions this node can perform.

Sets the actions that this node can perform.

Definition at line 600 of file fl_accessible_node.cc.

601  {
602  g_return_if_fail(FL_IS_ACCESSIBLE_NODE(self));
603 
604  return FL_ACCESSIBLE_NODE_GET_CLASS(self)->set_actions(self, actions);
605 }

Referenced by fl_view_accessible_handle_update_semantics(), and TEST().

◆ fl_accessible_node_set_children()

void fl_accessible_node_set_children ( FlAccessibleNode *  node,
GPtrArray *  children 
)

fl_accessible_node_set_children: @node: an #FlAccessibleNode. @children: (transfer none) (element-type AtkObject): a list of #AtkObject.

Sets the children of this node. The children can be changed at any time.

Definition at line 549 of file fl_accessible_node.cc.

550  {
551  g_return_if_fail(FL_IS_ACCESSIBLE_NODE(self));
553 
554  // Remove nodes that are no longer required.
555  for (guint i = 0; i < priv->children->len;) {
556  AtkObject* object = ATK_OBJECT(g_ptr_array_index(priv->children, i));
557  if (has_child(children, object)) {
558  i++;
559  } else {
560  g_signal_emit_by_name(self, "children-changed::remove", i, object,
561  nullptr);
562  g_ptr_array_remove_index(priv->children, i);
563  }
564  }
565 
566  // Add new nodes.
567  for (guint i = 0; i < children->len; i++) {
568  AtkObject* object = ATK_OBJECT(g_ptr_array_index(children, i));
569  if (!has_child(priv->children, object)) {
570  g_ptr_array_add(priv->children, g_object_ref(object));
571  g_signal_emit_by_name(self, "children-changed::add", i, object, nullptr);
572  }
573  }
574 }
static gboolean has_child(GPtrArray *children, AtkObject *object)
#define FL_ACCESSIBLE_NODE_GET_PRIVATE(node)
FlPixelBufferTexturePrivate * priv

References FL_ACCESSIBLE_NODE_GET_PRIVATE, has_child(), i, and priv.

Referenced by fl_view_accessible_handle_update_semantics(), and TEST().

◆ fl_accessible_node_set_extents()

void fl_accessible_node_set_extents ( FlAccessibleNode *  node,
gint  x,
gint  y,
gint  width,
gint  height 
)

fl_accessible_node_set_extents: @node: an #FlAccessibleNode. @x: x co-ordinate of this node relative to its parent. @y: y co-ordinate of this node relative to its parent. @width: width of this node in pixels. @height: height of this node in pixels.

Sets the position and size of this node.

Definition at line 582 of file fl_accessible_node.cc.

586  {
587  g_return_if_fail(FL_IS_ACCESSIBLE_NODE(self));
588 
589  return FL_ACCESSIBLE_NODE_GET_CLASS(self)->set_extents(self, x, y, width,
590  height);
591 }
const uint8_t uint32_t uint32_t * height
const uint8_t uint32_t * width

References height, and width.

Referenced by fl_view_accessible_handle_update_semantics(), and TEST().

◆ fl_accessible_node_set_flags()

void fl_accessible_node_set_flags ( FlAccessibleNode *  node,
FlutterSemanticsFlags *  flags 
)

fl_accessible_node_set_flags: @node: an #FlAccessibleNode. @flags: the flags for this node.

Sets the flags for this node.

Definition at line 593 of file fl_accessible_node.cc.

594  {
595  g_return_if_fail(FL_IS_ACCESSIBLE_NODE(self));
596 
597  return FL_ACCESSIBLE_NODE_GET_CLASS(self)->set_flags(self, flags);
598 }

Referenced by fl_view_accessible_handle_update_semantics(), and TEST().

◆ fl_accessible_node_set_name()

void fl_accessible_node_set_name ( FlAccessibleNode *  node,
const gchar *  name 
)

Definition at line 576 of file fl_accessible_node.cc.

576  {
577  g_return_if_fail(FL_IS_ACCESSIBLE_NODE(self));
578 
579  return FL_ACCESSIBLE_NODE_GET_CLASS(self)->set_name(self, name);
580 }

Referenced by fl_view_accessible_handle_update_semantics(), and TEST().

◆ fl_accessible_node_set_parent()

void fl_accessible_node_set_parent ( FlAccessibleNode *  node,
AtkObject *  parent,
gint  index 
)

fl_accessible_node_set_parent: @node: an #FlAccessibleNode. @parent: an #AtkObject. @index: the index of this node in the parent.

Sets the parent of this node. The parent can be changed at any time.

Definition at line 538 of file fl_accessible_node.cc.

540  {
541  g_return_if_fail(FL_IS_ACCESSIBLE_NODE(self));
543  priv->parent = parent;
544  priv->index = index;
545  g_object_add_weak_pointer(G_OBJECT(self),
546  reinterpret_cast<gpointer*>(&(priv->parent)));
547 }

References FL_ACCESSIBLE_NODE_GET_PRIVATE, and priv.

Referenced by fl_view_accessible_handle_update_semantics(), get_node(), and TEST().

◆ fl_accessible_node_set_text_direction()

void fl_accessible_node_set_text_direction ( FlAccessibleNode *  node,
FlutterTextDirection  direction 
)

fl_accessible_node_set_text_direction: @node: an #FlAccessibleNode. @direction: the direction of the text.

Sets the text direction of this node.

Definition at line 622 of file fl_accessible_node.cc.

623  {
624  g_return_if_fail(FL_IS_ACCESSIBLE_NODE(self));
625 
626  return FL_ACCESSIBLE_NODE_GET_CLASS(self)->set_text_direction(self,
627  direction);
628 }

Referenced by fl_view_accessible_handle_update_semantics().

◆ fl_accessible_node_set_text_selection()

void fl_accessible_node_set_text_selection ( FlAccessibleNode *  node,
gint  base,
gint  extent 
)

fl_accessible_node_set_text_selection: @node: an #FlAccessibleNode. @base: the position at which the text selection originates. @extent: the position at which the text selection terminates.

Sets the text selection of this node.

Definition at line 613 of file fl_accessible_node.cc.

615  {
616  g_return_if_fail(FL_IS_ACCESSIBLE_NODE(self));
617 
618  return FL_ACCESSIBLE_NODE_GET_CLASS(self)->set_text_selection(self, base,
619  extent);
620 }

Referenced by fl_view_accessible_handle_update_semantics(), and TEST().

◆ fl_accessible_node_set_value()

void fl_accessible_node_set_value ( FlAccessibleNode *  node,
const gchar *  value 
)

fl_accessible_node_set_value: @node: an #FlAccessibleNode. @value: a node value.

Sets the value of this node.

Definition at line 607 of file fl_accessible_node.cc.

607  {
608  g_return_if_fail(FL_IS_ACCESSIBLE_NODE(self));
609 
610  return FL_ACCESSIBLE_NODE_GET_CLASS(self)->set_value(self, value);
611 }
uint8_t value

References value.

Referenced by fl_view_accessible_handle_update_semantics(), and TEST().

◆ G_DECLARE_DERIVABLE_TYPE()

G_BEGIN_DECLS G_DECLARE_DERIVABLE_TYPE ( FlAccessibleNode  ,
fl_accessible_node  ,
FL  ,
ACCESSIBLE_NODE  ,
AtkObject   
)