ControlGetIndex

返回 ListBox, ComboBox 或 Tab 控件中当前选中的条目或标签的索引.

Index := ControlGetIndex(Control , WinTitle, WinText, ExcludeTitle, ExcludeText)

参数

Control

类型: 字符串, 整数对象

控件的 ClassNN, 文本或 HWND, 或具有 Hwnd 属性的对象. 有关详情, 请参阅 Control 参数.

WinTitle, WinText, ExcludeTitle, ExcludeText

类型: 字符串, 整数对象

如果这些都未设置或省略, 将使用上次找到的窗口. 否则, 为 WinTitle 指定窗口标题或其他条件, 来标识目标窗口, 和/或为 WinText 指定目标窗口的单个文本元素的子字符串(由包含的 Window Spy 实用程序显示). 如果 DetectHiddenText 已经打开, 则检测隐藏文本元素. 标题或文本包含 ExcludeTitleExcludeText 的窗口将不被考虑.

返回值

类型: 整数

此函数返回当前选择条目或标签页索引. 第一个条目或选项卡是 1, 第二个是 2, 依此类推. 如果未选择任何条目或选项卡, 则返回值为 0.

错误处理

如果找不到窗口或控件, 或者控件的类名不包含 "Combo", "List" 或 "Tab", 则抛出 TargetError.

如果消息不能被发送到控件, 则抛出 OSError.

备注

要改为发现 Tab 控件中存在多少个标签(页面), 请遵循以下示例:

TabCount := SendMessage(0x1304,,, "SysTabControl321", WinTitle)  ; 0x1304 为 TCM_GETITEMCOUNT.

窗口标题和文本是区分大小写的. 除非 DetectHiddenWindows 被打开, 否则不会检测隐藏窗口.

ControlChooseIndex, ControlGetChoice, ControlChooseString, Value 属性(GuiControl 对象), Choose 方法(GuiControl 对象), 控件函数

示例

检索第一个 Tab 控件的活动标签页序号.

WhichTab := ControlGetIndex("SysTabControl321", "Some Window Title")
MsgBox "Tab #" WhichTab " is active."
unixetc