SetTitleMatchMode

设置 WinTitle 参数在内置函数中的匹配行为, 如 WinWait.

SetTitleMatchMode MatchMode
SetTitleMatchMode Speed

参数

MatchMode

类型: 整数字符串

指定下列数字的其中一个或单词 RegEx:

上面的模式还会对 ExcludeTitle 产生与 WinTitle 相同的影响. 例如, 模式 3 要求被排除的窗口的标题必须准确匹配 ExcludeTitle.

Speed

类型: 字符串

以下单词之一来指定 WinTextExcludeText 参数应如何匹配:

Fast: 这是默认行为. 性能可能大大优于 Slow, 但某些类型的控件不会被检测到. 例如, 文本通常会在静态和按钮控件中被检测到, 但不会在编辑控件中被检测到, 除非它们为脚本所拥有.

Slow: 速度慢得多, 但适用于所有能响应 WM_GETTEXT 消息的控件.

备注

此函数影响所有窗口函数的行为, 例如 WinExistWinActivate. WinGetText 受影响的方式与其他函数相同, 但它总是使用 Slow 方法来检索文本.

如果未指定, 则 TitleMatchMode 默认为 2 和 fast.

如果使用窗口组, 则当前标题匹配模式适用于组中的每个单独的规则.

通常, 只有在无法通过其标题和 fast-模式文本唯一标识目标窗口时, 才应该使用 slow 模式. 这是因为当任意一个应用程序窗口正忙或 "无响应" 时, 慢速模式会非常慢.

Window Spy 有 Slow TitleMatchMode 的选项, 所以它很容易确定是否需要 Slow 模式.

如果您想同时改变两个属性, 请执行函数两次, 例如:

SetTitleMatchMode 2
SetTitleMatchMode "slow"

内置变量 A_TitleMatchModeA_TitleMatchModeSpeed contain 包含了当前的设置.

不管当前的 TitleMatchMode 如何, WinTitle, WinText, ExcludeTitleExcludeText 都是区分大小写的. 唯一的例外是带不区分大小写选项的 RegEx 模式; 例如: i)untitled - notepad.

每个新运行的线程(如 热键, 自定义菜单项定时子程序) 都会以此函数的默认设置开始. 这个默认设置可以通过在脚本启动中使用此函数来改变.

SetWinDelay, WinExist, WinActivate, RegExMatch

示例

强制窗口函数操作在开头处包含 WinTitle 而不是任意地方的窗口.

SetTitleMatchMode 1

允许窗口函数检测更多的控件类型, 但性能较低. 注意, Slow/Fast 可以独立于其他所有模式进行设置.

SetTitleMatchMode "Slow"
unixetc