class Gui.Control extends Object
提供用于修改 GUI 控件并检索有关控件的信息的接口. Gui.Add, Gui.__Item 和 GuiCtrlFromHwnd 返回这种类型的对象.
下面使用 "GuiCtrl" 作为任何 Gui.Control
类实例的占位符.
Gui.Control
作为所有 GUI 控件的基类, 但是每种类型的控件都有自己的类. 以下一些方法是由适当的类的原型, 或 Gui.List
基类定义的. 有关完整列表, 请参阅内置的类.
除了从 Object 继承的方法和属性外, GuiControl 对象还具有以下预定义的方法和属性.
添加项目到多项目控件(ListBox, DropDownList, ComboBox 或 Tab).
GuiCtrl.Add(Items)
类型:Array
将作为项目插入控件列表末尾的字符串数组, 例如 ["Red","Green","Blue"]
.
要替换(覆盖) 列表, 请事先使用 Delete 方法. 要选择一个项目, 请使用 Choose 方法.
在多项目控件(ListBox, DropDownList, ComboBox 或 Tab) 中选择一个项目.
GuiCtrl.Choose(Value)
指定 1 表示第一个项目, 2 表示第二个, 等等.
如果 Value 是字符串(即使是数字字符串), 将选择名称前部与 Value 相匹配的项目. 搜索不区分大小写. 例如, 如果控件中包含 "UNIX Text" 项目, 指定单词 unix(小写) 就可以选择它. 对于一个多选 ListBox, 所有匹配的项目都会被选中.
如果 Value 为零或为空, 则当前选择将被移除.
要选择或取消选择一个多选 ListBox 中的 所有 项目, 请参照此例:
PostMessage 0x185, 1, -1, ListBox ; 选择所有项目. 0x185 是 LB_SETSEL. PostMessage 0x185, 0, -1, ListBox ; 取消选择所有项目. ListBox.Choose(0) ; 取消选择所有项目.
与 ControlChooseIndex 不同, 该方法不会触发 Change 或 DoubleClick 事件.
删除多项目控件(ListBox, DropDownList, ComboBox 或 Tab) 中的一个或所有项目.
GuiCtrl.Delete(Value)
类型: 整数
如果省略, 则删除所有项目. 否则, 指定 1 表示第一个项目, 2 表示第二个, 等等.
对于 Tab 控件, 一个标签的子控件会与其原始的标签编号相关联; 也就是说, 它们永远不会与其标签的实际显示名称相关联. 因此, 重命名或删除一个选项卡不会改变子控件所属的选项卡号. 例如, 如果有三个选项卡 ["Red","Green","Blue"]
并且通过 MyTab.Delete(2)
删除了第二个选项卡, 则原来与 Green 相关联的子控件现在将与 Blue 相关联. 由于这种行为, 一般只应删除最后的标签页. 以这种方式删除的标签页可以在以后再添加回来, 届时它们将重新获得原来的控件集.
获取控件的位置和大小.
GuiCtrl.GetPos(&X, &Y, &Width, &Height)
类型: VarRef
如果省略, 则不存储相应的值. 否则, 指定对输出变量的引用, 在输出变量中存储控件左上角的 X 和 Y 坐标(以像素为单位). 这些坐标相对于窗口客户端区域的左上角,该区域不包括标题栏, 菜单栏和边框.
类型: VarRef
如果省略, 则不存储相应的值. 否则, 指定对输出变量的引用, 以存储控件的宽度和高度(以像素为单位).
与 ControlGetPos 不同的是, 本方法对返回的坐标应用了 DPI 缩放(除非使用了 -DPIScale
选项).
MyEdit.GetPos(&x, &y, &w, &h) MsgBox "The X coordinate is " x ". The Y coordinate is " y ". The width is " w ". The height is " h "."
移动和/或调整控件的大小.
GuiCtrl.Move(X, Y, Width, Height)
类型: 整数
如果省略其中任何一个, 则不会更改控件在该维度中的位置. 否则, 指定控件新位置左上角的 X 和 Y 坐标(以像素为单位). 坐标相对于窗口的客户端区域的左上角, 该区域不包括标题栏, 菜单栏和边框.
类型: 整数
如果省略其中任何一个, 则不会更改该维度中的控件的大小. 否则, 指定控件的新宽度和高度(以像素为单位).
与 ControlMove 不同的是, 本方法将 DPI 缩放应用于坐标(除非使用了 -DPIScale
选项).
MyEdit.Move(10, 20, 200, 100) MyEdit.Move(VarX+10, VarY+5, VarW*2, VarH*1.5)
注册一个函数或方法, 当通过 WM_COMMAND 消息接收到控件通知时调用.
GuiCtrl.OnCommand(NotifyCode, Callback , AddRemove)
有关详情, 请参阅 OnCommand.
注册一个函数或方法, 当通过 WM_NOTIFY 消息接收到控件通知时调用.
GuiCtrl.OnNotify(NotifyCode, Callback , AddRemove)
有关详情, 请参阅 OnNotify.
为控件的外观和行为设置各种选项和样式.
GuiCtrl.Opt(Options)
在下面的例子中, 该控件被禁用, 并且它的 background 恢复为系统默认值:
MyEdit.Opt("+Disabled -Background")
在下一个例子中, OK 按钮被变成了新的默认按钮:
OKButton.Opt("+Default")
虽然样式和扩展样式也被识别, 但其中一些样式在控件创建后无法应用或删除. 即使成功应用了某项更改, 控件也可能选择忽略它.
重绘控件所占的 GUI 窗口区域.
GuiCtrl.Redraw()
虽然当重复和快速调用时, 可能会导致不必要的闪烁效果, 但它解决了某些控件类型(如 GroupBox) 的显示重影的问题.
设置控件的字体字体, 大小, 样式和/或颜色.
GuiCtrl.SetFont(Options, FontName)
省略这两个参数, 以将字体设置为 GUI 的当前字体, 如 Gui.SetFont 所设置. 否则, 任何未指定的字体属性将从控件的先前字体中复制. 只有在 Options 中指定的情况下, 文本颜色才会改变.
关于这两个参数的详细说明, 请参阅 Gui.SetFont.
检索控件的类名和序列编号(ClassNN).
ClassNN := GuiCtrl.ClassNN
控件的 ClassNN 是它的窗口类名后面跟着它在包含它的顶级窗口中的序列号. 例如, "Edit1" 是窗口上的第一个编辑控件, 而 "Button12" 是第十二个按钮.
检索或设置控件的交互状态.
CurrentSetting := GuiCtrl.Enabled
GuiCtrl.Enabled := NewSetting
如果已经赋值, CurrentSetting 为 NewSetting, 否则, 默认为 1(true), 除非被 Disabled 选项覆盖.
NewSetting 是一个布尔值, 用于启用或禁用此设置. 如果为 true, 则启用该控件. 如果为 false, 则禁用该控件.
对于 Tab 控件, 这也将启用或禁用该 Tab 的所有子控件. 然而, 任何通过 GuiCtrl.Enabled := false
显式禁用的子控件将记住该设置, 因此即使在其 Tab 控件被重新启用后也会保持禁用状态.
检索控件当前焦点状态.
IsFocused := GuiCtrl.Focused
如果控件有键盘焦点, IsFocused 为 1(true), 否则为 0(false).
要让设置生效, 窗口一般不能处于最小化或隐藏状态.
要对聚焦控件, 请使用 Focus 方法.
检索控件的窗口句柄(HWND).
Hwnd := GuiCtrl.Hwnd
控件的 HWND, 通常与 PostMessage, SendMessage 和 DllCall 一起使用. 它也可以直接用于 Control 参数.
检索或设置控件的显式名称.
CurrentName := GuiCtrl.Name
GuiCtrl.Name := NewName
如果已经赋值, CurrentName 为 NewName, 否则默认为空字符串, 除非被 V 选项覆盖.
NewName 为控件的新名称, 它可以与 Gui.__Item 一起使用, 来检索 GuiControl 对象. 对于大多数支持输入的控件, Gui.Submit 也会使用这个名称.
检索或设置控件的文本/标题.
CurrentText := GuiCtrl.Text
GuiCtrl.Text := NewText
注意: 如果控件没有可见的标题文本和文本值, 则此属性对应于控件的隐藏标题文本(如 ControlGetText/ControlSetText).
CurrentText 和 NewText 的值取决于控件类型:
Button / CheckBox / Edit / GroupBox / Link / Radio / Text
CurrentText 和 NewText 是 Button, CheckBox, Edit, GroupBox, Link, Radio 或 Text 控件的标题/显示文本. 由于控件不会自动展开, 如果需要展开控件, 请使用 GuiCtrl.Move(,, 300)
或类似的方法.
DateTime
CurrentText 和 NewText 是 DateTime 控件显示的格式化文本. 不支持为控件指定格式化的日期/时间字符串. 要更改显示的日期/时间, 请为 Value 属性赋值为一个 YYYYMMDDHH24MISS 格式的日期-时间戳.
DropDownList / ComboBox / ListBox / Tab
CurrentText 和 NewText 是 DropDownList, ComboBox, ListBox 或 Tab 控件中当前选择的项/选项卡的文本.
NewText 应该是要选择的项目/标签的全部文本(不区分大小写).
对于 ComboBox, 如果没有选中的项目, 则会检索控件编辑栏中的文本. 对于其他控件, CurrentText 为空/空白. 同样, 如果 NewText 为空/空白, 则当前项/标签将被取消选择.
对于一个多选 ListBox, CurrentText 是一个数组. NewText 不能是一个数组, 但如果多个项目匹配, 它们都会被选择. 要用不同的文本选择多个项目, 请重复调用 Choose 方法.
要根据项目的位置编号而不是文本选择项目, 请使用 Value 属性.
Edit
CurrentText 和 NewText 是 Edit 控件的文本. 与其他控件一样, 文本按原样检索或设置; 不用预先进行尾转换. 要检索或设置多行 Edit 控件的文本, 同时在 `r`n
和 `n
之间进行转换, 请使用 Value 属性.
StatusBar
CurrentText 和 NewText 是 StatusBar 控件第一部分的文本(使用 SB.SetText 以获得更大的灵活性).
检索控件的类型.
CurrentType := GuiCtrl.Type
取决于控件类型, CurrentType 是以下字符串之一: ActiveX, Button, CheckBox, ComboBox, Custom, DateTime, DDL, Edit, GroupBox, Hotkey, Link, ListBox, ListView, MonthCal, Pic, Progress, Radio, Slider, StatusBar, Tab, Tab2, Tab3, Text, TreeView, UpDown.
检索或设置具有值的控件的内容.
CurrentValue := GuiCtrl.Value
GuiCtrl.Value := NewValue
注意: 如果控件不包含值, CurrentValue 将是空白, 并且赋值 NewValue 将引发错误. 无效的值会抛出异常.
CurrentValue 和 NewValue 的值取决于控件类型:
ActiveX
CurrentValue 是 ActiveX 控件的 ActiveX 对象. 例如, 如果控件是用文本 Shell.Explorer 创建的, 这是一个 WebBrowser 对象. 每次都返回相同的包装器对象.
NewValue 无效并抛出异常.
CheckBox / Radio
如果选中了 CheckBox 或 Radio 控件, 则 CurrentValue 为 1, 如果未选中, 则为 0, 如果有灰色复选标记, 则为 -1.
NewValue 可以是 0 来取消选中按钮, 1 来选中它, 或者 -1 来给它一个灰色的复选标记. 对于 Radio 按钮, 如果有一个按钮被选中(打开) 并且它是一个多个单选按钮组的成员, 那么该组中的其他单选按钮将被自动取消选中.
如果要获取或设置控件的文本/标题, 请使用 Text 属性.
ComboBox / DropDownList / ListBox / Tab
CurrentValue 是当前选中的项目/标签在 ComboBox, DropDownList, ListBox 或 Tab 控件中的位置编号. 如果没有选择, 则返回 0. 如果在 ComboBox 中输入了文本, 则使用第一个匹配文本的项目. 如果没有匹配的项目, 即使控件中有文本, 结果也是 0. 对于一个多选 ListBox, 结果是一个数字数组(如果没有选择任何项目, 则为空).
NewValue 是要选择的单个项目/标签的位置编号, 或者为零来清除当前的选择(即使对 Tab 控件也有效). 要选择多个项目, 请重复调用 Choose 方法.
要获取或设置选中项的文本而不是其位置, 请使用 Text 属性.
DateTime / MonthCal
CurrentValue 是当前在 DateTime 或 MonthCal 控件中选择的 YYYYMMDDHH24MISS 格式的日期-时间戳.
NewValue 是 YYYYMMDDHH24MISS 格式的日期-时间戳. 指定 A_Now
来使用当前日期和时间(今天). 对于 DateTime 控件, NewValue 可以是一个空字符串, 以使该控件没有选择日期/时间(如果它在创建时含有这个能力). 对于 MonthCal 控件, 如果控件是多选的, 则可以指定一个日期范围.
Edit
CurrentValue 是 Edit 件的当前内容. 对于多行控件, 文本中的任何换行符将以普通换行符(`n) 表示, 而不是 ControlGetText 和 ControlSetText 等非 GUI 函数所使用传统的 CR+LF(`r`n).
NewValue 是新的内容. 对于多行控件, NewValue 中任何缺少前回车(`r) 的换行(`n) 都会被自动转换为 CR+LF(`r`n) 以使其正确显示. 然而, 这通常不是一个问题, 因为当使用 MyGui.Submit 或检索这个值时, 这个转换会自动反过来, 用 LF(`n) 替换 CR+LF.
要检索或设置文本, 而不将 `n 转换为 `r`n, 请使用 Text 属性.
Hotkey
如果 Hotkey 控件中有热键, 则 CurrentValue 为修饰符和键名; 否则为空. 例如: ^!C
, ^Home
, +^NumpadHome
.
NewValue 可以是一组修饰符和键名, 或空白以清空该控件. 例如: ^!c
, ^Numpad1
, +Home
. 支持的修饰符仅包含 ^(Control), !(Alt), 和 +(Shift). 请参阅按键列表了解可用的按键名称.
Picture
CurrentValue 是创建 Picture 控件时指定的图片文件名. 即使指定了新的图片文件名, 这个名称也不会改变.
NewValue 是要加载的新图片的文件名(或句柄)(关于支持的文件类型, 请参阅 Picture). 可以在文件名前指定零个或多个下列选项: *wN
(宽度 N), *hN
(高度 N) 和 *IconN
(DLL 或 EXE 文件中的图标组编号 N). 在下面的例子中, 将加载第二个图标组中的默认图标, 设置宽度为 100 以及通过 "保持高宽比" 自动设置高度: MyPic.Value := "*icon2 *w100 *h-1 C:\My Application.exe"
. 指定 *w0 *h0
使用图像的实际宽度和高度. 如果同时省略 *w
和 *h
, 则调整图像以适应控件当前的大小. 从多图标的 .ICO 文件中加载时, 指定宽度和高度也决定了加载哪个图标. 注意: 在最后的选项和文件名之间只使用一个空格或制表符; 任何其他空格和制表符都会被视为文件名的一部分.
Progress / Slider / UpDown
CurrentValue 是 Progress, Slider 或 UpDown 控件的当前位置.
NewValue 是控件的新位置, 例如 MySlider.Value := 10
. 要调整一个相对的数值, 请使用运算符 +=
, -=
, ++
或 --
代替 :=
. 如果新的位置超出了控件的范围, 控件一般会被设置为最近的有效值.
Text
CurrentValue 是 Text 控件的的文本/标题.
NewValue 是控件的新文本. 由于控件不会自动展开, 所以如果需要扩大控件, 请使用 GuiCtrl.Move(,, 300)
.
检索或设置控件的当前可见状态.
CurrentSetting := GuiCtrl.Visible
GuiCtrl.Visible := NewSetting
如果已经赋值, CurrentSetting 为 NewSetting, 否则默认为 1(true), 除非被 Hidden 选项覆盖.
NewSetting 是一个布尔值, 用于启用或禁用这个设置. 如果为 true, 控件可见. 如果为 false, 控件被隐藏.
对于 Tab 控件, 这也将显示或隐藏该 Tab 的所有子控件. 如果您还想阻止一个控件的快捷键(下划线字母) 工作, 通过 GuiCtrl.Enabled := false
禁用该控件.
当向控件(如 ListView, TreeView 或 ListBox) 添加大量项目时, 可以通过防止在进行更改时重绘控件来提高性能. 这是通过在添加项目之前使用 GuiCtrl.Opt("-Redraw")
和在添加项目之后使用 GuiCtrl.Opt("+Redraw")
来实现的. 对控件的更改, 如果在禁用重绘前还未显示, 一般在重绘重新启用后才会显示.
出于性能原因, 即使启用了重绘, 对控件内容的更改通常也不会立即重绘该控件. 相反, 当程序检查其内部消息队列时, 控件的部分区域被 "失效", 通常在短暂延迟后重新绘制. 脚本可以通过调用 Sleep -1
立即强制执行此操作.