WinActive

检查指定的窗口是否激活且返回其唯一 ID(HWND).

UniqueID := WinActive(WinTitle, WinText, ExcludeTitle, ExcludeText)

参数

WinTitle, WinText, ExcludeTitle, ExcludeText

类型: 字符串, 整数对象

如果这些都未设置或省略, 将使用上次找到的窗口. 否则, 为 WinTitle 指定窗口标题或其他条件, 来标识目标窗口, 和/或为 WinText 指定目标窗口的单个文本元素的子字符串(由包含的 Window Spy 实用程序显示). 如果 DetectHiddenText 已经打开, 则检测隐藏文本元素. 标题或文本包含 ExcludeTitleExcludeText 的窗口将不被考虑.

返回值

类型: 整数

函数返回匹配指定的条件的活动窗口的唯一 ID(HWND), 如果不匹配, 则函数返回 0.

因为所有非零数字被视为 "true", 当 WinTitle 为活动窗口时, 语句 if WinActive(WinTitle) 为 true .

备注

如果省略所有参数, 那么将使用上次找到的窗口.

如果符合条件的窗口存在, 那么上次找到的窗口将更新为此窗口.

获取活动窗口的唯一 ID 的简便方法是使用 ActiveHwnd := WinExist("A").

SetWinDelay 不适用于此函数.

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

WinExist, SetTitleMatchMode, DetectHiddenWindows, Last Found Window, WinActivate, WinWaitActive, WinWait, WinWaitClose, #HotIf

示例

关闭记事本或另一个窗口, 这取决于 WinActive 函数找到的是哪个窗口. 注意, "ahk_" 关键字和它的标准值之间的空格可以省略; 这在使用变量时特别有用, 如第二个 WinActive 所示.

if WinActive("ahk_class Notepad") or WinActive("ahk_class" ClassName)
    WinClose ; 使用由 WinActive 找到的窗口.
unixetc