NVDA屏幕阅读器请求错误的QAccessible::InterfaceType
NVDA screen reader requests wrong QAccessible::InterfaceType
我在Qt 5.9.1上。
我正在尝试通过屏幕阅读器访问应用程序。我有一个自定义小部件(我们称之为MyWidget
),其中包含文本(很多)。文本是使用QPainter
绘制的,这就是为什么使用自定义小部件而不是像QTextBrowser
这样的东西。
我在派生自QAccessibleWidget
和QAccessibleTextInterface
的AccessibleMyWidget
类中实现了小部件的QAccessibleTextInterface
。它在Linux下的Orca上运行良好,但是当在带有NVDA的Windows 7中使用时,QAccessibleInterface::interface_cast()
请求错误的接口类型。对于逆戟鲸,我收到了QAccessible::TextInterface
的请求。在NVDA中,它总是QAccessible::ValueInterface
。
AccessibleMyWidget
定义为:
class AccessibleMyWidget:
public QAccessibleWidget, public QAccessibleTextInterface {
public:
explicit AccessibleMyWidget(QWidget* w)
: QAccessibleWidget(w, QAccessible::EditableText)
{
Q_ASSERT(isValid());
}
void* interface_cast(QAccessible::InterfaceType t) override
{
if (t == QAccessible::TextInterface) {
// !!! This is never requested with NVDA !!!
return static_cast<QAccessibleTextInterface*>(this);
}
return QAccessibleWidget::interface_cast(t);
}
/*
* QAccessibleTextInterface implementation below this point.
*/
void addSelection(int startOffset, int endOffset) override;
QString attributes(int offset, int* startOffset,
int* endOffset) const override;
// etc.
};
在Linux下使用Orca,一切似乎都按预期工作。我接到interface_cast()
TextInterface
的调用,之后调用QAccessibleTextInterface
的各种函数。使用Linux下的NVDA,我只收到interface_cast()
ValueInterface
调用,并且没有调用任何QAccessibleTextInterface
函数。这意味着MyWidget
是完全无法访问的,除非我覆盖QAccessibleWidget::text()
并将所有文本作为单个字符串返回,这意味着没有光标导航,没有选择支持......在这一点上,它基本上变成了一个QLabel
,但有大量的文本,因此很难使用。
我在这里错过了什么?
好吧,NVDA开发人员帮助我追踪了这个问题。这是因为MinGW版本的Qt禁用了IAccessible2,并使用MSAA(Microsoft Active Accessibility),它不支持任何这些接口。IA2需要COM,而MinGW不支持。
所以我必须从GCC/MinGW切换到MSVC才能在Windows上完成这项工作。太糟糕了,在可预见的未来,这实际上不是一种选择:-/
2020 更新:
此后已修复此问题。不确定确切的时间,但当前的 mingw Qt 版本现在支持这一点。
- 警告处理为错误这里有什么问题
- "error: no matching function for call to"构造函数错误
- boost::进程间消息队列引发错误
- C++,OpenCV,尝试显示图像时"OpenCV(4.3.0) Error: Assertion failed (size.width>0 && size.height>0)"此错误
- 有关插入适配器的错误。[错误]请求从 'back_insert_iterator<vector<>>' 类型转换为非标量类型
- QT在错误的班级中寻找空位
- vector.resize()中的分配错误
- 代码在main()中运行,但在函数中出现错误
- 释放错误后堆使用
- (C++)分析树以计算返回错误值的简单算术表达式
- Project Euler问题4的错误解决方案
- 我的字符计数代码计算错误.为什么
- 从"int*"强制转换为"unsigned int"会丢失精度错误
- 尝试导入pybind-opencv模块时出现libgtk错误
- CMake项目Boost库错误:Boost/config/compiler/gcc.hpp:165:10:致命错误:cs
- 在某些循环内使用vector.push_back时出现分段错误
- MSVC多行宏编译器错误
- 静态数据成员的问题-修复链接错误会导致编译器错误
- 为什么在运行时没有向我们提供有关分段错误的更多信息?
- NVDA屏幕阅读器请求错误的QAccessible::InterfaceType