看界面控件DevExpress WinForms——如何自定义辅助功能属性(上)

在官方最近的几个新版发布周期中,为

在开始之前

在这篇文章中将使用Microsoft Inspect检索各个UI元素的可访问性信息,尽管与 Accessibility Insights 应用程序相比,Inspect 可能已经过时,但它仍然是一个强大的工具,可以与完美的实用程序一起使用。

Inspect 是 Windows SDK 安装中包含的免费工具。 安装后,您可以在 C:Program Files (x86)Windows Kits10binsdk_build_versionx64 文件夹中找到“inspect.exe”文件。

放大镜按钮

如图所示,可访问的按钮名称是“Glyph”。这是由辅助功能客户端(例如Windows Narrator)大声朗读的名称,它没有说明按钮的实际作用。

看界面控件DevExpress WinForms——如何自定义辅助功能属性(上)

要解决此问题并分配更合理的辅助功能名称,请处理新的 QueryAccessibleInfo 事件,如下所示。

using DevExpress.Accessibility;public MyForm() {InitializeComponent();// ...DXAccessible.QueryAccessibleInfo += (s, e) => {if (e.OwnerControl == this.colorEdit1 && e.Name == "Glyph")e.Name = "Magnifier";};}

看界面控件DevExpress WinForms——如何自定义辅助功能属性(上)
格行名称

切换到同一示例的”Inplace Grid Cell Editors” 模块并检查 格单元名称,辅助功能树如下所示:

看界面控件DevExpress WinForms——如何自定义辅助功能属性(上)

行简称为 “Row 1”, “Row 2”, “Row 3″等,单元格名称为“Editor Name Row N”和“Value row N”。虽然这些名称让用户对当前鼠标指针位置有一个模糊的了解,但 QueryAccessibleInfo 事件允许我们指定更准确的行和单元格名称。

using DevExpress.Accessibility;DXAccessible.QueryAccessibleInfo += (s, e) => {if (e.OwnerControl == gridControl1) {if (e.Role == AccessibleRole.Cell) {if (e.Name.StartsWith("Editor Name"))e.Name = "Editor Name";else if (e.Name.StartsWith("Value"))e.Name = e.AccessibleObject.Parent.GetChild(0).Value + " Value";}if (e.Role == AccessibleRole.Row)e.Name = e.AccessibleObject.GetChild(0).Value + " Row";}/* For builds of v22.1.3 and olderif(e.Role == AccessibleRole.ListItem && e.Name.StartsWith("Row"))e.Role = AccessibleRole.Row;if (e.Role == AccessibleRole.Row)e.Name = e.AccessibleObject.GetChild(0).Value; */};

看界面控件DevExpress WinForms——如何自定义辅助功能属性(上)

v22.1.3 和更早的版本需要注释块,因为在这些版本中, 格行的 AccessibleRole 错误地返回了“ListItem”,官方已经在最新版本中修复了这个问题(除了之前实施的许多其他修复)。

DevExpress WinForm | 下载试用

DevExpress WinForm拥有180+组件和UI库,能为Windows Forms平台创建具有影响力的业务解决方案。DevExpress WinForms能完美构建流畅、美观且易于使用的应用程序,无论是Office风格的界面,还是分析处理大批量的业务数据,它都能轻松胜任!


DevExpress技术交流群6:600715373      欢迎一起进群讨论

DevExpress企业定制服务
标签:

声明:本站部分文章及图片源自用户投稿,如本站任何资料有侵权请您尽早请联系jinwei@zod.com.cn进行处理,非常感谢!

上一篇 2022年6月10日
下一篇 2022年6月10日

相关推荐

发表回复

登录后才能评论