UI 自动化对 Group 控件类型的支持
备注
本文档适用于想要使用 System.Windows.Automation 命名空间中定义的托管 UI 自动化类的 .NET Framework 开发人员。 有关 UI 自动化的最新信息,请参阅 Windows 自动化 API:UI 自动化。
本主题介绍 UI 自动化对 Group 控件类型的支持。 在 UI 自动化中,控件类型是一组条件,控件必须满足这些条件才能使用 ControlTypeProperty 属性。 这些条件包括针对 UI 自动化树结构、UI 自动化属性值和 UI 自动化控件模式的特定准则。
组控件表示层次结构中的节点。 Group 控件类型在 UI 自动化树中创建分离,以便组合在一起的项在 UI 自动化树内具有逻辑划分。
以下部分定义 Group 控件类型必需的 UI 自动化树结构、属性、控件模式和事件。 UI 自动化要求适用于所有 Group 控件,无论 Windows Presentation Foundation (WPF)、Win32 还是 Windows 窗体。
必需的 UI 自动化树结构
下表描述与 Group 控件有关的 UI 自动化树的控件视图和内容视图,以及每个视图中可包含的内容。 有关 UI 自动化树的详细信息,请参阅 UI 自动化树概述。
控件视图 | 内容视图 |
---|---|
组 - 0 个或多个控件 |
组 - 0 个或多个控件 |
通常,Group 控件具有 UI 自动化对 ListItem 控件类型的支持、UI 自动化对 TreeItem 控件类型的支持或 UI 自动化对 DataItem 控件类型的支持控件类型,这些控件类型可以在子树中 Group 控件的下方找到。 因为“Group”是泛型容器,因此任何类型的控件都有可能在 Group 控件下面的树中。
必需的 UI 自动化属性
下表列出值或定义与 Group 控件特别相关的 UI 自动化属性。 有关 UI 自动化属性的详细信息,请参阅客户端的 UI 自动化属性。
UI 自动化属性 | 值 | 说明 |
---|---|---|
AutomationIdProperty | 请参阅注释。 | 此属性的值在应用程序的所有控件中都必须保持唯一。 |
BoundingRectangleProperty | 请参阅注释。 | 包含整个控件的最外层矩形。 |
ClickablePointProperty | 请参阅注释。 | 如果存在边界矩形,则受支持。 如果边界矩形中存在无法单击的点,而你要执行专门的命中测试,则重写并提供可单击的点。 |
IsKeyboardFocusableProperty | 请参阅注释。 | 如果该控件可以接收键盘焦点,则它必须支持此属性。 |
NameProperty | 请参阅注释。 | 组控件通常从标记控件的文本获取其名称。 |
LabeledByProperty | 请参阅注释。 | 组控件通常自行进行标记。 在这些情况下,在此处返回 null 。 如果存在组的静态文本标签,则必须将其返回作为 LabeledBy 属性的值。 |
ControlTypeProperty | 组 | 此值对于所有 UI 框架均相同。 |
LocalizedControlTypeProperty | “Group” | 与 Group 控件类型相对应的本地化字符串。 |
IsContentElementProperty | 正确 | Group 控件始终包含在 UI 自动化树的内容视图中。 |
IsControlElementProperty | 正确 | 日历组始终包含在 UI 自动化树的控件视图中。 |
必需的 UI 自动化控件模式
下表列出需要对 Group 控件类型支持的 UI 自动化控件模式。 有关控件模式的详细信息,请参阅 UI Automation Control Patterns Overview。
控件模式 | 支持 | 说明 |
---|---|---|
IExpandCollapseProvider | 依赖的对象 | 可用于显示或隐藏信息的组控件必须支持展开折叠模式。 |
必需的 UI 自动化事件
下表列出需要由所有 Group 控件支持的 UI 自动化事件。 有关事件的详细信息,请参阅 UI Automation Events Overview。
UI 自动化事件 | 支持 | 说明 |
---|---|---|
BoundingRectangleProperty 属性更改事件。 | 必需 | 无 |
IsOffscreenProperty 属性更改事件。 | 必需 | 无 |
IsEnabledProperty 属性更改事件。 | 必需 | 无 |
ExpandCollapseStateProperty 属性更改事件。 | 依赖的对象 | 无 |
ToggleStateProperty 属性更改事件。 | 依赖的对象 | 无 |
AutomationFocusChangedEvent | 必须 | 无 |
StructureChangedEvent | 必须 | 无 |