app.hotkey - 全局热键 API

注册和管理全局键盘快捷键。插件可在后台响应快捷键。

权限: L3 dangerous(需要辅助功能权限)

方法

app.hotkey.bind(mods, key, callback)

注册全局快捷键。

参数:

  • mods (array) - 修饰键数组: "cmd", "shift", "alt"/"option", "ctrl"/"control", "fn"
  • key (string) - 按键名: "a"-"z", "0"-"9", "f1"-"f12", "space", "return", "tab", "escape", "left", "right", "up", "down", "delete", "home", "end", "pageup", "pagedown"
  • callback (function) - 快捷键触发时执行的回调函数

返回值: string, error - 热键 ID

-- 注册 Cmd+Shift+T
local id, err = app.hotkey.bind({"cmd", "shift"}, "t", function()
    app.notification.show("热键", "Cmd+Shift+T 被按下!")
end)

-- 注册 Ctrl+Alt+Space
app.hotkey.bind({"ctrl", "alt"}, "space", function()
    app.log.info("快速启动")
end)

app.hotkey.unbind(id)

注销指定快捷键。

参数:

  • id (string) - 热键 ID

返回值: boolean, error

local ok, err = app.hotkey.unbind(id)

app.hotkey.unbindAll()

注销当前插件的所有快捷键。

返回值: boolean

app.hotkey.unbindAll()

app.hotkey.list()

列出当前插件的已注册快捷键。

返回值: array<table> - 每项包含:

  • id (string) - 热键 ID
  • key (string) - 按键名
  • mods (array) - 修饰键数组
  • enabled (boolean) - 是否启用
local hotkeys = app.hotkey.list()
for _, hk in ipairs(hotkeys) do
    local mods = table.concat(hk.mods, "+")
    app.log.info(hk.id .. ": " .. mods .. "+" .. hk.key .. " enabled=" .. tostring(hk.enabled))
end

app.hotkey.enable(id)

启用已禁用的快捷键。

参数:

  • id (string) - 热键 ID

返回值: boolean, error

app.hotkey.disable(id)

临时禁用快捷键(不删除注册)。

参数:

  • id (string) - 热键 ID

返回值: boolean, error

-- 临时禁用
app.hotkey.disable(id)
-- ... 某些操作后 ...
-- 重新启用
app.hotkey.enable(id)

说明

  • 每个插件最多 20 个快捷键
  • 需要 macOS 辅助功能权限(系统偏好设置 > 隐私与安全性 > 辅助功能)
  • 相同按键组合不能被多个插件重复注册
  • 快捷键在应用的所有窗口和其他应用中均有效
  • 快捷键在插件卸载时自动注销
  • 回调在插件执行队列上调用(线程安全)
  • 快捷键不会消费原始事件,其他应用仍可接收

示例

快速操作面板

function MyPlugin:init()
    -- Cmd+Shift+K 打开快速操作
    app.hotkey.bind({"cmd", "shift"}, "k", function()
        local items = {
            {text = "新建文件", id = "new"},
            {text = "打开终端", id = "terminal"},
            {text = "复制路径", id = "copypath"},
        }
        local selected = app.chooser.show({
            title = "快速操作",
            items = items,
        })
        if selected then
            self:executeAction(selected[1])
        end
    end)
end
开发者文档
使用帮助
使用说明 脚本菜单 常见问题
脚本开发
开发指南
插件开发
快速开始 开发指南 示例插件
API 参考
概览 API 查询 插件信息 日志 Finder 上下文 插件设置 国际化
UI 与交互
对话框 进度条 系统通知 选择器 WebView 状态栏 Dock
文件与路径
文件操作 路径工具 Finder 操作 废纸篓 扩展属性 元数据 文件监听
数据格式
JSON Plist CSV XML PDF 图片
文本与编码
字符串 正则表达式 日期时间 颜色 加密编码
系统
Shell 命令 进程管理 应用管理 系统信息 AppleScript 快捷指令
系统信息
网络信息 电源/电池 屏幕/外观 音频控制 蓝牙设备 位置服务
网络
HTTP 请求 WebSocket URL 工具
输入与剪贴板
键盘模拟 鼠标模拟 全局热键 剪贴板 窗口管理
存储
SQLite Keychain UserDefaults
媒体
文字识别 二维码
工具
归档 类型标识 分享 定时器 防休眠 并发/协程