当用户提出以下意图时触发:
以下情况不触发本技能:
> 📚 渐进式加载:本技能采用渐进式 MD 体系,SKILL.md 为入口(≤230行),详细内容拆分到 references/*.md 按需加载。
draw.io.exe 打开,即时查看结果
| 文件 | 说明 |
|------|------|
| references/guide.md | 执行流程详解(思考-确认-迭代-版本回溯) |
| references/hooks.md | 钩子系统详解(8 个 Hook Point 实现) |
| references/generation.md | 图表生成参考(XML 结构/样式/模板) |
| references/api_reference.md | API 参考(CLI/SDK/脚本接口) |
| references/layout_rules.md | 坐标系与布局规则 |
| references/antipatterns.md | 反模式与常见错误 |
| references/faq.md | 常见问题与排错 |
| references/known_issues.md | 已知问题与修复记录 |
| references/changelog.md | 更新日志 |
| references/permissions.md | 权限说明 |
→ 详见 执行流程详解
本技能采用 思考(Think) → 确认(Confirm) → 迭代(Iterate) → 版本回溯(Version Control) 四阶段工作流。
→ 详见 执行流程详解
各阶段要点:
快捷模式(可跳过确认):
版本管理命令:
python {SKILL_DIR}/scripts/drawio_version.py init <文件.drawio> "初始版本"
python {SKILL_DIR}/scripts/drawio_version.py save <文件.drawio> "更新了 XX"
python {SKILL_DIR}/scripts/drawio_version.py list <文件.drawio>
python {SKILL_DIR}/scripts/drawio_version.py restore <文件.drawio> v2
关键操作由 Python 端自动执行,不依赖 LLM 自觉。
备份、版本管理初始化、版本上限清理均由钩子在脚本层直接完成,
LLM 无权跳过这些操作。
→ 详见 钩子系统
| Hook Point | 强制操作 | 说明 |
|---|---|---|
| pre_think | 输入非空校验(阻断) | 空输入直接阻断 |
| post_think | 分析结果校验 | 缺失字段仅警告 |
| pre_confirm | 选项完整性校验(阻断)+ 快捷跳过(清除选项) | 不足 2 项或快捷跳转均阻断/跳过 |
| post_confirm | 用户选择解析 | - |
| pre_iterate | 自动创建目录 + 自动备份 | 备份由 Python 调用 VersionManager |
| post_iterate | 输出校验 + 自动初始化版本管理 + 自动打开预览 | init 和预览都由 Python 执行 |
| pre_vc | 自动清理超限版本 | 删除最旧版本由 Python 执行 |
| post_vc | 版本状态报告 | - |
from drawio_hooks import hooks
# 在阶段开始时
results = hooks('pre_iterate', {
'output_path': output_path,
'is_update': True, # 会触发自动备份
})
for r in results:
if r.abort:
return # 钩子已处理,阻断并返回
if not r.success:
print(f'Warning: {r.message}')
# 在阶段结束时
results = hooks('post_iterate', {
'output_path': output_path, # 会触发自动 init 版本管理
})
from drawio_hooks import register, unregister
@register('pre_think', name='my_check', description='自定义校验')
def my_hook(ctx):
if 'special' not in ctx.get('user_input', ''):
return {'success': False, 'message': '缺少特殊参数', 'abort': True}
return {'success': True, 'message': 'ok'}
unregister('post_iterate', 'preview_trigger') # 禁用自动预览
python {SKILL_DIR}/scripts/drawio_hooks.py list # 查看所有注册钩子
python {SKILL_DIR}/scripts/drawio_hooks.py check # 全流程自检
python {SKILL_DIR}/scripts/drawio_hooks.py history # 查看执行历史
→ 详见 图表生成参考
→ 详见 API 参考
→ 详见 坐标系与布局规则
→ 详见 已知问题与修复记录
→ 详见 反模式
→ 详见 常见问题
{类型}_{描述}.drawio,如 architecture_microservice.drawio
_meta.json data_dir 声明 + frontmatter data_dir 字段
| 文件 | 路径 | 说明 |
|------|------|------|
| 核心库 | scripts/drawio_gen.py | 节点/连线/容器/XML 生成 |
| 模板库 | scripts/drawio_templates.py | 8 种图表模板 |
| Agent 入口 | scripts/drawio_agent.py | CLI/自然语言解析 |
| 版本管理 | scripts/drawio_version.py | 5 版本回溯系统 |
用户:帮我画一个微服务架构图,包含 API 网关、用户服务、订单服务和数据库
drawiodo:正在分析需求 → 判断为"架构图" → 输出方案:4 个容器+连线+数据库图标
用户确认后 → 生成 architecture_microservice.drawio → 自动打开预览
用户:在上次的系统架构图里加一个消息队列,在订单服务和用户服务之间
drawiodo:读取已存在的文件 → 自动备份(v2) → 在订单服务和用户服务之间插入消息队列节点和连线
→ 更新文件 → 自动打开预览展示变化
共 6 个版本