IUIAutomationElement::FindFirstBuildCache 方法 (uiautomationclient.h)

检索与指定条件匹配的第一个子元素或后代元素,预提取请求的属性和控件模式,并将预提取的项存储在缓存中。

语法

HRESULT FindFirstBuildCache(
                TreeScope                 scope,
  [in]          IUIAutomationCondition    *condition,
  [in]          IUIAutomationCacheRequest *cacheRequest,
  [out, retval] IUIAutomationElement      **found
);

参数

scope

[in] condition

类型: IUIAutomationCondition*

指向表示要匹配的条件的条件的指针。

[in] cacheRequest

类型: IUIAutomationCacheRequest*

指向缓存请求的指针,该请求指定要包含在缓存中的控件模式和属性。

[out, retval] found

类型: IUIAutomationElement**

接收指向匹配元素的指针;如果未找到匹配元素,则为 NULL

返回值

类型: HRESULT

如果该方法成功,则返回 S_OK。 否则,将返回 HRESULT 错误代码。

注解

搜索范围相对于调用方法的元素。 元素按在树中遇到的顺序返回。

此函数无法在 Microsoft UI 自动化树中搜索上级元素;也就是说,TreeScope_Ancestors 不是范围参数的有效值。

在桌面上搜索顶级窗口时,请确保在 scope 参数中指定TreeScope_Children,而不是TreeScope_Descendants。 在桌面的整个子树中搜索可能会循环访问数千个项,并导致堆栈溢出。

如果客户端应用程序可能尝试在其自己的用户界面中查找元素,则必须在单独的线程上进行所有UI 自动化调用。

若要搜索原始树,请在 cacheRequest 参数中指定相应的 TreeScope

要求

要求
最低受支持的客户端 Windows 7、带 SP2 的 Windows Vista 和适用于 Windows Vista 的平台更新、带 SP3 的 Windows XP 和适用于 Windows Vista 的平台更新 [仅限桌面应用]
最低受支持的服务器 Windows Server 2008 R2、Windows Server 2008 SP2 和 Platform Update for Windows Server 2008、Windows Server 2003 SP2 和 Platform Update for Windows Server 2008 [仅限桌面应用]
目标平台 Windows
标头 uiautomationclient.h (包括 UIAutomation.h)

另请参阅

缓存UI 自动化属性和控件模式

概念性

FindAll

FindAllBuildCache

FindFirst

IUIAutomationElement

获取 UI 自动化元素

引用