GuiControl 对象

class Gui.Control extends Object

提供用于修改 GUI 控件并检索有关控件的信息的接口. Gui.Add, Gui.__ItemGuiCtrlFromHwnd 返回这种类型的对象.

下面使用 "GuiCtrl" 作为任何 Gui.Control 类实例的占位符.

Gui.Control 作为所有 GUI 控件的基类, 但是每种类型的控件都有自己的类. 以下一些方法是由适当的类的原型, 或 Gui.List 基类定义的. 有关完整列表, 请参阅内置的类.

除了从 Object 继承的方法和属性外, GuiControl 对象还具有以下预定义的方法和属性:

属性:

方法:

Type

检索控件的类型.

Type := GuiCtrl.Type

有关控件类型的完整列表, 请参阅 GUI 控件类型.

Hwnd

检索控件的窗口句柄(HWND).

Hwnd := GuiCtrl.Hwnd

控件的 HWND, 通常与 PostMessage, SendMessageDllCall 一起使用.

Name

检索或设置控件的名称.

RetrievedName := GuiCtrl.Name
GuiCtrl.Name := NewName

控件的名称可以与 Gui.__Item 一起使用, 以检索 GuiControl 对象. 对于大多数具有输入功能的控件, 该名称也被 Gui.Submit.

ClassNN

检索控件的 ClassNN.

ClassNN := GuiCtrl.ClassNN

Gui

检索控件的父 GUI 窗口的 Gui 对象.

GuiObj := GuiCtrl.Gui

Opt

添加或删除控件的各种选项和样式.

GuiCtrl.Opt(Options)
Options

类型: 字符串

控件专用通用选项和样式.

在下面的例子中, 该控件被禁用, 并且它的 background 恢复为系统默认值:

MyEdit.Opt("+Disabled -Background")

在下一个例子中, OK 按钮被变成了新的默认按钮:

OKButton.Opt("+Default")

虽然样式和扩展样式也被识别, 但其中一些样式在控件创建后无法应用或删除. 即使成功应用了某项更改, 控件也可能选择忽略它.

Move

移动和/或调整控件的大小.

GuiCtrl.Move(X, Y, Width, Height)
X, Y

类型: 整数

新的位置, 相对于 GUI 窗口的客户端区域, 即不包括标题栏, 菜单栏, 和边框的区域.

Width, Height

类型: 整数

新的尺寸.

ControlMove 不同的是, 本方法将 DPI 缩放应用于坐标(除非使用了 -DPIScale 选项).

示例

MyEdit.Move(10, 20, 200, 100)
MyEdit.Move(VarX+10, VarY+5, VarW*2, VarH*1.5)

Focus

设置键盘焦点到控件上.

GuiCtrl.Focus()

注意: 要让设置生效, 窗口一般不能处于最小化或隐藏状态.

Choose

设置 ListBox, DropDownList, ComboBox 或 Tab 控件中的选择为指定值.

GuiCtrl.Choose(Value)
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 不同, 该方法不会触发 ChangeDoubleClick 事件.

UseTab

使随后添加的控件属于 Tab 控件的指定标签.

GuiCtrl.UseTab(Value, ExactMatch)
Value

类型: 整数字符串

参数为 1 表示第一个条目, 2 表示第二个, 等等. 如果 Value 不是一个整数, 前面部分与 Value 匹配的标签将被使用. 搜索不区分大小写. 例如, 如果一个控件包含 "UNIX Text" 标签, 指定单词 unix(小写) 就可以使用它. 如果 Value 为 0, 是一个空白字符串或被省略, 随后的控件将被添加到 Tab 控件之外.

ExactMatch

类型: 整数(布尔值)

如果该参数为 true, Value 必须完全匹配, 但不区分大小写.

Add

将列表项目添加到 ListBox, DropDownList 或 ComboBox, 或将标签添加到 Tab 控件中.

GuiCtrl.Add(Items)
Items

类型: Array(数组)

要插入到控件列表末尾的字符串数组(例如 ["Red","Green","Blue"]). 要替换(覆盖) 列表, 请事先使用 GuiCtrl.Delete.

使用 GuiCtrl.Choose 选择一个项目.

相关: ListView.Add, TreeView.Add

Delete

删除 ListBox, DropDownList, ComboBox 或 Tab 控件的指定项或所有项.

GuiCtrl.Delete(Value)
Value

类型: 整数

参数为 1 表示第一个条目, 2 表示第二个, 等等. 如果省略, 则删除所有条目.

