ClawSkills logoClawSkills

Peekaboo

使用 Peekaboo CLI 捕获并自动化 macOS UI。

介绍

# Peekaboo

Peekaboo 是一个完整的 macOS UI 自动化命令行工具:用于捕获/检查屏幕、定位 UI 元素、驱动输入,以及管理应用程序/窗口/菜单。命令共享一个快照缓存,并支持 `--json`/`-j` 用于脚本编写。运行 `peekaboo` 或 `peekaboo <cmd> --help` 查看选项;`peekaboo --version` 打印构建元数据。提示:通过 `polter peekaboo` 运行以确保使用最新构建。

## 功能特性(所有 CLI 功能,不含 agent/MCP)

核心 - `bridge`:检查 Peekaboo Bridge 主机连接状态 - `capture`:实时捕获或视频导入 + 帧提取 - `clean`:清理快照缓存和临时文件 - `config`:初始化/显示/编辑/验证,包括提供商、模型、凭据 - `image`:捕获屏幕截图(屏幕/窗口/菜单栏区域) - `learn`:打印完整的代理指南 + 工具目录 - `list`:应用、窗口、屏幕、菜单栏、权限 - `permissions`:检查屏幕录制/辅助功能状态 - `run`:执行 `.peekaboo.json` 脚本 - `sleep`:暂停执行指定时长 - `tools`:列出可用工具,支持过滤和显示选项

交互 - `click`:通过 ID/查询/坐标定位目标,支持智能等待 - `drag`:在元素/坐标/Dock 之间拖放 - `hotkey`:修饰键组合,如 `cmd,shift,t` - `move`:光标定位,可选平滑效果 - `paste`:设置剪贴板 -> 粘贴 -> 恢复 - `press`:特殊按键序列,支持重复 - `scroll`:方向滚动(定向 + 平滑) - `swipe`:目标之间的手势式拖动 - `type`:文本 + 控制键(`--clear`,延迟)

系统 - `app`:启动/退出/重启/隐藏/显示/切换/列出应用 - `clipboard`:读取/写入剪贴板(文本/图片/文件) - `dialog`:点击/输入/文件/取消/列出系统对话框 - `dock`:启动/右键点击/隐藏/显示/列出 Dock 项目 - `menu`:点击/列出应用菜单 + 菜单扩展 - `menubar`:列出/点击状态栏项目 - `open`:增强型 `open`,支持应用定位 + JSON 负载 - `space`:列出/切换/移动窗口(空间) - `visualizer`:运行 Peekaboo 视觉反馈动画 - `window`:关闭/最小化/最大化/移动/调整大小/聚焦/列出窗口

视觉 - `see`:带注释的 UI 地图、快照 ID、可选分析

全局运行时标志 - `--json`/`-j`,`--verbose`/`-v`,`--log-level <level>` - `--no-remote`,`--bridge-socket <path>`

## 快速入门(理想路径) ```bash peekaboo permissions peekaboo list apps --json peekaboo see --annotate --path /tmp/peekaboo-see.png peekaboo click --on B1 peekaboo type "Hello" --return ```

## 常用定位参数(大多数交互命令) - 应用/窗口:`--app`、`--pid`、`--window-title`、`--window-id`、`--window-index` - 快照定位:`--snapshot`(来自 `see` 的 ID;默认为最新的) - 元素/坐标:`--on`/`--id`(元素 ID)、`--coords x,y` - 聚焦控制:`--no-auto-focus`、`--space-switch`、`--bring-to-current-space`、 `--focus-timeout-seconds`、`--focus-retry-count`

## 常用捕获参数 - 输出:`--path`、`--format png|jpg`、`--retina` - 定位:`--mode screen|window|frontmost`、`--screen-index`、 `--window-title`、`--window-id` - 分析:`--analyze "prompt"`、`--annotate` - 捕获引擎:`--capture-engine auto|classic|cg|modern|sckit`

## 常用动作/输入参数 - 计时:`--duration`(拖动/滑动)、`--steps`、`--delay`(输入/滚动/按键) - 拟人化动作:`--profile human|linear`、`--wpm`(打字) - 滚动:`--direction up|down|left|right`、`--amount <ticks>`、`--smooth`

## 示例 ### 查看 -> 点击 -> 输入(最可靠的流程) ```bash peekaboo see --app Safari --window-title "Login" --annotate --path /tmp/see.png peekaboo click --on B3 --app Safari peekaboo type "[email protected]" --app Safari peekaboo press tab --count 1 --app Safari peekaboo type "supersecret" --app Safari --return ```

### 按窗口 ID 定位 ```bash peekaboo list windows --app "Visual Studio Code" --json peekaboo click --window-id 12345 --coords 120,160 peekaboo type "Hello from Peekaboo" --window-id 12345 ```

### 截图 + 分析 ```bash peekaboo image --mode screen --screen-index 0 --retina --path /tmp/screen.png peekaboo image --app Safari --window-title "Dashboard" --analyze "Summarize KPIs" peekaboo see --mode screen --screen-index 0 --analyze "Summarize the dashboard" ```

### 实时捕获(运动感知) ```bash peekaboo capture live --mode region --region 100,100,800,600 --duration 30 \ --active-fps 8 --idle-fps 2 --highlight-changes --path /tmp/capture ```

### 应用 + 窗口管理 ```bash peekaboo app launch "Safari" --open https://example.com peekaboo window focus --app Safari --window-title "Example" peekaboo window set-bounds --app Safari --x 50 --y 50 --width 1200 --height 800 peekaboo app quit --app Safari ```

### 菜单、菜单栏、Dock ```bash peekaboo menu click --app Safari --item "New Window" peekaboo menu click --app TextEdit --path "Format > Font > Show Fonts" peekaboo menu click-extra --title "WiFi" peekaboo dock launch Safari peekaboo menubar list --json ```

### 鼠标 + 手势输入 ```bash peekaboo move 500,300 --smooth peekaboo drag --from B1 --to T2 peekaboo swipe --from-coords 100,500 --to-coords 100,200 --duration 800 peekaboo scroll --direction down --amount 6 --smooth ```

### 键盘输入 ```bash peekaboo hotkey --keys "cmd,shift,t" peekaboo press escape peekaboo type "Line 1\nLine 2" --delay 10 ```

说明 - 需要屏幕录制和辅助功能权限。 - 点击前使用 `peekaboo see --annotate` 来识别目标。

更多产品