Install
openclaw skills install fn-ime-voice-switchmacOS 上用 Hammerspoon 实现按住 Fn 切到豆包语音输入、松开切回默认输入法的自动化方案。包含权限设置、输入法 ID 查找、微信输入法 Fn 拦截绕过、init.lua 模板。
openclaw skills install fn-ime-voice-switch在 macOS 上让"打字默认 IME + 语音用豆包"的两难变成一个键:按住 Fn 切到豆包并触发语音,松开自动切回默认 IME。整套流程不需要模拟按键,只切输入法。
当用户说以下任意一种时启动:
/fn-ime-voice-switch豆包输入法本身允许把"语音输入快捷键"设为「长按 Fn」。所以用户态程序只要把当前输入法切到豆包,豆包会自然响应那个 Fn 长按、开始录音。整套方案:
按住 Fn → Hammerspoon 监听到 flagsChanged → 切到豆包 → 豆包响应 Fn 长按开始录音
松开 Fn → Hammerspoon 监听到 flagsChanged → 切回原 IME
| 参数 | 必填 | 说明 |
|---|---|---|
| 默认输入法 | ✅ | 用户日常打字用的 IME(微信、搜狗、系统拼音等) |
| 豆包是否已装 | ✅ | 必须先装豆包输入法 PC 版 |
| 默认 IME source ID | ❌ | 不确定时通过 hs.keycodes.methods(true) 查 |
按顺序检查并引导用户:
确认两个输入法已装并加入系统
安装 Hammerspoon(用户目录方案,避开 sudo)
brew install --cask --appdir=$HOME/Applications hammerspoon
open ~/Applications/Hammerspoon.app
说明:--appdir=$HOME/Applications 把 app 装到用户目录。brew cask 默认要 sudo 拷到 /Applications,没法弹密码的环境会失败。装到 ~/Applications 一样能用,菜单栏有图标,brew 一样能升级。
授权 TCC 权限
去 系统设置 → 隐私与安全性,在以下两处都勾上 Hammerspoon:
这是整套方案最容易踩的坑。
如果默认是微信输入法:它出厂就绑了「长按 Fn = 语音输入」,并且是在系统底层装钩子把 Fn 事件全部吃掉。任何用户态 eventtap 都收不到——表现就是按 Fn 微信自己的录音条出来,Hammerspoon 半点反应没有。
必须先关它:进微信输入法偏好设置 → 语音输入/快捷键 → 把「长按 Fn」改成别的或直接关掉。一关 Fn 立马正常下发。
如果默认是搜狗、系统拼音、其他:实测不抢 Fn,可以跳过。但保险起见,看一眼那个输入法的快捷键面板,确认没有把 Fn 绑给它自己就行。
排查思路:在 init.lua 里加事件计数器,按 Shift 看数字涨不涨,再按 Fn 比对。Shift 涨、Fn 不涨就是被某个高优先级钩子抢了,99% 是某个输入法自己。
豆包菜单栏图标 → 偏好设置 → 语音输入 → 快捷键 → 选「长按 Fn」。
把模板放到 ~/.hammerspoon/init.lua:模板见 templates/init.lua。
需要替换的占位符:
{{DEFAULT_INPUT}} → 用户默认 IME 的 source ID常见 IME source ID 速查:
| 输入法 | source ID |
|---|---|
| 微信输入法 | com.tencent.inputmethod.wetype.pinyin |
| 搜狗输入法 | com.sogou.inputmethod.sogou.pinyin |
| 系统拼音 | com.apple.inputmethod.SCIM.ITABC |
| 豆包输入法 | com.bytedance.inputmethod.doubaoime.pinyin |
不确定就跑:
hs -c "hs.keycodes.methods(true)"
⚠️ 不要信 defaults read com.apple.HIToolbox AppleEnabledInputSources——这份 plist 是缓存,与系统不实时同步,列表里可能根本没有刚装的输入法但实际能用。靠它判断会误判。hs.keycodes.methods(true) 走系统 API 拿真实可用列表。
hs -c 'hs.reload()'
或者 Hammerspoon 菜单 → Reload Config。
切到默认输入法,找个文本框按住 Fn 测试:屏幕右上角弹出"切到豆包",开始录音;松开切回默认。
如果按 Fn 没反应:
AppleFnUsageType:如果 macOS 系统设置里把 Fn 设成"什么都不做"或"显示 Emoji",可能影响事件下发。改回"开始听写"或类似选项。调试小技巧:Hammerspoon 装好后会软链 CLI 到 /opt/homebrew/bin/hs,可以从外部直接发命令验证:
hs -c 'hs.keycodes.currentSourceID("com.bytedance.inputmethod.doubaoime.pinyin")'
hs -c 'hs.keycodes.currentSourceID()'
hs -c 'hs.reload()'
切输入法、读当前状态、reload 配置全不用动鼠标。
完成后,用户体验:
hs.eventtap 和 hs.keycodes)hs.keycodes API:https://www.hammerspoon.org/docs/hs.keycodes.htmlhs.eventtap API:https://www.hammerspoon.org/docs/hs.eventtap.html