对于 tab 控件, 您应该注意到, 一个标签的子控件会与其原始的标签编号相关联; 也就是说, 它们永远不会与其标签的实际显示名称相关联. 因此, 重命名或删除一个选项卡不会改变子控件所属的选项卡号. 例如, 如果有三个选项卡 ["Red","Green","Blue"] 并且通过 MyTab.Delete(2) 删除了第二个选项卡, 则原来与 Green 相关联的子控件现在将与 Blue 相关联. 由于这种行为, 一般只应删除最后的标签页. 以这种方式删除的标签页可以在以后再添加回来, 届时它们将重新获得原来的控件集.

相关: ListView.Delete, TreeView.Delete

Value

检索或设置控件的内容.

RetrievedValue := GuiCtrl.Value
GuiCtrl.Value := NewValue

注意: 如果控件不包含值, RetrievedValue 将是空白, 并且赋值 NewValue 将引发错误. 无效的值会抛出异常.

以下控件类型包含值:

Picture

RetrievedValue 是创建 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 文件中加载时, 指定宽度和高度也决定了加载哪个图标. 注意: 在最后的选项和文件名之间只使用一个空格或制表符; 任何其他空格和制表符都会被视为文件名的一部分.

Text

RetrievedValueText 控件的的文本/标题.

NewValue 是控件的新文本. 由于控件不会自动展开, 所以如果需要扩大控件, 请使用 GuiCtrl.Move("w300").

Edit

RetrievedValueEdit 件的当前内容. 对于多行控件, 文本中的任何换行符将以普通换行符(`n) 表示, 而不是 ControlGetTextControlSetText 等非 GUI 函数所使用传统的 CR+LF(`r`n).

NewValue 是新的内容. 对于多行控件, NewValue 中任何缺少前回车(`r) 的换行(`n) 都会被自动转换为 CR+LF(`r`n) 以使其正确显示. 然而, 这通常不是一个问题, 因为当使用 MyGui.Submit 或检索这个值时, 这个转换会自动反过来, 用 LF(`n) 替换 CR+LF.

要检索或设置文本, 而不将 `n 转换为 `r`n, 请使用 GuiCtrl.Text.

Hotkey

如果 Hotkey 控件中有热键, 则 RetrievedValue 为修饰符和键名; 否则为空. 例如: ^!C, ^Home, +^NumpadHome.

NewValue 可以是一组修饰符和键名, 或空白以清空该控件. 例如: ^!c, ^Numpad1, +Home. 支持的修饰符仅包含 ^(Ctrl), !(Alt), 和 +(Shift). 请参阅按键列表了解可用的按键名称.

Checkbox / Radio

如果选中了 CheckboxRadio 控件, 则 RetrievedValue 为 1, 如果未选中, 则为 0, 如果有灰色复选标记, 则为 -1.

NewValue 可以是 0 来取消选中按钮, 1 来选中它, 或者 -1 来给它一个灰色的复选标记. 对于 Radio 按钮, 如果有一个按钮被选中(打开) 并且它是一个多个单选按钮组的成员, 那么该组中的其他单选按钮将被自动取消选中.

如果要获取或设置控件的文本/标题, 请使用 GuiCtrl.Text.

DateTime / MonthCal

RetrievedValue 是当前在 DateTimeMonthCal 控件中选择的 YYYYMMDDHH24MISS 格式的日期-时间戳.

NewValueYYYYMMDDHH24MISS 格式的日期-时间戳. 指定 A_Now 来使用当前日期和时间(今天). 对于 DateTime 控件, NewValue 可以是一个空字符串, 以使该控件没有选择日期/时间(如果它在创建时含有这个能力). 对于 MonthCal 控件, 如果控件是多选的, 则可以指定一个日期范围.

UpDown / Slider / Progress

RetrievedValueUpDown, SliderProgress 控件的当前位置.

NewValue 是控件的新位置, 例如 MySlider.Value := 10. 要调整一个相对的数值, 请使用运算符 +=, -=, ++-- 代替 :=. 如果新的位置超出了控件的范围, 控件一般会被设置为最近的有效值.

Tab / DropDownList / ComboBox / ListBox

RetrievedValue 是当前选中的项目/标签在 Tab, DropDownList, ComboBoxListBox 控件中的位置. 如果没有选择, 则返回 0. 如果在 ComboBox 中输入了文本, 则使用第一个匹配文本的项目. 如果没有匹配的项目, 即使控件中有文本, 结果也是 0. 对于一个多选 ListBox, 结果是一个数字数组(如果没有选择任何项目, 则为空).

NewValue 是要选择的单个项目/标签的位置, 或者为零来清除当前的选择(即使对 Tab 控件也有效). 要选择多个项目, 请重复调用 GuiCtrl.Choose.

要获取或设置选中项的文本而不是其位置, 请使用 GuiCtrl.Text.

ActiveX

RetrievedValueActiveX 控件的 ActiveX 对象. 例如, 如果控件是用文本 Shell.Explorer 创建的, 这是一个 WebBrowser 对象. 每次都返回相同的包装器对象.

Text

检索或设置控件的文本/标题.

RetrievedText := GuiCtrl.Text
GuiCtrl.Text := NewText

注意: 如果控件没有可见的标题文本和文本值, 则此属性对应于控件的隐藏标题文本(如 ControlGetText/ControlSetText).

标题/显示文本: Text 属性可检索或设置以下控件类型的标题/显示文本: Button, Checkbox, Edit, GroupBox, Link, Radio, Text. 由于控件不会自动展开, 请使用 GuiCtrl.Move("w300") 或类似的方法.

DateTime: Text 属性检索了控件显示的格式化文本. 不支持为控件指定格式化的日期/时间字符串. 要更改显示的日期/时间, 请为 GuiCtrl.Value 指定一个 YYYYMMDDHH24MISS 格式的日期-时间戳.

Edit: 与其他控件一样, 文本按原样检索或设置; 不用预先进行尾转换. 要检索或设置多行 Edit 控件的文本, 同时在 `r`n`n 之间进行转换, 请使用 GuiCtrl.Value.

