Install
openclaw skills install excalidraw-handdraw-skill根据提示词生成手绘风格图表的 skill。用于:(1) 创建架构图、流程图、ER 图等 Excalidraw 手绘风格图表 (2) 通过 Docker 本地运行 canvas 服务器 (3) 生成 PNG/SVG 图片 (4) 保存图片到指定目录 (5) 将图表插入或替换到文件指定位置 (6) 支持中文手写字体。触发词:画图、创建图表、生成图表、手绘风格、架构图、流程图、Excalidraw、保存图表到文件、插入图表。
openclaw skills install excalidraw-handdraw-skill首先检查 Docker canvas 是否已运行:
docker ps | grep mcp_excalidraw-canvas
如果未运行,使用脚本启动:
./scripts/start-canvas.sh
确认服务可用:
curl -s http://localhost:3000/health
用户描述想要创建的图表类型,例如:
分析需求:
使用 batch_create_elements 批量创建元素。参考坐标系统:
max(160, labelCharCount * 9)JSON 元素示例:
{
"elements": [
{"id": "lb", "type": "rectangle", "x": 300, "y": 50, "width": 180, "height": 60, "text": "负载均衡器"},
{"id": "svc-a", "type": "rectangle", "x": 100, "y": 200, "width": 160, "height": 60, "text": "服务 A"},
{"id": "svc-b", "type": "rectangle", "x": 450, "y": 200, "width": 160, "height": 60, "text": "服务 B"},
{"type": "arrow", "x": 0, "y": 0, "startElementId": "lb", "endElementId": "svc-a"},
{"type": "arrow", "x": 0, "y": 0, "startElementId": "lb", "endElementId": "svc-b"}
]
}
创建后获取截图验证:
get_canvas_screenshot 获取图片发现问题时修复:
当图表完成后,使用 Playwright 导出只包含画布区域的图片(无 UI 按钮):
./scripts/export-canvas.sh [--output path]
默认输出到 /tmp/excalidraw-diagram.png
使用脚本保存到用户指定位置:
./scripts/save-to-file.sh --source <图片路径> --dest <目标路径>
示例:
./scripts/save-to-file.sh --source /tmp/diagram.png --dest docs/diagrams/architecture.png
将图片插入到 Markdown 文件:
插入到文件末尾:

插入到特定位置: 使用 sed 或脚本在指定标记位置插入:
# 在 <!-- diagram:start --> 和 <!-- diagram:end --> 之间插入
./scripts/insert-image.sh --file README.md --marker "diagram:start" --image path/to/image.png
替换已存在的图片:
./scripts/replace-image.sh --file README.md --old-image old.png --new-image new.png
| 操作 | 命令 |
|---|---|
| 启动 Canvas | ./scripts/start-canvas.sh |
| 停止 Canvas | ./scripts/stop-canvas.sh |
| 导出图片(仅画布) | ./scripts/export-canvas.sh /tmp/diagram.png |
| 保存到目录 | ./scripts/save-to-file.sh --source /tmp/d.png --dest docs/d.png |
| 插入到文件 | ./scripts/insert-image.sh --file README.md --marker "diagram:start" --image d.png |
| 替换图片 | ./scripts/replace-image.sh --file README.md --old d1.png --new d2.png |
fontFamily: "1" 或默认字体,Excalidraw 原生支持中文docker ps | grep mcp_excalidraw-canvas