限制: 下面描述的 AutoHotkey 重映射功能通常不如直接通过 Windows 注册表进行映射那么纯粹和有效. 对于每种方法的优点和缺点, 请参阅注册表重映射..
内置重映射功能的语法为 OriginKey::DestinationKey
. 例如, 只包含下面这行内容的脚本会将 A 重映射成 B:
a::b
上面的例子并不改变 B 键本身. B 将继续发送 "b" 的键击, 除非把它重映射到其他内容, 如下面的示例所示:
a::b b::a
上述例子中使用小写字母, 在大多数情况下建议这么做, 因为它也会映射相应的大写字母(即在 CapsLock "打开" 或 Shift 被按住时会发送大写形式). 与之相比, 在右边使用大写字母会强制发送大写形式. 例如, 下面的代码行在您输入 "a" 或 "A" 时都会产生大写字母 B(只要 CapsLock 是关闭的):
a::B
相反, 在发送按键时, 将自动释放包含在左侧但不包含在右侧的任何修饰符. 例如, 以下两行会产生一个小写字母 "b", 当你按下 Shift+A 或 Ctrl+A 时:
A::b ^a::b
要重映射鼠标而不是键盘, 请使用相同的方法. 例如:
示例 | 描述 |
---|---|
MButton::Shift |
把鼠标中键映射成 Shift. |
XButton1::LButton |
把第四个鼠标按钮映射成鼠标左键. |
RAlt::RButton |
把右 Alt 映射成鼠标右键. |
示例 | 描述 |
---|---|
CapsLock::Ctrl |
把 CapsLock 映射成 Ctrl 键. 要保留打开及关闭 CapsLock 的功能, 需先包含重映射 +CapsLock::CapsLock . 这样, 当按住 Shift 并按下 CapsLock 时, 可切换 CapsLock 的开关状态. 因为两个重映射均允许附加修饰键被按下, 额外指定的 +CapsLock::CapsLock 重映射必须优先放置以便能正常工作. |
XButton2::^LButton |
把第五个鼠标按钮(XButton2) 映射成 control-click. |
RAlt::AppsKey |
把右 Alt 映射成 Menu(这是打开上下文菜单的按键). |
RCtrl::RWin |
把右 Ctrl 映射成右 Win. |
Ctrl::Alt |
把左右 Ctrl 映射成 Alt. 但是, 请参阅 alt-tab 的问题. |
^x::^c |
把 Ctrl+X 映射成 Ctrl+C. 它也会让 Ctrl+Alt+X 映射成 Ctrl+Alt+C, 等等. |
RWin::Return |
通过简单的return, 来禁用右 Win. |
您可以通过将这些示例复制到一个新的文本文件(如 "Remap") 中来尝试其中任何一个示例, 然后启动文件.
有关键和鼠标按钮名称的完整列表, 请参阅按键列表.
#HotIf 指令可用于仅在指定的窗口(或者当满足任何给定条件时) 激活选定的重映射. 例如:
#HotIf WinActive("ahk_class Notepad") a::b ; 使 'a' 键发送 'b' 键, 但仅在记事本中有效. #HotIf ; 这里让后续的重映射和热键对所有窗口生效.
重映射按键或按钮在以下方面是 "完全的":
b::a
会在您按下 Ctrl+B 时产生 Ctrl+A 的效果.尽管被重映射的按键可以触发普通热键, 但默认情况下它不能触发鼠标热键或钩子热键(请使用 ListHotkeys 来找出哪些热键使用了 "钩子"). 例如, 如果重映射 a::b
有效, 那么按下 Ctrl+Alt+A 会触发 ^!b
热键, 但仅在 ^!b
不是钩子热键的时候. 如果 ^!b
是钩子热键, 而且您希望使用 Ctrl+Alt+A 来执行和 Ctrl+Alt+B 相同的动作, 那么您可以把 ^!a
定义为热键. 例如:
a::b ^!a:: ^!b::ToolTip "You pressed " A_ThisHotkey
或者, 使用 #InputLevel 来覆盖此默认行为. 例如:
#InputLevel 1 a::b #InputLevel 0 ^!b::ToolTip "You pressed " A_ThisHotkey
如果在脚本启动时使用了 SendMode, 那么它会影响所有的重映射. 但是, 由于重映射使用 Send "{Blind}" 而 SendPlay 模式不完全支持 {Blind}, 所以一些映射在 SendPlay 模式中可能无法正常运行(尤其是 Ctrl, Shift, Alt 和 Win). 要解决此问题, 当您脚本中含有重映射时请避免在脚本启动时使用 SendMode "Play"
; 而仅在整个脚本需要的地方使用 SendPlay 函数而不是 Send. 或者, 您可以把您的重映射转换为热键(如下所述), 这样就显式调用 SendEvent 而不是 Send.
如果 DestinationKey 是按键 {
, 它必须进行转义, 例如, x::`{
. 否则它将被解释为热键函数的左大括号.
加载脚本时, 每个重映射会被转换为一对热键. 例如, 包含重映射 a::b
的脚本实际包含下面的两个热键:
*a:: { SetKeyDelay -1 ; 如果目标键是鼠标按钮, 则使用 SetMouseDelay 代替. Send "{Blind}{b DownR}" ; DownR 和 Down 相似, 不过使用 DownTemp 时脚本中后面的其他 Send 命令则不会假定 "b" 仍然处于按下的状态. } *a up:: { SetKeyDelay -1 ; 请参阅下面的注意事项来了解在这段代码中两处 SetKeyDelay 都没有指定按键时长的原因. Send "{Blind}{b Up}" }
但是, 上面的两个热键在下列环境中会发生变化:
Send "{Blind}{LAlt DownR}"
这行语句替换为 Send "{Blind}{LCtrl up}{LAlt DownR}"
. 如果原按键为右 Ctrl 也会如此, 除非使用了 {RCtrl up}
. 这样做是为了确保系统将 Alt 键组合转换为好像没有按住 Ctrl 一样, 但它也会导致重映射覆盖任何先前的 {Ctrl down}. [v2.0.8+]: 为了向后兼容, 仍然发送未抑制的 Ctrl 键, 但不再需要用于其原始目的. 副作用可以通过用一对显式热键替换重映射来避免, 如上所示.RCtrl::RButton
), 在上面的热键中会使用 SetMouseDelay 代替 SetKeyDelay. 而且, 上面的首个热键会被替换为下面的热键, 这样避免了由于键盘的自动重复功能生成的重复的鼠标点击:
*RCtrl:: { SetMouseDelay -1 if not GetKeyState("RButton") ; 即鼠标右键还没有按下. Send "{Blind}{RButton DownR}" }
!#^+
中的任何修饰符如果应用于源按键而不是目标按键, 则将它们插入到单词 "Blind" 之后, 以允许 Send 释放这些修饰符. 例如, ^a::b
将使用 {Blind^}
. <^a::b
也会使用 {Blind^}
, 如果与 RCtrl 结合使用, 可能会产生意想不到的结果. 有关详情, 请参阅 Blind 模式.注意, SetKeyDelay 的第二个参数(按下持续时间) 在上面的热键中被省略了. 这是因为按下持续时间不适用于独立的按键按下或按键弹起事件, 例如 {b down}
和 {b up}
. 但是, 它适用于修饰键(Shift, Ctrl, Alt 和 Win) 状态的改变, 这会影响像 a::B
或 a::^b
这样的重映射. 因此, 脚本在脚本启动期间设置的任何按下持续时间将会应用于所有此类重映射.
由于重映射会被简单转换为上面描述的热键, 所以 Suspend 也会影响它们. 同样地, Hotkey 函数可以禁用或修改重映射. 例如, 下面的两个函数会禁用重映射 a::b
.
Hotkey "*a", "Off" Hotkey "*a up", "Off"
Alt-tab 的问题: 如果您把一个按键或鼠标按钮映射为 Alt, 那么这个键很可能无法正确实现 alt-tab 的功能. 一个可能的解决方法是添加热键 *Tab::Send "{Blind}{Tab}"
-- 但是需要注意这样很可能妨碍使用真正的 Alt 实现 alt-tab 的功能. 因此, 只有当您仅通过重映射的按键和/或 alt-tab 热键实现 alt-tab 功能时, 才应使用它.
除了按键列表 页面中的按键和鼠标按钮外, 源按键还可以是特殊按键章节描述的虚拟键(VKnn) 或扫描码(SCnnn). 对于目标键同样如此, 不过它还可以在虚拟键后指定扫描码. 例如, 在大多数键盘布局中 sc01e::vk42sc030
等同于 a::b
.
要禁用按键而不进行重映射, 请把它设置为只含有 returns 的热键. 例如, F1::return
会禁用 F1.
内置的重映射方法不支持下列按键:
vk13
或对应的扫描码代替.x::+sc01A
和 y::+sc01B
.键盘可以用来移动鼠标光标, 如功能齐全的键盘到鼠标脚本所示. 由于该脚本提供了鼠标平滑移动, 加速和其他特性, 所以如果您想使用键盘进行大量的鼠标操作, 那么推荐使用该脚本. 相比之下, 下面的例子是一个更简单的例子:
*#up::MouseMove 0, -10, 0, "R" ; Win+UpArrow 热键 => 上移光标 *#Down::MouseMove 0, 10, 0, "R" ; Win+DownArrow => 下移光标 *#Left::MouseMove -10, 0, 0, "R" ; Win+LeftArrow => 左移光标 *#Right::MouseMove 10, 0, 0, "R" ; Win+RightArrow => 右移光标 *<#RCtrl:: ; 左 Win + 右 Control => Left-click(按住 Control/Shift 来进行 Control-Click 或 Shift-Click). { SendEvent "{Blind}{LButton down}" KeyWait "RCtrl" ; 防止键盘自动重复导致的重复鼠标点击. SendEvent "{Blind}{LButton up}" } *<#AppsKey:: ; 左 Win + AppsKey => Right-click { SendEvent "{Blind}{RButton down}" KeyWait "AppsKey" ; 防止键盘自动重复导致重复的鼠标点击. SendEvent "{Blind}{RButton up}" }
优点:
缺点:
如何将更改应用于注册表: 使用注册表重映射按键至少有两种方法: