ai_member_xiaobian/.agents/skills/lark-whiteboard/routes/svg.md
2026-05-15 10:57:05 +08:00

3.5 KiB
Raw Blame History

SVG 路径

你在设计一张专业的信息图——内容扎实, 美观漂亮, 具有设计感和视觉张力, 不是枯燥的布局和文字堆砌, 不要做的像普通的网页或者千篇一律的模版 最终交付是画板跨越重排渲染的节点(你写 SVG → 画板解析)

核心心智纠正 (重要)

  • 大多数 AI 如果只考虑“绝对不报错/完美映射”, 最终给出的都是全篇纯白底色加单层 <rect> 的方正卡片网格, 极其死板单调, 这将被视为不及格!
  • SVG 给你了完全的设计自由, 请大胆使用你脑内的图标路径 (<path>), 连接指引 (流畅的 <path>), 各种环境氛围点缀, 大胆一点, 充分信任你的品味, 发挥出你的顶级艺术创造力!

Workflow

1. 想清楚要画什么

  • 核心信息是什么? 能做到一图胜千言, 绝对不要只生成平平无奇的文字表格, 要有设计感
  • 内容充实度:如果用户描述稀疏简略, 利用你的领域知识扩展, 保证信息维度和内容充实, 但不要过度堆砌, 淹没重点
  • 视觉层级与隐喻:这个没有固定的形式, 你自由判断, 比如: 给重要的节点加光环, 加高亮背景;给对比项设计天平或对称结构

2. 写 SVG

[!IMPORTANT] 布局, 配色, 信息密度, 装饰物——全部由你判断, 打破单调的 <rect> 牢笼, 严禁通篇用矩形和文字应付用户

操作边界约束:

  • 语言跟随用户:图表文字的语言与用户 prompt 保持一致, 技术术语用行业里通用的写法, 不机械翻译
  • 文字用 <text>(不是 <path>), 容器宽度留够——画板按 CJK ≈ 1em / Latin ≈ 0.6em 重排
  • 连线使用正交折线替代斜直线(<polyline> 带水平/垂直折点)视觉效果更好
  • 可自由使用 translate, rotate, scale但请尽量避免使用 skewX / skewY / matrix(...) 发生空间级扭曲

3. 渲染审查

建目录   ./diagrams/YYYY-MM-DDTHHMMSS/         (例:./diagrams/2026-04-15T143022/)
写文件   <dir>/diagram.svg
渲染     npx -y @larksuite/whiteboard-cli@^0.2.10 -i <dir>/diagram.svg -o <dir>/diagram.png -f svg
检查     npx -y @larksuite/whiteboard-cli@^0.2.10 -i <dir>/diagram.svg -f svg --check
导出     npx -y @larksuite/whiteboard-cli@^0.2.10 -i <dir>/diagram.svg -f svg --to openapi --format json > <dir>/diagram.json

npx -y @larksuite/whiteboard-cli@^0.2.10 --check 检测 text-overflownode-overlap, 并结合视觉效果(查看 PNG)进行调整

画板怎么处理 SVG

画板的 svg-parser 把可识别元素转成可编辑节点, 其余降级为内嵌图片(渲染没问题, 虽然不可编辑, 但是可以正常显示);但 <radialGradient> / <filter> / <clipPath> 等装饰特性画板完全不支持,会导致渲染问题(见下方⚠️ 不需要所有元素都可编辑, 但必须避免使用不支持的装饰特性, 且要兼顾可编辑和美观漂亮

可识别的元素

  • 形状:<rect> / <circle> / <ellipse> / <polygon>
  • 连线:<line> / <polyline> / <path>(自动识别为直线 / 折线 / 曲线)
  • 文本:<text> / <tspan> 画板硬编码 Noto Sans SC 文字必须用 <text>
  • 分组:<g> / <a> / <use> 引用 <symbol>
  • 变换:translate / rotate / scale 正常;skewX / skewY / matrix(...) 降级

⚠️ [!IMPORTANT] 不支持的装饰特性

  • <radialGradient> / <filter> / <pattern> / <clipPath> / <mask> → 画板都不支持,请避免使用,否则会导致画板渲染问题