GroupAdd

增加窗口规格到窗口组, 必要时创建组.

GroupAdd GroupName , WinTitle, WinText, ExcludeTitle, ExcludeText

参数

GroupName

类型: 字符串

要向其中添加此窗口规范的组的名称. 如果组不存在, 则会创建它. 组名不区分大小写.

WinTitle, WinText, ExcludeTitle, ExcludeText

类型: 字符串, 整数对象

WinTitle 指定窗口标题或其他条件, 来标识目标窗口, 和/或为 WinText 指定目标窗口的单个文本元素的子字符串(由包含的 Window Spy 实用程序显示).

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

窗口标题和文本是区分大小写的. 尽管 DetectHiddenWindows, DetectHiddenTextSetTitleMatchMode 不会直接影响此函数的行为, 但它们会影响其他组函数(例如 GroupActivateGroupClose). 它们还会影响其他任何函数的 WinTitle 参数中 ahk_group 的使用.

备注

每使用此函数一次则添加一条新规则到组中. 换句话说, 一个组由窗口规格的集合组成而不是固定的窗口列表. 后面当类似 GroupActivate的函数使用组时, 会使用这些规则中的每一条检查桌面上的每个窗口. 如果窗口匹配组里的其中一条规则, 则它被视为一个匹配.

窗口组的典型用法是将相关窗口收集绑定在一起, 这可用于包含许多相关窗口的任务或有许多子窗口的程序. 例如, 如果您频繁地工作在一个图形程序或文本编辑器的多个实例时, 您可以使用热键通过 GroupActivate 来切换此程序的每一个实例(每次一个), 而不需要使用 alt-tab 或任务栏按钮找到它们.

由于每组中的条目仅需要添加一次, 所以此函数通常使用在脚本启动时. 添加重复的条目到组中会被忽略.

要在一个组中包含 所有 窗口(除了特殊的 Program Manager 窗口), 请使用这个例子:

GroupAdd "AllWindows"

通过在 WinTitle 参数中指定 ahk_group MyGroupName, 所有的窗口函数都可以操作窗口组. 函数 WinMinimize, WinMaximize, WinRestore, WinHide, WinShow, WinCloseWinKill 会对一个组中的 所有 窗口进行操作. 要仅对顶层窗口进行操作, 请参照此例:

WinHide WinExist("ahk_group MyGroup")

与之相比, 其他的窗口函数(例如 WinActivateWinExist) 只对组中的顶层窗口进行操作.

GroupActivate, GroupDeactivate, GroupClose

示例

按下热键可以遍历所有打开的 MSIE 窗口.

; 在全局代码中, 启动时计算:
GroupAdd "MSIE", "ahk_class IEFrame" ; 只添加 Internet Explorer 窗口到该组.

; 设置一个热键激活该组, 它会遍历
; 打开的所有 MSIE 窗口, 每次一个
; (即每次使用热键时激活一个窗口).
Numpad1::GroupActivate "MSIE", "r"

按下热键, 每次访问一个 MS Outlook 2002 窗口.

; 在全局代码中, 启动时计算:
SetTitleMatchMode 2 
GroupAdd "mail", "Message - Microsoft Word" ; 针对当前正在撰写的邮件
GroupAdd "mail", "- Message (" ; 用于已打开的项目
; 需要附加文本以避免激活错误窗口:
GroupAdd "mail", "Advanced Find", "Sear&ch for the word(s)"
GroupAdd "mail", , "Recurrence:"
GroupAdd "mail", "Reminder"
GroupAdd "mail", "- Microsoft Outlook"

; 设置一个热键访问每个 Outlook 窗口(每次一个).
Numpad5::GroupActivate "mail"