ControlGetFocus

如果有, 则获取目标窗口中具有输入焦点的控件.

ControlGetFocus, OutputVar , WinTitle, WinText, ExcludeTitle, ExcludeText

参数

OutputVar

用于保存控件标识符的输出变量的名称, 控件标识符由控件的类名以及在父窗口中的序列编号组成, 例如 Button12.

WinTitle, WinText, ExcludeTitle, ExcludeText

如果这些都是空白或省略, 将使用上次找到的窗口. 否则, 为 WinTitle 指定窗口标题或其他条件, 来标识目标窗口, 和/或为 WinText 指定目标窗口的单个文本元素的子字符串(由包含的 Window Spy 实用程序显示).

ExcludeTitleExcludeText 可用于根据标题或文本排除一个或多个窗口. 它们的规范类似于 WinTitleWinText, 除了 ExcludeTitle 不识别除窗口标题之外的任何条件.

窗口标题和文本是区分大小写的. 默认情况下, 不检测隐藏窗口, 而检测隐藏文本元素, 除非使用 DetectHiddenWindowsDetectHiddenText 进行更改. 默认情况下, 窗口标题必须以指定的 WinTitleExcludeTitle 开头才能匹配, 除非使用 SetTitleMatchMode 进行更改.

错误处理

[v1.1.04+]: 此命令失败时会抛出异常. 想了解更多信息, 请参阅运行时错误.

如果成功获取具有输入焦点的控件, 则 ErrorLevel 被置为 0. 否则(例如目标窗口不存在或它所有的控件都不具有输入焦点) 被置为 1.

备注

此命令获取的控件是含键盘焦点的那个, 即在用户输入时会接收到键击的那个.

目标窗口必须是活动的, 才能含有焦点控件. 如果窗口不是活动的, 则 OutputVar 被置为空.

[v1.1.19.03] 之前, 如果 ControlGetFocus 以较高频率运行(比如每 500 ms 或更短的周期), 可能会让用户的双击操作失败. 目前已经修复.

ControlFocus, ControlMove, ControlClick, ControlGetText, ControlSetText, ControlSend

示例

报告在记事本中输入焦点的控件的 ClassNN.

ControlGetFocus, OutputVar, Untitled - Notepad
if ErrorLevel
    MsgBox, The target window doesn't exist or none of its controls has input focus.
else
    MsgBox, Control with focus = %OutputVar%