ControlMove

移动和/或调整控件.

ControlMove X, Y, Width, Height, ControlID, WinTitle, WinText, ExcludeTitle, ExcludeText

参数

X, Y

类型: 整数

如果任一坐标省略, 那么控件在这个维度(坐标轴) 中的位置将保持不变. 否则, 请指定控件新位置的左上角的 X 和 Y 坐标(单位为像素). 这里的坐标相对于目标窗口的客户端区域(不包括标题栏, 菜单栏和边框) 的左上角; 可以使用 ControlGetPosWindow Spy 来确定它们.

Width, Height

类型: 整数

如果任一省略, 那么控件在这个维度(坐标轴) 中的尺寸将保持不变. 否则, 请指定控件的新宽度和高度(单位为像素).

ControlID

类型: 字符串, 整数对象

控件的 ClassNN, 文本或 HWND, 或具有 Hwnd 属性的对象. 有关详情, 请参阅控件标识符. 该参数是必需的; 也就是说, 不能省略.

WinTitle, WinText, ExcludeTitle, ExcludeText

类型: 字符串, 整数对象

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

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

窗口标题和文本是区分大小写的. 默认情况下, 不检测隐藏窗口, 而检测隐藏文本元素, 除非使用 DetectHiddenWindowsDetectHiddenText 进行更改; 当使用纯 HWND 时, 都会检测隐藏窗口. 默认情况下, 窗口标题的任意位置包含 WinTitleExcludeTitle 就能形成匹配, 除非使用 SetTitleMatchMode 进行了更改.

错误处理

如果找不到窗口或控件, 则抛出 TargetError.

如果控件的当前位置无法确定, 则抛出 OSError.

备注

此函数适用于非图形用户界面窗口中的控件, 即那些并非通过 Gui 函数创建的窗口. 这个函数最适用于常见的或预定义的 Microsoft 控件; 而某些应用程序则使用自定义或修改后的控件, 在这种情况下, 函数可能无法按预期工作. 对于 GUI 控件, 通常使用 GuiControl.Move 更方便.

为了提高可靠性, 每次使用此函数后都会自动执行延迟. 该延迟可以通过 SetControlDelay 或者给 A_ControlDelay 赋值来更改. 有关详情, 请参阅 SetControlDelay 备注.

ControlGetPos, WinMove, SetControlDelay, GuiControl.Move, 控件函数

示例

演示如何在脚本等待用户输入时操作输入框的 OK 按钮.

SetTimer ControlMoveTimer
IB := InputBox(, "My Input Box")

ControlMoveTimer()
{
    if !WinExist("My Input Box")
        return
    ; 否则上面设置为 "上次找到的" 窗口:
    SetTimer, 0
    WinActivate
    ControlMove 10,, 200,, "OK"  ; 将 OK 按钮移动到左边并增加其宽度.
}