StatusBar: Text 属性仅检索或设置第一部分的文本(使用 SB.SetText 可获得更大的灵活性).

List 项目文本: Text 属性为以下控件类型检索或设置当前选中的项目/标签: Tab, DropDownList, ComboBox, ListBox.

NewText 应该是要选择的项目/标签的全部文本(不区分大小写).

对于 ComboBox, 如果没有选中的项目, 则会检索控件编辑栏中的文本. 对于其他控件, RetrievedText 为空/空白. 同样, 如果 NewText 为空/空白, 则当前项/标签将被取消选择.

对于一个多选 ListBox, RetrievedText 是一个数组. NewText 不能是一个数组, 但如果多个项目匹配, 它们都会被选择. 要用不同的文本选择多个项目, 请重复调用 GuiCtrl.Choose.

要根据项目的位置编号而不是文本选择项目, 请使用 GuiCtrl.Value.

Redraw

重绘控件所占的 GUI 窗口区域.

GuiCtrl.Redraw()

虽然当重复和快速调用时, 可能会导致不必要的闪烁效果, 但它解决了某些控件类型(如 GroupBox) 的显示重影的问题.

SetFont

设置控件的字体字体, 大小, 样式和/或颜色.

注意: 省略这两个参数, 以将字体设置为 GUI 的当前字体, 如 Gui.SetFont 所设置. 否则, 任何未指定的字体属性将从控件的先前字体中复制. 只有在 Options 中指定的情况下, 文本颜色才会改变.

GuiCtrl.SetFont(Options, FontName)

关于这两个参数的详细说明, 请参阅 Gui.SetFont.

Enabled

检索控件当前交互状态, 或启用或禁用(灰色) 控件.

RetrievedState := GuiCtrl.Enabled
GuiCtrl.Enabled := NewState

对于 Tab 控件, 这也将启用或禁用该 Tab 的所有子控件. 然而, 任何通过 GuiCtrl.Enabled := false 显式禁用的子控件将记住该设置, 因此即使在其 Tab 控件被重新启用后也会保持禁用状态.

Visible

检索控件的当前可见状态, 或显示或隐藏它.

RetrievedState := GuiCtrl.Visible
GuiCtrl.Visible := NewState

对于 Tab 控件, 这也将显示或隐藏该 Tab 的所有子控件. 如果您还想阻止一个控件的快捷键(下划线字母) 工作, 通过 GuiCtrl.Enabled := false 禁用该控件.

Focused

检索控件当前焦点状态.

RetrievedState := GuiCtrl.Focused

注意: 要让设置生效, 窗口一般不能处于最小化或隐藏状态.

GetPos

获取控件的位置和大小.

GuiCtrl.GetPos(X, Y, Width, Height)

每个参数都应该是一个变量引用, 在其中存储各自的坐标. 位置是相对于 GUI 窗口的客户端区域而言的, 客户端区域是不包括标题栏, 菜单栏和边框的区域.

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 "."
unixetc