pub struct FrozenNode {
pub(crate) role: Role,
pub(crate) actions: u32,
pub(crate) flags: u32,
pub(crate) properties: FrozenProperties,
}
Expand description
An accessibility node snapshot that can’t be modified. This is not used by
toolkits or applications, but only by code that retains an AccessKit tree
in memory, such as the accesskit_consumer
crate.
Fields§
§role: Role
§actions: u32
§flags: u32
§properties: FrozenProperties
Implementations§
§impl FrozenNode
impl FrozenNode
§impl FrozenNode
impl FrozenNode
pub fn supports_action(&self, action: Action) -> bool
§impl FrozenNode
impl FrozenNode
Exclude this node and its descendants from the tree presented to assistive technologies, and from hit testing.
pub fn is_linked(&self) -> bool
pub fn is_multiselectable(&self) -> bool
pub fn is_required(&self) -> bool
pub fn is_visited(&self) -> bool
pub fn is_busy(&self) -> bool
pub fn is_live_atomic(&self) -> bool
pub fn is_touch_transparent(&self) -> bool
pub fn is_touch_transparent(&self) -> bool
This element allows touches to be passed through when a screen reader is in touch exploration mode, e.g. a virtual keyboard normally behaves this way.
pub fn is_read_only(&self) -> bool
pub fn is_read_only(&self) -> bool
Use for a text widget that allows focus/selection but not input.
pub fn is_disabled(&self) -> bool
pub fn is_disabled(&self) -> bool
Use for a control or group of controls that disallows input.
pub fn is_bold(&self) -> bool
pub fn is_italic(&self) -> bool
pub fn clips_children(&self) -> bool
pub fn clips_children(&self) -> bool
Indicates that this node clips its children, i.e. may have
overflow: hidden
or clip children by default.
pub fn is_line_breaking_object(&self) -> bool
pub fn is_line_breaking_object(&self) -> bool
Indicates whether this node causes a hard line-break
(e.g. block level elements, or <br>
).
pub fn is_page_breaking_object(&self) -> bool
pub fn is_page_breaking_object(&self) -> bool
Indicates whether this node causes a page break.
pub fn is_spelling_error(&self) -> bool
pub fn is_grammar_error(&self) -> bool
pub fn is_search_match(&self) -> bool
pub fn is_suggestion(&self) -> bool
§impl FrozenNode
impl FrozenNode
§impl FrozenNode
impl FrozenNode
§impl FrozenNode
impl FrozenNode
§impl FrozenNode
impl FrozenNode
pub fn described_by(&self) -> &[NodeId]
§impl FrozenNode
impl FrozenNode
§impl FrozenNode
impl FrozenNode
pub fn labelled_by(&self) -> &[NodeId]
§impl FrozenNode
impl FrozenNode
pub fn owns(&self) -> &[NodeId]
pub fn owns(&self) -> &[NodeId]
As with the aria-owns
property in ARIA, this property should be set
only if the nodes referenced in the property are not descendants
of the owning node in the AccessKit tree. In the common case, where the
owned nodes are direct children or indirect descendants, this property
is unnecessary.
§impl FrozenNode
impl FrozenNode
pub fn radio_group(&self) -> &[NodeId]
pub fn radio_group(&self) -> &[NodeId]
On radio buttons this should be set to a list of all of the buttons in the same group as this one, including this radio button itself.
§impl FrozenNode
impl FrozenNode
pub fn active_descendant(&self) -> Option<NodeId>
§impl FrozenNode
impl FrozenNode
pub fn error_message(&self) -> Option<NodeId>
§impl FrozenNode
impl FrozenNode
pub fn in_page_link_target(&self) -> Option<NodeId>
§impl FrozenNode
impl FrozenNode
§impl FrozenNode
impl FrozenNode
pub fn next_on_line(&self) -> Option<NodeId>
§impl FrozenNode
impl FrozenNode
pub fn previous_on_line(&self) -> Option<NodeId>
§impl FrozenNode
impl FrozenNode
§impl FrozenNode
impl FrozenNode
pub fn label(&self) -> Option<&str>
pub fn label(&self) -> Option<&str>
The label of a control that can have a label. If the label is specified
via the Node::labelled_by
relation, this doesn’t need to be set.
Note that the text content of a node with the Role::Label
role
should be provided via Node::value
, not this property.
§impl FrozenNode
impl FrozenNode
pub fn description(&self) -> Option<&str>
§impl FrozenNode
impl FrozenNode
§impl FrozenNode
impl FrozenNode
pub fn access_key(&self) -> Option<&str>
pub fn access_key(&self) -> Option<&str>
A single character, usually part of this node’s name, that can be pressed,
possibly along with a platform-specific modifier, to perform
this node’s default action. For menu items, the access key is only active
while the menu is active, in contrast with keyboard_shortcut
;
a single menu item may in fact have both properties.
§impl FrozenNode
impl FrozenNode
A way for application authors to identify this node for automated testing purpose. The value must be unique among this node’s siblings.
§impl FrozenNode
impl FrozenNode
pub fn class_name(&self) -> Option<&str>
§impl FrozenNode
impl FrozenNode
pub fn font_family(&self) -> Option<&str>
pub fn font_family(&self) -> Option<&str>
Only present when different from parent.
§impl FrozenNode
impl FrozenNode
§impl FrozenNode
impl FrozenNode
pub fn inner_html(&self) -> Option<&str>
pub fn inner_html(&self) -> Option<&str>
Inner HTML of an element. Only used for a top-level math element, to support third-party math accessibility products that parse MathML.
§impl FrozenNode
impl FrozenNode
pub fn keyboard_shortcut(&self) -> Option<&str>
pub fn keyboard_shortcut(&self) -> Option<&str>
A keystroke or sequence of keystrokes, complete with any required modifiers(s), that will perform this node’s default action. The value of this property should be in a human-friendly format.
§impl FrozenNode
impl FrozenNode
§impl FrozenNode
impl FrozenNode
pub fn placeholder(&self) -> Option<&str>
pub fn placeholder(&self) -> Option<&str>
If a text input has placeholder text, it should be exposed
through this property rather than label
.
§impl FrozenNode
impl FrozenNode
pub fn role_description(&self) -> Option<&str>
pub fn role_description(&self) -> Option<&str>
An optional string that may override an assistive technology’s description of the node’s role. Only provide this for custom control types. The value of this property should be in a human-friendly, localized format.
§impl FrozenNode
impl FrozenNode
pub fn state_description(&self) -> Option<&str>
pub fn state_description(&self) -> Option<&str>
An optional string that may override an assistive technology’s description of the node’s state, replacing default strings such as “checked” or “selected”. Note that most platform accessibility APIs and assistive technologies do not support this feature.
§impl FrozenNode
impl FrozenNode
§impl FrozenNode
impl FrozenNode
§impl FrozenNode
impl FrozenNode
pub fn row_index_text(&self) -> Option<&str>
§impl FrozenNode
impl FrozenNode
pub fn column_index_text(&self) -> Option<&str>
§impl FrozenNode
impl FrozenNode
§impl FrozenNode
impl FrozenNode
pub fn scroll_x_min(&self) -> Option<f64>
§impl FrozenNode
impl FrozenNode
pub fn scroll_x_max(&self) -> Option<f64>
§impl FrozenNode
impl FrozenNode
§impl FrozenNode
impl FrozenNode
pub fn scroll_y_min(&self) -> Option<f64>
§impl FrozenNode
impl FrozenNode
pub fn scroll_y_max(&self) -> Option<f64>
§impl FrozenNode
impl FrozenNode
pub fn numeric_value(&self) -> Option<f64>
§impl FrozenNode
impl FrozenNode
pub fn min_numeric_value(&self) -> Option<f64>
§impl FrozenNode
impl FrozenNode
pub fn max_numeric_value(&self) -> Option<f64>
§impl FrozenNode
impl FrozenNode
pub fn numeric_value_step(&self) -> Option<f64>
§impl FrozenNode
impl FrozenNode
pub fn numeric_value_jump(&self) -> Option<f64>
§impl FrozenNode
impl FrozenNode
§impl FrozenNode
impl FrozenNode
pub fn font_weight(&self) -> Option<f64>
pub fn font_weight(&self) -> Option<f64>
Font weight can take on any arbitrary numeric value. Increments of 100 in
range [0, 900]
represent keywords such as light, normal, bold, etc.
§impl FrozenNode
impl FrozenNode
§impl FrozenNode
impl FrozenNode
pub fn column_count(&self) -> Option<usize>
§impl FrozenNode
impl FrozenNode
§impl FrozenNode
impl FrozenNode
pub fn column_index(&self) -> Option<usize>
§impl FrozenNode
impl FrozenNode
§impl FrozenNode
impl FrozenNode
pub fn column_span(&self) -> Option<usize>
§impl FrozenNode
impl FrozenNode
§impl FrozenNode
impl FrozenNode
pub fn size_of_set(&self) -> Option<usize>
§impl FrozenNode
impl FrozenNode
pub fn position_in_set(&self) -> Option<usize>
§impl FrozenNode
impl FrozenNode
pub fn color_value(&self) -> Option<u32>
pub fn color_value(&self) -> Option<u32>
For Role::ColorWell
, specifies the selected color in RGBA.
§impl FrozenNode
impl FrozenNode
pub fn background_color(&self) -> Option<u32>
pub fn background_color(&self) -> Option<u32>
Background color in RGBA.
§impl FrozenNode
impl FrozenNode
pub fn foreground_color(&self) -> Option<u32>
pub fn foreground_color(&self) -> Option<u32>
Foreground color in RGBA.
§impl FrozenNode
impl FrozenNode
pub fn overline(&self) -> Option<TextDecoration>
§impl FrozenNode
impl FrozenNode
pub fn strikethrough(&self) -> Option<TextDecoration>
§impl FrozenNode
impl FrozenNode
pub fn underline(&self) -> Option<TextDecoration>
§impl FrozenNode
impl FrozenNode
pub fn character_lengths(&self) -> &[u8] ⓘ
pub fn character_lengths(&self) -> &[u8] ⓘ
For text runs, the length (non-inclusive) of each character
in UTF-8 code units (bytes). The sum of these lengths must equal
the length of value
, also in bytes.
A character is defined as the smallest unit of text that can be selected. This isn’t necessarily a single Unicode scalar value (code point). This is why AccessKit can’t compute the lengths of the characters from the text itself; this information must be provided by the text editing implementation.
If this node is the last text run in a line that ends with a hard line break, that line break should be included at the end of this node’s value as either a CRLF or LF; in both cases, the line break should be counted as a single character for the sake of this slice. When the caret is at the end of such a line, the focus of the text selection should be on the line break, not after it.
§impl FrozenNode
impl FrozenNode
pub fn word_lengths(&self) -> &[u8] ⓘ
pub fn word_lengths(&self) -> &[u8] ⓘ
For text runs, the length of each word in characters, as defined
in character_lengths
. The sum of these lengths must equal
the length of character_lengths
.
The end of each word is the beginning of the next word; there are no characters that are not considered part of a word. Trailing whitespace is typically considered part of the word that precedes it, while a line’s leading whitespace is considered its own word. Whether punctuation is considered a separate word or part of the preceding word depends on the particular text editing implementation. Some editors may have their own definition of a word; for example, in an IDE, words may correspond to programming language tokens.
Not all assistive technologies require information about word boundaries, and not all platform accessibility APIs even expose this information, but for assistive technologies that do use this information, users will get unpredictable results if the word boundaries exposed by the accessibility tree don’t match the editor’s behavior. This is why AccessKit does not determine word boundaries itself.
§impl FrozenNode
impl FrozenNode
pub fn character_positions(&self) -> Option<&[f32]>
pub fn character_positions(&self) -> Option<&[f32]>
For text runs, this is the position of each character within
the node’s bounding box, in the direction given by
text_direction
, in the coordinate space of this node.
When present, the length of this slice should be the same as the length
of character_lengths
, including for lines that end
with a hard line break. The position of such a line break should
be the position where an end-of-paragraph marker would be rendered.
This property is optional. Without it, AccessKit can’t support some use cases, such as screen magnifiers that track the caret position or screen readers that display a highlight cursor. However, most text functionality still works without this information.
§impl FrozenNode
impl FrozenNode
pub fn character_widths(&self) -> Option<&[f32]>
pub fn character_widths(&self) -> Option<&[f32]>
For text runs, this is the advance width of each character,
in the direction given by text_direction
, in the coordinate
space of this node.
When present, the length of this slice should be the same as the length
of character_lengths
, including for lines that end
with a hard line break. The width of such a line break should
be non-zero if selecting the line break by itself results in
a visible highlight (as in Microsoft Word), or zero if not
(as in Windows Notepad).
This property is optional. Without it, AccessKit can’t support some use cases, such as screen magnifiers that track the caret position or screen readers that display a highlight cursor. However, most text functionality still works without this information.
§impl FrozenNode
impl FrozenNode
pub fn is_expanded(&self) -> Option<bool>
pub fn is_expanded(&self) -> Option<bool>
Whether this node is expanded, collapsed, or neither.
Setting this to false
means the node is collapsed; omitting it means this state
isn’t applicable.
§impl FrozenNode
impl FrozenNode
pub fn is_selected(&self) -> Option<bool>
pub fn is_selected(&self) -> Option<bool>
Indicates whether this node is selected or unselected.
The absence of this flag (as opposed to a false
setting)
means that the concept of “selected” doesn’t apply.
When deciding whether to set the flag to false or omit it,
consider whether it would be appropriate for a screen reader
to announce “not selected”. The ambiguity of this flag
in platform accessibility APIs has made extraneous
“not selected” announcements a common annoyance.
§impl FrozenNode
impl FrozenNode
pub fn invalid(&self) -> Option<Invalid>
pub fn toggled(&self) -> Option<Toggled>
pub fn live(&self) -> Option<Live>
pub fn text_direction(&self) -> Option<TextDirection>
pub fn orientation(&self) -> Option<Orientation>
pub fn sort_direction(&self) -> Option<SortDirection>
pub fn aria_current(&self) -> Option<AriaCurrent>
pub fn auto_complete(&self) -> Option<AutoComplete>
pub fn has_popup(&self) -> Option<HasPopup>
pub fn list_style(&self) -> Option<ListStyle>
pub fn list_style(&self) -> Option<ListStyle>
The list style type. Only available on list items.
pub fn text_align(&self) -> Option<TextAlign>
pub fn vertical_offset(&self) -> Option<VerticalOffset>
§impl FrozenNode
impl FrozenNode
pub fn transform(&self) -> Option<&Affine>
pub fn transform(&self) -> Option<&Affine>
An affine transform to apply to any coordinates within this node
and its descendants, including the bounds
property of this node.
The combined transforms of this node and its ancestors define
the coordinate space of this node. /// This should be None
if
it would be set to the identity transform, which should be the case
for most nodes.
AccessKit expects the final transformed coordinates to be relative to the origin of the tree’s container (e.g. window), in physical pixels, with the y coordinate being top-down.
pub fn bounds(&self) -> Option<Rect>
pub fn bounds(&self) -> Option<Rect>
The bounding box of this node, in the node’s coordinate space.
This property does not affect the coordinate space of either this node
or its descendants; only the transform
property affects that.
This, along with the recommendation that most nodes should have
a transform
of None
, implies that the bounds
property
of most nodes should be in the coordinate space of the nearest ancestor
with a non-None
transform
, or if there is no such ancestor,
the tree’s container (e.g. window).
pub fn text_selection(&self) -> Option<&TextSelection>
§impl FrozenNode
impl FrozenNode
pub fn custom_actions(&self) -> &[CustomAction]
Trait Implementations§
§impl Clone for FrozenNode
impl Clone for FrozenNode
§fn clone(&self) -> FrozenNode
fn clone(&self) -> FrozenNode
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read more§impl Debug for FrozenNode
impl Debug for FrozenNode
§impl From<Node> for FrozenNode
impl From<Node> for FrozenNode
§fn from(node: Node) -> FrozenNode
fn from(node: Node) -> FrozenNode
§impl PartialEq for FrozenNode
impl PartialEq for FrozenNode
§fn eq(&self, other: &FrozenNode) -> bool
fn eq(&self, other: &FrozenNode) -> bool
self
and other
values to be equal, and is used
by ==
.impl StructuralPartialEq for FrozenNode
Auto Trait Implementations§
impl Freeze for FrozenNode
impl RefUnwindSafe for FrozenNode
impl Send for FrozenNode
impl Sync for FrozenNode
impl Unpin for FrozenNode
impl UnwindSafe for FrozenNode
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
source§impl<T> CheckedAs for T
impl<T> CheckedAs for T
source§fn checked_as<Dst>(self) -> Option<Dst>where
T: CheckedCast<Dst>,
fn checked_as<Dst>(self) -> Option<Dst>where
T: CheckedCast<Dst>,
source§impl<Src, Dst> CheckedCastFrom<Src> for Dstwhere
Src: CheckedCast<Dst>,
impl<Src, Dst> CheckedCastFrom<Src> for Dstwhere
Src: CheckedCast<Dst>,
source§fn checked_cast_from(src: Src) -> Option<Dst>
fn checked_cast_from(src: Src) -> Option<Dst>
§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Box<dyn Trait>
(where Trait: Downcast
) to Box<dyn Any>
. Box<dyn Any>
can
then be further downcast
into Box<ConcreteType>
where ConcreteType
implements Trait
.§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Rc<Trait>
(where Trait: Downcast
) to Rc<Any>
. Rc<Any>
can then be
further downcast
into Rc<ConcreteType>
where ConcreteType
implements Trait
.§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
&Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &Any
’s vtable from &Trait
’s.§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
&mut Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &mut Any
’s vtable from &mut Trait
’s.§impl<T> DowncastSync for T
impl<T> DowncastSync for T
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
source§impl<T> IntoEither for T
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moresource§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
T
in a tonic::Request