UI 自动化对 Calendar 控件类型的支持

备注

本文档适用于想要使用 System.Windows.Automation 命名空间中定义的托管 UI 自动化类的 .NET Framework 开发人员。 有关 UI 自动化的最新信息,请参阅 Windows 自动化 API:UI 自动化

本主题介绍了 UI 自动化对 Calendar 控件类型的支持。 在 UI 自动化中,控件类型是一组条件,控件必须满足这些条件才能使用 ControlTypeProperty 属性。 这些条件包括针对 UI 自动化树结构、UI 自动化属性值、控件模式和 UI 自动化事件的特定准则。

Calendar 控件允许用户轻松确定日期并选择其他日期。

以下部分定义 Calendar 控件类型必需的 UI 自动化树结构、属性、控件模式和事件。 UI 自动化要求适用于所有 Calendar 控件,无论是 Windows Presentation Foundation (WPF)、Win32 还是 Windows 窗体。

必需的 UI 自动化树结构

下表描述与 Calendar 控件有关的 UI 自动化树的控件视图和内容视图,以及每个视图中可包含的内容。 有关 UI 自动化树的详细信息,请参阅 UI 自动化树概述

控件视图 内容视图
日历

  • DataGrid

    • 标头(0 个或 1 个)
    • HeaderItem(0 个或 7个;数量取决于列中显示了多少天)
    • ListItem(数量取决于显示了多少天)
    • Button(0 个或 2 个;用于对日历视图进行分页)
日历

- ListItem(数量取决于显示了多少天)

Calendar 控件可在用户界面中表示为多种不同的形式。 UI 自动化树的控件视图中唯一确保存在的控件是数据网格、标头、标头项和列表项控件。

必需的 UI 自动化属性

下表列出了其值或定义与 Calendar 控件特别相关的 UI 自动化属性。 有关 UI 自动化属性的详细信息,请参阅客户端的 UI 自动化属性

UI 自动化属性 说明
AutomationIdProperty 请参阅注释。 此属性的值在应用程序的所有控件中都必须保持唯一。
BoundingRectangleProperty 请参阅注释。 包含整个控件的最外层矩形。
ClickablePointProperty 请参阅注释。 如果存在边界矩形,则受支持。 如果边界矩形中存在无法单击的点,而你要执行专门的命中测试,则重写并提供可单击的点。
ControlTypeProperty 日历 此值对于所有 UI 框架均相同。
IsContentElementProperty 正确 Calendar 控件始终包含在 UI 自动化树的内容视图中。
IsControlElementProperty 正确 Calendar 控件始终包含在 UI 自动化树的控件视图中。
IsKeyboardFocusableProperty 请参阅注释。 如果该控件可以接收键盘焦点,则它必须支持此属性。
LabeledByProperty 请参阅注释。 文档控件的标签。 通常使用文档的标题。
LocalizedControlTypeProperty “日历” 与 Calendar 控件类型相对应的本地化字符串。
NameProperty 请参阅注释。 日历控件通常从当前日的日期中获取其名称。

必需的 UI 自动化控件模式

下表列出了需要由所有 Calendar 控件支持的 UI 自动化控件模式。 有关控件模式的详细信息,请参阅 UI Automation Control Patterns Overview

控件模式/模式属性 支持 说明
IGridProvider 日历控件始终支持“网格”模式,因为月份中的日期是可以在空间中导航的项。
IScrollProvider 依赖的对象 大多数日历控件支持按页翻转视图。 建议使用“滚动”模式支持分页导航。
ISelectionProvider 依赖的对象 大多数日历控件将特定日期、月份或年份保留为子元素的选定项。 某些日历具有多选功能和其他日历只能进行单选。
ITableProvider 日历控件在其子树内始终具有该星期所有日期的标头,因此必须支持表格模式。
IValueProvider Value 控件模式对于日历控件而言不是必要的,因为无法直接在控件上设置值。 如果特定日期与控件关联,则信息应由 Selection 控件模式提供。

必需的 UI 自动化事件

下表列出了需要由所有 Calendar 控件支持的 UI 自动化事件。 有关事件的详细信息,请参阅 UI Automation Events Overview

UI 自动化事件 支持 说明
AutomationFocusChangedEvent 必须
BoundingRectangleProperty 属性更改事件。 必需
IsEnabledProperty 属性更改事件。 必需
IsOffscreenProperty 属性更改事件。 必需
LayoutInvalidatedEvent 必须
StructureChangedEvent 必须
CurrentViewProperty 属性更改事件。 依赖的对象
HorizontallyScrollableProperty 属性更改事件。 依赖的对象 如果该控件支持 Scroll 控件模式,它必须支持此事件。
HorizontalScrollPercentProperty 属性更改事件。 依赖的对象 如果该控件支持 Scroll 控件模式,它必须支持此事件。
HorizontalViewSizeProperty 属性更改事件。 依赖的对象 如果该控件支持 Scroll 控件模式,它必须支持此事件。
VerticalScrollPercentProperty 属性更改事件。 依赖的对象 如果该控件支持 Scroll 控件模式,它必须支持此事件。
VerticallyScrollableProperty 属性更改事件。 依赖的对象 如果该控件支持 Scroll 控件模式,它必须支持此事件。
VerticalViewSizeProperty 属性更改事件。 依赖的对象 如果该控件支持 Scroll 控件模式,它必须支持此事件。
InvalidatedEvent 必需

请参阅