ControlGetFocus

AutoHotKey

ControlGetFocus

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

ControlGetFocus, OutputVar [, WinTitle, WinText, ExcludeTitle, ExcludeText]

参数

OutputVar

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

WinTitle

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

WinText

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

ExcludeTitle

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

ExcludeText

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

ErrorLevel

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

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

备注

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

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

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

WinTitle (窗口标题) 和 WinText (窗口内文本) 是大小写敏感的. 除非将 DetectHiddenWindows 设置为 on, 否则无法探测隐藏的窗口.

相关

ControlFocus, ControlMove, ControlClick, ControlGetText, ControlSetText, ControlSend

示例

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%