Qt
Internal/Contributor docs for the Qt SDK. Note: These are NOT official API docs; those are found at https://doc.qt.io/
Loading...
Searching...
No Matches
qaccessible_base.h
Go to the documentation of this file.
1// Copyright (C) 2022 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#ifndef QACCESSIBLE_BASE_H
5#define QACCESSIBLE_BASE_H
6
7#include <QtGui/qtguiglobal.h>
8#if QT_CONFIG(accessibility)
9
10#if 0
11// QAccessible class is handled in qaccessible.h
12#pragma qt_sync_stop_processing
13#endif
14
15#include <QtCore/qobjectdefs.h>
16
17#include <cstring> // memset, memcmp
18
19QT_BEGIN_NAMESPACE
20
21class QAccessibleInterface;
22class QAccessibleEvent;
23class QTextCursor;
24
25class Q_GUI_EXPORT QAccessible
26{
27 Q_GADGET
28public:
29
30 enum Event {
31 SoundPlayed = 0x0001,
32 Alert = 0x0002,
33 ForegroundChanged = 0x0003,
34 MenuStart = 0x0004,
35 MenuEnd = 0x0005,
36 PopupMenuStart = 0x0006,
37 PopupMenuEnd = 0x0007,
38 ContextHelpStart = 0x000C,
39 ContextHelpEnd = 0x000D,
40 DragDropStart = 0x000E,
41 DragDropEnd = 0x000F,
42 DialogStart = 0x0010,
43 DialogEnd = 0x0011,
44 ScrollingStart = 0x0012,
45 ScrollingEnd = 0x0013,
46
47 MenuCommand = 0x0018,
48
49 // Values from IAccessible2
50 ActionChanged = 0x0101,
51 ActiveDescendantChanged = 0x0102,
52 AttributeChanged = 0x0103,
53 DocumentContentChanged = 0x0104,
54 DocumentLoadComplete = 0x0105,
55 DocumentLoadStopped = 0x0106,
56 DocumentReload = 0x0107,
57 HyperlinkEndIndexChanged = 0x0108,
58 HyperlinkNumberOfAnchorsChanged = 0x0109,
59 HyperlinkSelectedLinkChanged = 0x010A,
60 HypertextLinkActivated = 0x010B,
61 HypertextLinkSelected = 0x010C,
62 HyperlinkStartIndexChanged = 0x010D,
63 HypertextChanged = 0x010E,
64 HypertextNLinksChanged = 0x010F,
65 ObjectAttributeChanged = 0x0110,
66 PageChanged = 0x0111,
67 SectionChanged = 0x0112,
68 TableCaptionChanged = 0x0113,
69 TableColumnDescriptionChanged = 0x0114,
70 TableColumnHeaderChanged = 0x0115,
71 TableModelChanged = 0x0116,
72 TableRowDescriptionChanged = 0x0117,
73 TableRowHeaderChanged = 0x0118,
74 TableSummaryChanged = 0x0119,
75 TextAttributeChanged = 0x011A,
76 TextCaretMoved = 0x011B,
77 // TextChanged = 0x011C, is deprecated in IA2, use TextUpdated
78 TextColumnChanged = 0x011D,
79 TextInserted = 0x011E,
80 TextRemoved = 0x011F,
81 TextUpdated = 0x0120,
82 TextSelectionChanged = 0x0121,
83 VisibleDataChanged = 0x0122,
84
85 ObjectCreated = 0x8000,
86 ObjectDestroyed = 0x8001,
87 ObjectShow = 0x8002,
88 ObjectHide = 0x8003,
89 ObjectReorder = 0x8004,
90 Focus = 0x8005,
91 Selection = 0x8006,
92 SelectionAdd = 0x8007,
93 SelectionRemove = 0x8008,
94 SelectionWithin = 0x8009,
95 StateChanged = 0x800A,
96 LocationChanged = 0x800B,
97 NameChanged = 0x800C,
98 DescriptionChanged = 0x800D,
99 ValueChanged = 0x800E,
100 ParentChanged = 0x800F,
101 HelpChanged = 0x80A0,
102 DefaultActionChanged = 0x80B0,
103 AcceleratorChanged = 0x80C0,
104 Announcement = 0x80D0,
105 IdentifierChanged = 0x80E0,
106 RoleChanged = 0x80E1,
107
108 // was declared after AcceleratorChanged, without explicit value
109 InvalidEvent = AcceleratorChanged + 1,
110 };
111 Q_ENUM(Event)
112
113 // 64 bit enums seem hard on some platforms (windows...)
114 // which makes using a bit field a sensible alternative
115 struct State {
116 // http://msdn.microsoft.com/en-us/library/ms697270.aspx
117 quint64 disabled : 1; // used to be Unavailable
118 quint64 selected : 1;
119 quint64 focusable : 1;
120 quint64 focused : 1;
121 quint64 pressed : 1;
122 quint64 checkable : 1;
123 quint64 checked : 1;
124 quint64 checkStateMixed : 1; // used to be Mixed
125 quint64 readOnly : 1;
126 quint64 hotTracked : 1;
127 quint64 defaultButton : 1;
128 quint64 expanded : 1;
129 quint64 collapsed : 1;
130 quint64 busy : 1;
131 quint64 expandable : 1;
132 quint64 marqueed : 1;
133 quint64 animated : 1;
134 quint64 invisible : 1;
135 quint64 offscreen : 1;
136 quint64 sizeable : 1;
137 quint64 movable : 1;
138 quint64 selfVoicing : 1;
139 quint64 selectable : 1;
140 quint64 linked : 1;
141 quint64 traversed : 1;
142 quint64 multiSelectable : 1;
143 quint64 extSelectable : 1;
144 quint64 passwordEdit : 1; // used to be Protected
145 quint64 hasPopup : 1;
146 quint64 modal : 1;
147
148 // IA2 - we chose to not add some IA2 states for now
149 // Below the ones that seem helpful
150 quint64 active : 1;
151 quint64 invalid : 1; // = defunct
152 quint64 editable : 1;
153 quint64 multiLine : 1;
154 quint64 selectableText : 1;
155 quint64 supportsAutoCompletion : 1;
156
157 quint64 searchEdit : 1;
158
159 // quint64 horizontal : 1;
160 // quint64 vertical : 1;
161 // quint64 invalidEntry : 1;
162 // quint64 managesDescendants : 1;
163 // quint64 singleLine : 1; // we have multi line, this is redundant.
164 // quint64 stale : 1;
165 // quint64 transient : 1;
166 // quint64 pinned : 1;
167
168 // Apple - see http://mattgemmell.com/2010/12/19/accessibility-for-iphone-and-ipad-apps/
169 // quint64 playsSound : 1;
170 // quint64 summaryElement : 1;
171 // quint64 updatesFrequently : 1;
172 // quint64 adjustable : 1;
173 // more and not included here: http://developer.apple.com/library/mac/#documentation/UserExperience/Reference/Accessibility_RoleAttribute_Ref/Attributes.html
174
175 // MSAA
176 // quint64 alertLow : 1;
177 // quint64 alertMedium : 1;
178 // quint64 alertHigh : 1;
179
180 State() {
181 std::memset(this, 0, sizeof(State));
182 }
183 friend inline bool operator==(const QAccessible::State &first, const QAccessible::State &second)
184 {
185 return std::memcmp(&first, &second, sizeof(QAccessible::State)) == 0;
186 }
187 };
188
189
190
191
192
193 enum Role {
194 NoRole = 0x00000000,
195 TitleBar = 0x00000001,
196 MenuBar = 0x00000002,
197 ScrollBar = 0x00000003,
198 Grip = 0x00000004,
199 Sound = 0x00000005,
200 Cursor = 0x00000006,
201 Caret = 0x00000007,
202 AlertMessage = 0x00000008,
203 Window = 0x00000009,
204 Client = 0x0000000A,
205 PopupMenu = 0x0000000B,
206 MenuItem = 0x0000000C,
207 ToolTip = 0x0000000D,
208 Application = 0x0000000E,
209 Document = 0x0000000F,
210 Pane = 0x00000010,
211 Chart = 0x00000011,
212 Dialog = 0x00000012,
213 Border = 0x00000013,
214 Grouping = 0x00000014,
215 Separator = 0x00000015,
216 ToolBar = 0x00000016,
217 StatusBar = 0x00000017,
218 Table = 0x00000018,
219 ColumnHeader = 0x00000019,
220 RowHeader = 0x0000001A,
221 Column = 0x0000001B,
222 Row = 0x0000001C,
223 Cell = 0x0000001D,
224 Link = 0x0000001E,
225 HelpBalloon = 0x0000001F,
226 Assistant = 0x00000020,
227 List = 0x00000021,
228 ListItem = 0x00000022,
229 Tree = 0x00000023,
230 TreeItem = 0x00000024,
231 PageTab = 0x00000025,
232 PropertyPage = 0x00000026,
233 Indicator = 0x00000027,
234 Graphic = 0x00000028,
235 StaticText = 0x00000029,
236 EditableText = 0x0000002A, // Editable, selectable, etc.
237 Button = 0x0000002B,
238#ifndef Q_QDOC
239 PushButton = Button, // deprecated
240#endif
241 CheckBox = 0x0000002C,
242 RadioButton = 0x0000002D,
243 ComboBox = 0x0000002E,
244 // DropList = 0x0000002F,
245 ProgressBar = 0x00000030,
246 Dial = 0x00000031,
247 HotkeyField = 0x00000032,
248 Slider = 0x00000033,
249 SpinBox = 0x00000034,
250 Canvas = 0x00000035, // MSAA: ROLE_SYSTEM_DIAGRAM - The object represents a graphical image that is used to diagram data.
251 Animation = 0x00000036,
252 Equation = 0x00000037,
253 ButtonDropDown = 0x00000038, // The object represents a button that expands a grid.
254 ButtonMenu = 0x00000039,
255 ButtonDropGrid = 0x0000003A,
256 Whitespace = 0x0000003B, // The object represents blank space between other objects.
257 PageTabList = 0x0000003C,
258 Clock = 0x0000003D,
259 Splitter = 0x0000003E,
260 // Reserved space in case MSAA roles needs to be added
261
262 // Additional Qt roles where enum value does not map directly to MSAA:
263 LayeredPane = 0x00000080,
264 Terminal = 0x00000081,
265 Desktop = 0x00000082,
266 Paragraph = 0x00000083,
267 WebDocument = 0x00000084,
268 Section = 0x00000085,
269 Notification = 0x00000086,
270
271 // IAccessible2 roles
272 // IA2_ROLE_CANVAS = 0x401, // An object that can be drawn into and to manage events from the objects drawn into it
273 // IA2_ROLE_CAPTION = 0x402,
274 // IA2_ROLE_CHECK_MENU_ITEM = 0x403,
275 ColorChooser = 0x404,
276 // IA2_ROLE_DATE_EDITOR = 0x405,
277 // IA2_ROLE_DESKTOP_ICON = 0x406,
278 // IA2_ROLE_DESKTOP_PANE = 0x407,
279 // IA2_ROLE_DIRECTORY_PANE = 0x408,
280 // IA2_ROLE_EDITBAR = 0x409,
281 // IA2_ROLE_EMBEDDED_OBJECT = 0x40A,
282 // IA2_ROLE_ENDNOTE = 0x40B,
283 // IA2_ROLE_FILE_CHOOSER = 0x40C,
284 // IA2_ROLE_FONT_CHOOSER = 0x40D,
285 Footer = 0x40E,
286 // IA2_ROLE_FOOTNOTE = 0x40F,
287 Form = 0x410,
288 // some platforms (windows and at-spi) use Frame for regular windows
289 // because window was taken for tool/dock windows by MSAA
290 // Frame = 0x411,
291 // IA2_ROLE_GLASS_PANE = 0x412,
292 // IA2_ROLE_HEADER = 0x413,
293 Heading = 0x414,
294 // IA2_ROLE_ICON = 0x415,
295 // IA2_ROLE_IMAGE_MAP = 0x416,
296 // IA2_ROLE_INPUT_METHOD_WINDOW = 0x417,
297 // IA2_ROLE_INTERNAL_FRAME = 0x418,
298 // IA2_ROLE_LABEL = 0x419,
299 // IA2_ROLE_LAYERED_PANE = 0x41A,
300 Note = 0x41B,
301 // IA2_ROLE_OPTION_PANE = 0x41C,
302 // IA2_ROLE_PAGE = 0x41D,
303 // IA2_ROLE_PARAGRAPH = 0x42E,
304 // IA2_ROLE_RADIO_MENU_ITEM = 0x41F,
305 // IA2_ROLE_REDUNDANT_OBJECT = 0x420,
306 // IA2_ROLE_ROOT_PANE = 0x421,
307 // IA2_ROLE_RULER = 0x422,
308 // IA2_ROLE_SCROLL_PANE = 0x423,
309 // IA2_ROLE_SECTION = 0x424,
310 // IA2_ROLE_SHAPE = 0x425,
311 // IA2_ROLE_SPLIT_PANE = 0x426,
312 // IA2_ROLE_TEAR_OFF_MENU = 0x427,
313 // IA2_ROLE_TERMINAL = 0x428,
314 // IA2_ROLE_TEXT_FRAME = 0x429,
315 // IA2_ROLE_TOGGLE_BUTTON = 0x42A,
316 // IA2_ROLE_VIEW_PORT = 0x42B,
317 ComplementaryContent = 0x42C,
318 // IA2_ROLE_LANDMARK = 0x42D,
319 // IA2_ROLE_LEVEL_BAR = 0x42E,
320 // IA2_ROLE_CONTENT_DELETION = 0x42F,
321 // IA2_ROLE_CONTENT_INSERTION = 0x430,
322 BlockQuote = 0x431,
323 // IA2_ROLE_MARK = 0x432,
324 // IA2_ROLE_SUGGESTION = 0x433,
325 // IA2_ROLE_COMMENT = = 0x434,
326
327 UserRole = 0x0000ffff
328 };
329 Q_ENUM(Role)
330
331 enum Text {
332 Name = 0,
333 Description,
334 Value,
335 Help,
336 Accelerator,
337 DebugDescription,
338 Identifier,
339 UserText = 0x0000ffff
340 };
341
342 enum RelationFlag {
343 Label = 0x00000001,
344 Labelled = 0x00000002,
345 Controller = 0x00000004,
346 Controlled = 0x00000008,
347 DescriptionFor = 0x00000010,
348 Described = 0x00000020,
349 FlowsFrom = 0x00000040,
350 FlowsTo = 0x00000080,
351 AllRelations = 0xffffffff
352 };
353 Q_DECLARE_FLAGS(Relation, RelationFlag)
354
355 enum InterfaceType
356 {
357 TextInterface,
358 EditableTextInterface,
359 ValueInterface,
360 ActionInterface,
361 ImageInterface,
362 TableInterface,
363 TableCellInterface,
364 HyperlinkInterface,
365 SelectionInterface,
366 AttributesInterface,
367 };
368
369 enum TextBoundaryType {
370 CharBoundary,
371 WordBoundary,
372 SentenceBoundary,
373 ParagraphBoundary,
374 LineBoundary,
375 NoBoundary
376 };
377
378 enum class Attribute {
379 Custom,
380 Level,
381 Locale,
382 };
383 Q_ENUM(Attribute)
384
385 enum class AnnouncementPoliteness {
386 Polite,
387 Assertive,
388 };
389 Q_ENUM(AnnouncementPoliteness)
390
391 typedef QAccessibleInterface*(*InterfaceFactory)(const QString &key, QObject*);
392 typedef void(*UpdateHandler)(QAccessibleEvent *event);
393 typedef void(*RootObjectHandler)(QObject*);
394
395 typedef unsigned Id;
396
397 static void installFactory(InterfaceFactory);
398 static void removeFactory(InterfaceFactory);
399 static UpdateHandler installUpdateHandler(UpdateHandler);
400 static RootObjectHandler installRootObjectHandler(RootObjectHandler);
401
402 class Q_GUI_EXPORT ActivationObserver
403 {
404 public:
405 virtual ~ActivationObserver();
406 virtual void accessibilityActiveChanged(bool active) = 0;
407 };
408 static void installActivationObserver(ActivationObserver *);
409 static void removeActivationObserver(ActivationObserver *);
410
411 static QAccessibleInterface *queryAccessibleInterface(QObject *);
412 static Id uniqueId(QAccessibleInterface *iface);
413 static QAccessibleInterface *accessibleInterface(Id uniqueId);
414 static Id registerAccessibleInterface(QAccessibleInterface *iface);
415 static void deleteAccessibleInterface(Id uniqueId);
416
417 static void updateAccessibility(QAccessibleEvent *event);
418
419 static bool isActive();
420 static void setActive(bool active);
421 static void setRootObject(QObject *object);
422
423 static void cleanup();
424
425 static std::pair< int, int > qAccessibleTextBoundaryHelper(const QTextCursor &cursor, TextBoundaryType boundaryType);
426
427private:
428 static UpdateHandler updateHandler;
429 static RootObjectHandler rootObjectHandler;
430
431 QAccessible() {}
432
433 friend class QAccessibleCache;
434};
435
436Q_DECLARE_OPERATORS_FOR_FLAGS(QAccessible::Relation)
437
438QT_END_NAMESPACE
439
440#endif // QT_CONFIG(accessibility)
441#endif // QACCESSIBLE_BASE_H