#[non_exhaustive]
pub enum StateType {
Show 44 variants
Invalid,
Active,
Armed,
Busy,
Checked,
Defunct,
Editable,
Enabled,
Expandable,
Expanded,
Focusable,
Focused,
Horizontal,
Iconified,
Modal,
MultiLine,
Multiselectable,
Opaque,
Pressed,
Resizable,
Selectable,
Selected,
Sensitive,
Showing,
SingleLine,
Stale,
Transient,
Vertical,
Visible,
ManagesDescendants,
Indeterminate,
Truncated,
Required,
InvalidEntry,
SupportsAutocompletion,
SelectableText,
Default,
Animated,
Visited,
Checkable,
HasPopup,
HasTooltip,
ReadOnly,
Collapsed,
// some variants omitted
}
Expand description
The possible types of states of an object
Variants (Non-exhaustive)
This enum is marked as non-exhaustive
Invalid
Indicates an invalid state - probably an error condition.
Active
Indicates a window is currently the active window, or an object is the active subelement within a container or table. ATK_STATE_ACTIVE should not be used for objects which have ATK_STATE_FOCUSABLE or ATK_STATE_SELECTABLE: Those objects should use ATK_STATE_FOCUSED and ATK_STATE_SELECTED respectively. ATK_STATE_ACTIVE is a means to indicate that an object which is not focusable and not selectable is the currently-active item within its parent container.
Armed
Indicates that the object is ‘armed’, i.e. will be activated by if a pointer button-release event occurs within its bounds. Buttons often enter this state when a pointer click occurs within their bounds, as a precursor to activation. ATK_STATE_ARMED has been deprecated since ATK-2.16 and should not be used in newly-written code.
Busy
Indicates the current object is busy, i.e. onscreen representation is in the process of changing, or the object is temporarily unavailable for interaction due to activity already in progress. This state may be used by implementors of Document to indicate that content loading is underway. It also may indicate other ‘pending’ conditions; clients may wish to interrogate this object when the ATK_STATE_BUSY flag is removed.
Checked
Indicates this object is currently checked, for instance a checkbox is ‘non-empty’.
Defunct
Indicates that this object no longer has a valid backing widget (for instance, if its peer object has been destroyed)
Editable
Indicates that this object can contain text, and that the
user can change the textual contents of this object by editing those contents
directly. For an object which is expected to be editable due to its type, but
which cannot be edited due to the application or platform preventing the user
from doing so, that object’s StateSet
should lack ATK_STATE_EDITABLE and
should contain ATK_STATE_READ_ONLY.
Enabled
Indicates that this object is enabled, i.e. that it currently reflects some application state. Objects that are “greyed out” may lack this state, and may lack the STATE_SENSITIVE if direct user interaction cannot cause them to acquire STATE_ENABLED. See also: ATK_STATE_SENSITIVE
Expandable
Indicates this object allows progressive disclosure of its children
Expanded
Indicates this object its expanded - see ATK_STATE_EXPANDABLE above
Focusable
Indicates this object can accept keyboard focus, which means all events resulting from typing on the keyboard will normally be passed to it when it has focus
Focused
Indicates this object currently has the keyboard focus
Horizontal
Indicates the orientation of this object is horizontal; used, for instance, by objects of ATK_ROLE_SCROLL_BAR. For objects where vertical/horizontal orientation is especially meaningful.
Iconified
Indicates this object is minimized and is represented only by an icon
Modal
Indicates something must be done with this object before the user can interact with an object in a different window
MultiLine
Indicates this (text) object can contain multiple lines of text
Multiselectable
Indicates this object allows more than one of its children to be selected at the same time, or in the case of text objects, that the object supports non-contiguous text selections.
Opaque
Indicates this object paints every pixel within its rectangular region.
Pressed
Indicates this object is currently pressed.
Resizable
Indicates the size of this object is not fixed
Selectable
Indicates this object is the child of an object that allows its children to be selected and that this child is one of those children that can be selected
Selected
Indicates this object is the child of an object that allows its children to be selected and that this child is one of those children that has been selected
Sensitive
Indicates this object is sensitive, e.g. to user interaction.
STATE_SENSITIVE usually accompanies STATE_ENABLED for user-actionable controls,
but may be found in the absence of STATE_ENABLED if the current visible state of the
control is “disconnected” from the application state. In such cases, direct user interaction
can often result in the object gaining STATE_SENSITIVE, for instance if a user makes
an explicit selection using an object whose current state is ambiguous or undefined.
see
STATE_ENABLED, STATE_INDETERMINATE.
Showing
Indicates this object, the object’s parent, the object’s parent’s parent, and so on, are all ‘shown’ to the end-user, i.e. subject to “exposure” if blocking or obscuring objects do not interpose between this object and the top of the window stack.
SingleLine
Indicates this (text) object can contain only a single line of text
Stale
Indicates that the information returned for this object may no longer be synchronized with the application state. This is implied if the object has STATE_TRANSIENT, and can also occur towards the end of the object peer’s lifecycle. It can also be used to indicate that the index associated with this object has changed since the user accessed the object (in lieu of “index-in-parent-changed” events).
Transient
Indicates this object is transient, i.e. a snapshot which may not emit events when its state changes. Data from objects with ATK_STATE_TRANSIENT should not be cached, since there may be no notification given when the cached data becomes obsolete.
Vertical
Indicates the orientation of this object is vertical
Visible
Indicates this object is visible, e.g. has been explicitly marked for exposure to the user.
note: Visible
is no guarantee that the object is actually unobscured on the screen, only
that it is ‘potentially’ visible, barring obstruction, being scrolled or clipped out of the
field of view, or having an ancestor container that has not yet made visible.
A widget is potentially onscreen if it has both Visible
and Showing
.
The absence of Visible
and Showing
is semantically equivalent to saying
that an object is ‘hidden’. See also Truncated
, which applies if an object with
Visible
and Showing
set lies within a viewport which means that its
contents are clipped, e.g. a truncated spreadsheet cell or
an image within a scrolling viewport. Mostly useful for screen-review and magnification
algorithms.
ManagesDescendants
Indicates that “active-descendant-changed” event is sent when children become ‘active’ (i.e. are selected or navigated to onscreen). Used to prevent need to enumerate all children in very large containers, like tables. The presence of STATE_MANAGES_DESCENDANTS is an indication to the client. that the children should not, and need not, be enumerated by the client. Objects implementing this state are expected to provide relevant state notifications to listening clients, for instance notifications of visibility changes and activation of their contained child objects, without the client having previously requested references to those children.
Indeterminate
Indicates that the value, or some other quantifiable property, of this AtkObject cannot be fully determined. In the case of a large data set in which the total number of items in that set is unknown (e.g. 1 of 999+), implementors should expose the currently-known set size (999) along with this state. In the case of a check box, this state should be used to indicate that the check box is a tri-state check box which is currently neither checked nor unchecked.
Truncated
Indicates that an object is truncated, e.g. a text value in a speradsheet cell.
Required
Indicates that explicit user interaction with an object is required by the user interface, e.g. a required field in a “web-form” interface.
InvalidEntry
Indicates that the object has encountered an error condition due to failure of input validation. For instance, a form control may acquire this state in response to invalid or malformed user input.
SupportsAutocompletion
Indicates that the object in question implements some form of ¨typeahead¨ or
pre-selection behavior whereby entering the first character of one or more sub-elements
causes those elements to scroll into view or become selected. Subsequent character input
may narrow the selection further as long as one or more sub-elements match the string.
This state is normally only useful and encountered on objects that implement Selection.
In some cases the typeahead behavior may result in full or partial ¨completion¨ of
the data in the input field, in which case these input events may trigger text-changed
events from the AtkText interface. This state supplants Role::Autocomplete
.
SelectableText
Indicates that the object in question supports text selection. It should only be exposed on objects which implement the Text interface, in order to distinguish this state from Selectable
, which infers that the object in question is a selectable child of an object which implements Selection. While similar, text selection and subelement selection are distinct operations.
Default
Indicates that the object is the “default” active component, i.e. the object which is activated by an end-user press of the “Enter” or “Return” key. Typically a “close” or “submit” button.
Animated
Indicates that the object changes its appearance dynamically as an inherent part of its presentation. This state may come and go if an object is only temporarily animated on the way to a ‘final’ onscreen presentation. note: some applications, notably content viewers, may not be able to detect all kinds of animated content. Therefore the absence of this state should not be taken as definitive evidence that the object’s visual representation is static; this state is advisory.
Visited
Indicates that the object (typically a hyperlink) has already been ‘activated’, and/or its backing data has already been downloaded, rendered, or otherwise “visited”.
Checkable
Indicates this object has the potential to be
checked, such as a checkbox or toggle-able table cell. Since
:
ATK-2.12
HasPopup
Indicates that the object has a popup context
menu or sub-level menu which may or may not be showing. This means
that activation renders conditional content. Note that ordinary
tooltips are not considered popups in this context. Since
: ATK-2.12
HasTooltip
Indicates this object has a tooltip. Since
: ATK-2.16
ReadOnly
Indicates that a widget which is ENABLED and SENSITIVE
has a value which can be read, but not modified, by the user. Note that this
state should only be applied to widget types whose value is normally directly
user modifiable, such as check boxes, radio buttons, spin buttons, text input
fields, and combo boxes, as a means to convey that the expected interaction
with that widget is not possible. When the expected interaction with a
widget does not include modification by the user, as is the case with
labels and containers, ATK_STATE_READ_ONLY should not be applied. See also
ATK_STATE_EDITABLE. Since
: ATK-2-16
Collapsed
v2_38
only.Indicates this object is collapsed. Since
: ATK-2.38
Implementations
Trait Implementations
sourceimpl<'a> FromValue<'a> for StateType
impl<'a> FromValue<'a> for StateType
type Checker = GenericValueTypeChecker<StateType>
type Checker = GenericValueTypeChecker<StateType>
sourceunsafe fn from_value(value: &'a Value) -> Self
unsafe fn from_value(value: &'a Value) -> Self
Value
. Read moresourceimpl Ord for StateType
impl Ord for StateType
1.21.0 · sourceconst fn max(self, other: Self) -> Self
const fn max(self, other: Self) -> Self
1.21.0 · sourceconst fn min(self, other: Self) -> Self
const fn min(self, other: Self) -> Self
1.50.0 · sourceconst fn clamp(self, min: Self, max: Self) -> Selfwhere
Self: PartialOrd<Self>,
const fn clamp(self, min: Self, max: Self) -> Selfwhere
Self: PartialOrd<Self>,
sourceimpl PartialOrd<StateType> for StateType
impl PartialOrd<StateType> for StateType
sourcefn partial_cmp(&self, other: &StateType) -> Option<Ordering>
fn partial_cmp(&self, other: &StateType) -> Option<Ordering>
1.0.0 · sourceconst fn le(&self, other: &Rhs) -> bool
const fn le(&self, other: &Rhs) -> bool
self
and other
) and is used by the <=
operator. Read moresourceimpl StaticType for StateType
impl StaticType for StateType
sourcefn static_type() -> Type
fn static_type() -> Type
Self
.impl Copy for StateType
impl Eq for StateType
impl StructuralEq for StateType
impl StructuralPartialEq for StateType
Auto Trait Implementations
impl RefUnwindSafe for StateType
impl Send for StateType
impl Sync for StateType
impl Unpin for StateType
impl UnwindSafe for StateType
Blanket Implementations
sourceimpl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
sourceimpl<T> StaticTypeExt for Twhere
T: StaticType,
impl<T> StaticTypeExt for Twhere
T: StaticType,
sourcefn ensure_type()
fn ensure_type()
sourceimpl<T> ToClosureReturnValue for Twhere
T: ToValue,
impl<T> ToClosureReturnValue for Twhere
T: ToValue,
fn to_closure_return_value(&self) -> Option<Value>
sourceimpl<T> ToSendValue for Twhere
T: Send + ToValue + ?Sized,
impl<T> ToSendValue for Twhere
T: Send + ToValue + ?Sized,
sourcefn to_send_value(&self) -> SendValue
fn to_send_value(&self) -> SendValue
SendValue
clone of self
.