ControlGetChoice

返回列表框, 组合框或下拉列表中当前选中项的文本.

Choice := ControlGetChoice(ControlID , WinTitle, WinText, ExcludeTitle, ExcludeText)

参数

ControlID

类型: 字符串, 整数对象

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

WinTitle, WinText, ExcludeTitle, ExcludeText

类型: 字符串, 整数对象

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

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

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

返回值

类型: 字符串

此函数会返回当前选中的条目的文本. 若未选中任何条目, 则会抛出异常.

多选 列表框中, 返回值始终是具有键盘焦点的选项的文本. 这通常是在选择了多个选项的情况下, 最后被选中的那个选项的文本.

错误处理

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

失败时抛出 Error.

备注

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

要获取所选条目的索引, 请参考以下示例(仅使用前两行中的其中一行, 即对于列表框使用 LB_GETCURSEL, 而对于组合框或下拉列表使用 CB_GETCURSEL):

Index := SendMessage(0x0188, 0, 0, "ListBox1", WinTitle)  ; 0x0188 为 LB_GETCURSEL.
Index := SendMessage(0x0147, 0, 0, "ComboBox1", WinTitle)  ; 0x0147 为 CB_GETCURSEL.
; 将基数从 0 转换为 1, 这样第一个项目对应的索引将变为 1 而不是 0
; 而 0 则表示 "没有条目被选中":
Index += 1

ControlChooseString, ControlGetIndex, ControlChooseIndex, GuiControl.Value, GuiControl.Choose, 控件函数