Qt
Internal/Contributor docs for the Qt SDK. <b>Note:</b> These are NOT official API docs; those are found <a href='https://doc.qt.io/'>here</a>.
Loading...
Searching...
No Matches
qspi_constant_mappings.cpp
Go to the documentation of this file.
1// Copyright (C) 2016 The Qt Company Ltd.
2// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR LGPL-3.0-only OR GPL-2.0-only OR GPL-3.0-only
3
4
6
7#include <qobject.h>
8#include <qdebug.h>
9
10// FIXME the assignment of roles is quite arbitrary, at some point go through this list and sort and check that it makes sense
11// "calendar" "check menu item" "color chooser" "column header" "dateeditor" "desktop icon" "desktop frame"
12// "directory pane" "drawing area" "file chooser" "fontchooser" "frame" "glass pane" "html container" "icon"
13// "internal frame" "option pane" "password text" "radio menu item" "root pane" "row header" "scroll pane"
14// "tear off menu item" "terminal" "toggle button" "tree table" "unknown" "viewport" "header" "footer" "paragraph"
15// "ruler" "autocomplete" "edit bar" "embedded component" "entry" "caption"
16// "heading" "page" "section" "redundant object" "form" "input method window" "menu"
17
18#if QT_CONFIG(accessibility)
20
22{
23 quint64 spiState = 0;
24
25 if (state.active)
26 setSpiStateBit(&spiState, ATSPI_STATE_ACTIVE);
27 if (state.editable)
28 setSpiStateBit(&spiState, ATSPI_STATE_EDITABLE);
29 if (!state.disabled) {
30 setSpiStateBit(&spiState, ATSPI_STATE_ENABLED);
31 setSpiStateBit(&spiState, ATSPI_STATE_SENSITIVE);
32 }
33 if (state.selected)
34 setSpiStateBit(&spiState, ATSPI_STATE_SELECTED);
35 if (state.focused)
36 setSpiStateBit(&spiState, ATSPI_STATE_FOCUSED);
37 if (state.pressed)
38 setSpiStateBit(&spiState, ATSPI_STATE_PRESSED);
39 if (state.checkable)
40 setSpiStateBit(&spiState, ATSPI_STATE_CHECKABLE);
41 if (state.checked)
42 setSpiStateBit(&spiState, ATSPI_STATE_CHECKED);
43 if (state.checkStateMixed)
44 setSpiStateBit(&spiState, ATSPI_STATE_INDETERMINATE);
45 if (state.readOnly)
46 setSpiStateBit(&spiState, ATSPI_STATE_READ_ONLY);
47 // if (state.HotTracked)
48 if (state.defaultButton)
49 setSpiStateBit(&spiState, ATSPI_STATE_IS_DEFAULT);
50 if (state.expandable)
51 setSpiStateBit(&spiState, ATSPI_STATE_EXPANDABLE);
52 if (state.expanded)
53 setSpiStateBit(&spiState, ATSPI_STATE_EXPANDED);
54 if (state.collapsed)
55 setSpiStateBit(&spiState, ATSPI_STATE_COLLAPSED);
56 if (state.busy)
57 setSpiStateBit(&spiState, ATSPI_STATE_BUSY);
58 if (state.marqueed || state.animated)
59 setSpiStateBit(&spiState, ATSPI_STATE_ANIMATED);
60 if (!state.invisible && !state.offscreen) {
61 setSpiStateBit(&spiState, ATSPI_STATE_SHOWING);
62 setSpiStateBit(&spiState, ATSPI_STATE_VISIBLE);
63 }
64 if (state.sizeable)
65 setSpiStateBit(&spiState, ATSPI_STATE_RESIZABLE);
66 // if (state.Movable)
67 // if (state.SelfVoicing)
68 if (state.focusable)
69 setSpiStateBit(&spiState, ATSPI_STATE_FOCUSABLE);
70 if (state.selectable)
71 setSpiStateBit(&spiState, ATSPI_STATE_SELECTABLE);
72 // if (state.Linked)
73 if (state.traversed)
74 setSpiStateBit(&spiState, ATSPI_STATE_VISITED);
75 if (state.multiSelectable)
76 setSpiStateBit(&spiState, ATSPI_STATE_MULTISELECTABLE);
77 if (state.extSelectable)
78 setSpiStateBit(&spiState, ATSPI_STATE_SELECTABLE);
79 // if (state.Protected)
80 if (state.hasPopup)
81 setSpiStateBit(&spiState, ATSPI_STATE_HAS_POPUP);
82 if (state.modal)
83 setSpiStateBit(&spiState, ATSPI_STATE_MODAL);
84 if (state.multiLine)
85 setSpiStateBit(&spiState, ATSPI_STATE_MULTI_LINE);
86
87 return spiState;
88}
89
91{
92 uint low = states & 0xFFFFFFFF;
93 uint high = (states >> 32) & 0xFFFFFFFF;
94
95 QSpiUIntList stateList;
96 stateList.append(low);
97 stateList.append(high);
98 return stateList;
99}
100
101AtspiRelationType qAccessibleRelationToAtSpiRelation(QAccessible::Relation relation)
102{
103 // direction of the relation is "inversed" in Qt and AT-SPI
104 switch (relation) {
105 case QAccessible::Label:
106 return ATSPI_RELATION_LABELLED_BY;
107 case QAccessible::Labelled:
108 return ATSPI_RELATION_LABEL_FOR;
109 case QAccessible::Controller:
110 return ATSPI_RELATION_CONTROLLED_BY;
111 case QAccessible::Controlled:
112 return ATSPI_RELATION_CONTROLLER_FOR;
113 case QAccessible::DescriptionFor:
114 return ATSPI_RELATION_DESCRIBED_BY;
115 case QAccessible::Described:
116 return ATSPI_RELATION_DESCRIPTION_FOR;
117 case QAccessible::FlowsFrom:
118 return ATSPI_RELATION_FLOWS_TO;
119 case QAccessible::FlowsTo:
120 return ATSPI_RELATION_FLOWS_FROM;
121 default:
122 qWarning() << "Cannot return AT-SPI relation for:" << relation;
123 }
124 return ATSPI_RELATION_NULL;
125}
126
128#endif // QT_CONFIG(accessibility)
\inmodule QtGui
void append(parameter_type t)
Definition qlist.h:458
else opt state
[0]
Combined button and popup list for selecting options.
#define qWarning
Definition qlogging.h:166
GLuint * states
AtspiRelationType qAccessibleRelationToAtSpiRelation(QAccessible::Relation relation)
quint64 spiStatesFromQState(QAccessible::State state)
void setSpiStateBit(quint64 *state, AtspiStateType spiState)
QSpiUIntList spiStateSetFromSpiStates(quint64 states)
unsigned long long quint64
Definition qtypes.h:61
unsigned int uint
Definition qtypes.h:34