发送鼠标按钮或鼠标滚轮事件到控件.
ControlClick Control-or-Pos, WinTitle, WinText, WhichButton, ClickCount, Options, ExcludeTitle, ExcludeText
如果省略此参数, 则目标窗口本身将被点击. 否则, 将使用以下两种模式之一.
模式 1(位置): 指定相对于目标窗口客户端区域左上角的 X 和 Y 坐标. X 坐标必须在 Y 坐标之前, 并且它们之间必须至少有一个空格或制表符. 例如: X55 Y33
. 如果在指定的坐标上有一个控件, 它将在这些确切的坐标上发送点击事件. 如果没有控件, 目标窗口本身将被发送事件(根据窗口的性质, 可能没有效果).
注意: 在模式 1 中, 会忽略 Options 参数中的 X 和 Y 字母选项.
模式 2(控件): 指定控件的 ClassNN, 文本或 HWND, 或一个具有 Hwnd
属性的对象. 有关详情, 请参阅控件的参数.
默认情况下, 模式 2 优先于模式 1. 例如, 在一种不太可能发生的情况中某个控件的文本或 ClassNN 格式为 "Xnnn Ynnn", 那么此时会使用模式 2. 要覆盖此行为而无条件使用模式 1, 请在 Options中加上单词 Pos, 如下例所示: ControlClick "x255 y152", WinTitle,,,, "Pos"
.
识别目标窗口的窗口标题或其他条件. 请参阅 WinTitle.
类型: 字符串
如果存在, 此参数必须是目标窗口的单个文本元素的子字符串(和内置的 Window Spy 工具显示的一样). 如果 DetectHiddenText 为 ON, 那么会检测隐藏文本元素.
类型: 字符串
要点击的按钮: LEFT, RIGHT, MIDDLE(或这些单词的首个字母). 如果省略或为空, 则使用 LEFT 按钮.
支持 X1(XButton1, 第四个鼠标按钮) 和 X2(XButton2, 第五个鼠标按钮).
支持 WheelUp(或 WU), WheelDown(或 WD), WheelLeft(或 WL) 和 WheelRight(或 WR). 此时, ClickCount 为需要转动的滚轮格数.
类型: 整数
发送的点击次数. 如果省略或为空, 则点击 1 次.
类型: 字符串
零个或多个下列选项字母组成的系列. 例如: d x50 y25
NA: 也许可以提高可靠性. 请参阅后面的可靠性.
D: 按住鼠标按钮不放(即生成按下事件). 如果 D 和 U 选项都没有, 则会发送完整的点击事件(按下事件和弹起事件).
U: 释放鼠标按钮(即生成弹起事件). 此选项不能和 D 选项同时使用.
Pos: 在 Options 的任意位置指定单词 Pos, 这样会无条件使用 Control-or-Pos 参数中描述的 X/Y 位置模式.
Xn: 指定 n 为要点击的相对于控件左上角的 X 坐标. 如果未指定, 则在控件的水平中心点击.
Yn: 指定 n 为要点击的相对于控件左上角的 Y 坐标. 如果未指定, 则在控件的垂直中心点击.
X 和 Y 选项中使用十进制(不是十六进制数) 数字.
类型: 字符串
标题中含有此参数值的窗口将被排除.
类型: 字符串
文本中含有此参数值的窗口将被排除.
在以下情况下会抛出异常:
要提高可靠性, 尤其是在 ControlClick 期间用户同时在使用鼠标, 请尝试下面的一种或两种方法也许会有所帮助:
1) 在 ControlClick 前, 使用 SetControlDelay -1
. 这样可以避免在点击时按住鼠标, 减少对用户使用鼠标的干扰.
2) 在第六个参数(Options) 中指定字符串 NA, 如下所示:
SetControlDelay -1 ControlClick "Toolbar321", WinTitle,,,, "NA"
NA
可以避免激活目标窗口, 同时避免混淆它和脚本的输入, 这样可以防止鼠标实际移动产生的冲突(但通常只在目标窗口不活动时). 然而, 此方法不是对所有的窗口和控件都有效.
并非所有的应用程序都遵守 ClickCount 大于 1 的方式来转动鼠标滚轮. 对于这些应用, 使用 Loop 来转动多个格数, 例如这个例子转动 5 格:
Loop 5 ControlClick Control, WinTitle, WinText, "WheelUp"
窗口标题和文本是区分大小写的. 除非 DetectHiddenWindows 被打开, 否则不会检测隐藏窗口.
SetControlDelay, Control 函数, Click