WinGetList

返回与指定条件匹配的所有现有窗口的唯一 ID 号.

List := WinGetList(WinTitle, WinText, ExcludeTitle, ExcludeText)

参数

WinTitle

类型: 字符串, 整数对象

识别目标窗口的窗口标题或其他条件. 请参阅 WinTitle.

WinText

类型: 字符串

如果存在, 此参数必须是目标窗口的单个文本元素的子字符串(和内置的 Window Spy 工具显示的一样). 如果 DetectHiddenText 为 ON, 那么会检测隐藏文本元素.

ExcludeTitle

类型: 字符串

标题中含有此参数值的窗口将被排除.

ExcludeText

类型: 字符串

文本中含有此参数值的窗口将被排除.

返回值

类型: 数组

此函数返回一个数组, 其中包含了与指定参数匹配的所有现有窗口的 窗口句柄(HWND). 如果没有匹配的窗口, 则返回一个空数组.

例如, 如果将返回值赋值给名为 List 的变量, 并且发现了两个匹配的窗口, 则 List[1] 包含第一个窗口的 ID, List[2] 包含第二个窗口的 ID, 而 List.Length 返回数字 2.

Windows 将按从顶部到底部的顺序检索(根据它们在桌面上的堆叠方式).

备注

要获取整个系统的所有窗口, 省略所有的四个标题/文本参数.

鼠标光标下的窗口的 ID 可以使用 MouseGetPos 来获取.

窗口标题和文本是区分大小写的. 除非 DetectHiddenWindows 被打开, 否则不会检测隐藏窗口.

WinGetCount, Win 函数, Control 函数

示例

访问整个系统中的所有窗口并显示它们的信息.

ids := WinGetList(,, "Program Manager")
for this_id in ids
{
    WinActivate this_id
    this_class := WinGetClass(this_id)
    this_title := WinGetTitle(this_id)
    Result := MsgBox(
    (
        "Visiting All Windows
        " A_Index " of " ids.Length "
        ahk_id " this_id "
        ahk_class " this_class "
        " this_title "

        Continue?"
    ),, 4)
    if (Result = "No")
        break
}
unixetc