注释
本文档适用于想要使用 System.Windows.Automation 命名空间中定义的托管 UI 自动化类的 .NET Framework 开发人员。 有关 UI 自动化的最新信息,请参阅 Windows 自动化 API:UI 自动化。
本主题提供有关日历控件类型的 UI 自动化支持的信息。 在 UI 自动化中,控件类型是控件为了使用属性 ControlTypeProperty 而必须满足的一组条件。 这些条件包括 UI 自动化树结构、UI 自动化属性值、控件模式和 UI 自动化事件的特定准则。
日历控件允许用户轻松确定日期并选择其他日期。
以下部分定义了日历控件类型的所需 UI 自动化树结构、属性、控件模式和事件。 UI 自动化要求适用于所有日历控件,无论是 Windows Presentation Foundation (WPF)、Win32 还是 Windows Forms。
必需的 UI 自动化树结构
下表描述了与日历控件相关的 UI 自动化树的控件视图和内容视图,并描述了每个视图中可包含的内容。 有关 UI 自动化树的详细信息,请参阅 UI 自动化树概述。
控件视图 | 内容视图 |
---|---|
日历
|
日历 - ListItem (数量取决于显示的天数) |
日历控件可以以用户界面中的多种不同形式表示。 UI 自动化树的控件视图中唯一保证出现的控件是数据网格、标头、标头项和列表项控件。
所需的 UI 自动化属性
下表列出了其值或定义与日历控件特别相关的 UI 自动化属性。 有关 UI 自动化属性的详细信息,请参阅 客户端的 UI 自动化属性。
UI 自动化属性 | 价值 | 注释 |
---|---|---|
AutomationIdProperty | 请参阅备注。 | 此属性的值需要在应用程序中的所有控件中唯一。 |
BoundingRectangleProperty | 请参阅备注。 | 包含整个控件的最外侧矩形。 |
ClickablePointProperty | 请参阅备注。 | 如果存在边界矩形,则受支持。 如果边界矩形中存在无法单击的点,而你要执行专门的命中测试,则重写并提供可单击的点。 |
ControlTypeProperty | 日历 | 对于所有 UI 框架,此值相同。 |
IsContentElementProperty | 真 实 | 日历控件始终包含在 UI 自动化树的内容视图中。 |
IsControlElementProperty | 真 实 | 日历控件始终包含在 UI 自动化树的控件视图中。 |
IsKeyboardFocusableProperty | 请参阅备注。 | 如果控件可以接收键盘焦点,它必须支持此属性。 |
LabeledByProperty | 请参阅备注。 | 文档控件的标签。 通常,使用文档的标题。 |
LocalizedControlTypeProperty | “日历” | 与日历控件类型对应的本地化字符串。 |
NameProperty | 请参阅备注。 | 日历控件通常从当前日期获取其名称。 |
必需的 UI 自动化控件模式
下表列出了所有日历控件支持所需的 UI 自动化控件模式。 有关控件模式的详细信息,请参阅 UI 自动化控件模式概述。
控件模式/模式属性 | 支持 | 注释 |
---|---|---|
IGridProvider | 是的 | 日历控件始终支持网格模式,因为一个月内的天数是可以空间导航的项目。 |
IScrollProvider | 取决于 | 大多数日历控件都支持按页面翻转视图。 建议使用滚动模式来支持分页导航。 |
ISelectionProvider | 取决于 | 大多数日历控件保留特定的日期、月或年份作为子元素的选择。 某些日历是多选日历,其他日历只能选择单选。 |
ITableProvider | 是的 | 日历控件在其子树内始终有一个表示星期几的标题,因此必须支持表格模式。 |
IValueProvider | 否 | 日历控件不需要值控件模式,因为不能直接在控件上设置值。 如果特定日期与控件相关联,则选择控件模式应提供该信息。 |
所需的 UI 自动化事件
下表列出了所有日历控件支持的 UI 自动化事件。 有关事件的详细信息,请参阅 UI 自动化事件概述。
UI 自动化事件 | 支持 | 注释 |
---|---|---|
AutomationFocusChangedEvent | 必选 | 没有 |
BoundingRectangleProperty 属性更改事件。 | 必选 | 没有 |
IsEnabledProperty 属性更改事件。 | 必选 | 没有 |
IsOffscreenProperty 属性更改事件。 | 必选 | 没有 |
LayoutInvalidatedEvent | 必选 | 没有 |
StructureChangedEvent | 必选 | 没有 |
CurrentViewProperty 属性更改事件。 | 取决于 | 没有 |
HorizontallyScrollableProperty 属性更改事件。 | 取决于 | 如果控件支持 Scroll 控件模式,则必须支持此事件。 |
HorizontalScrollPercentProperty 属性更改事件。 | 取决于 | 如果控件支持 Scroll 控件模式,则必须支持此事件。 |
HorizontalViewSizeProperty 属性更改事件。 | 取决于 | 如果控件支持 Scroll 控件模式,则必须支持此事件。 |
VerticalScrollPercentProperty 属性更改事件。 | 取决于 | 如果控件支持 Scroll 控件模式,则必须支持此事件。 |
VerticallyScrollableProperty 属性更改事件。 | 取决于 | 如果控件支持 Scroll 控件模式,则必须支持此事件。 |
VerticalViewSizeProperty 属性更改事件。 | 取决于 | 如果控件支持 Scroll 控件模式,则必须支持此事件。 |
InvalidatedEvent | 必选 | 没有 |