通过索引选择列表框, 组合框, 下拉列表或标签页控件页面中的条目.
ControlChooseIndex N, ControlID , WinTitle, WinText, ExcludeTitle, ExcludeText
类型: 整数
选择条目或页面的索引, 其中 1 是第一项, 2 是第二项, 以此类推.
若要选择所有条目, 则指定 0. 对于选项卡控件而言, 指定 0 则此操作无效并抛出异常, 因为非图形用户界面窗口通常无法处理这种情况.
控件的 ClassNN, 文本或 HWND, 或具有 Hwnd 属性的对象. 有关详情, 请参阅控件标识符.
如果这些都是空白或省略, 将使用上次找到的窗口. 否则, 为 WinTitle 指定窗口标题或其他条件, 来标识目标窗口, 和/或为 WinText 指定目标窗口的单个文本元素的子字符串(由包含的 Window Spy 实用程序显示).
ExcludeTitle 和 ExcludeText 可用于根据标题或文本排除一个或多个窗口. 它们的规范类似于 WinTitle 和 WinText, 除了 ExcludeTitle 不识别除窗口标题之外的任何条件.
窗口标题和文本是区分大小写的. 默认情况下, 不检测隐藏窗口, 而检测隐藏文本元素, 除非使用 DetectHiddenWindows 和 DetectHiddenText 进行更改; 当使用纯 HWND 时, 都会检测隐藏窗口. 默认情况下, 窗口标题的任意位置包含 WinTitle 或 ExcludeTitle 就能形成匹配, 除非使用 SetTitleMatchMode 进行了更改.
如果找不到窗口或控件, 或者控件的类名不包含 "Combo", "List" 或 "Tab", 则抛出 TargetError.
如果无法应用更改, 则抛出 Error 或 OSError.
此函数适用于非图形用户界面窗口中的控件, 即那些并非通过 Gui 函数创建的窗口. 这个函数最适用于常见的或预定义的 Microsoft 控件; 而某些应用程序则使用自定义或修改后的控件, 在这种情况下, 函数可能无法按预期工作. 对于 GUI 控件, 通常使用 GuiControl.Choose 更方便.
要在 多选 列表框中选择所有项目, 请使用 PostMessage(0x0185, 1, -1, "ListBox1", WinTitle), 其中 0x0185 为 LB_SETSEL. 作为一种替代方法, 为 ControlGetItems 返回的数组中的每个项目调用这个函数:
for index, text in ControlGetItems("ListBox1", WinTitle)
ControlChooseIndex(index, "ListBox1", WinTitle)
与 GuiControl.Choose 不同, 此函数引发 Change 或 DoubleClick 事件.
为了提高可靠性, 每次使用此函数后都会自动执行延迟. 该延迟可以通过 SetControlDelay 或给 A_ControlDelay 赋值来更改. 有关详情, 请参阅 SetControlDelay 备注.
ControlGetIndex, ControlChooseString, GuiControl.Choose, 控件函数