返回符合指定条件的所有现有窗口的唯一 ID 号(HWND) 数组.
HWNDs := WinGetList(WinTitle, WinText, ExcludeTitle, ExcludeText)
如果这些都是空白或省略, 则将检索整个系统上的所有窗口. 否则, 为 WinTitle 指定窗口标题或其他条件, 来标识目标窗口, 和/或为 WinText 指定目标窗口的单个文本元素的子字符串(由包含的 Window Spy 实用程序显示).
ExcludeTitle 和 ExcludeText 可用于根据标题或文本排除一个或多个窗口. 它们的规范类似于 WinTitle 和 WinText, 除了 ExcludeTitle 不识别除窗口标题之外的任何条件.
窗口标题和文本是区分大小写的. 默认情况下, 不检测隐藏窗口, 而检测隐藏文本元素, 除非使用 DetectHiddenWindows 和 DetectHiddenText 进行更改. 默认情况下, 窗口标题的任意位置包含 WinTitle 或 ExcludeTitle 就能形成匹配, 除非使用 SetTitleMatchMode 进行了更改.
类型: Array
此函数返回所有符合指定条件的现有窗口的唯一 ID 号的数组. 每个数字是一个窗口句柄(HWND). 如果没有匹配窗口, 则返回空数组.
例如, 如果将返回值赋值给变量 HWNDs
, 并且发现了两个匹配的窗口, 则 HWNDs[1]
包含第一个窗口的 ID, HWNDs[2]
包含第二个窗口的 ID, 而 HWNDs.Length
返回数字 2.
Windows 将按从顶部到底部的顺序检索(根据它们在桌面上的堆叠方式).
鼠标光标下的窗口的 ID 可以使用 MouseGetPos 来获取.
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 }