跳到主要内容

概念图

生成扁平、极简、支持明暗模式的SVG图表,作为独立HTML文件,使用统一的教育视觉语言,包含9个语义颜色渐变、句子式排版和自动暗色模式。最适合教育类和非软件类视觉内容——物理装置、化学机理、数学曲线、实物(飞机、涡轮机、智能手机、机械手表)、解剖图、平面图、剖面图、叙事旅程(X的生命周期、Y的过程)、中心辐射式系统集成(智慧城市、物联网)以及分解层视图。如果该主题存在更专门的技能(如专用软件/云架构、手绘草图、动画解说等),则优先使用那些技能——否则,此技能也可作为通用SVG图表后备方案,具有简洁的教育风格。附带15个示例图表。

技能元数据

来源可选 — 使用 hermes skills install official/creative/concept-diagrams 安装
路径optional-skills/creative/concept-diagrams
版本0.1.0
作者v1k22(原始PR),移植至 hermes-agent
许可证MIT
标签diagrams, svg, visualization, education, physics, chemistry, engineering
相关技能architecture-diagram, excalidraw, generative-widgets

参考:完整 SKILL.md

信息

以下是该技能被触发时 Hermes 加载的完整技能定义。当技能激活时,Agent 会将其视为指令。

概念图

使用统一的扁平、极简设计系统生成生产级 SVG 图表。输出为单个自包含 HTML 文件,可在任何现代浏览器中呈现一致的效果,并支持自动明暗模式。

适用范围

最适合用于:

  • 物理装置、化学机制、数学曲线、生物学
  • 实物(飞机、涡轮机、智能手机、机械手表、细胞)
  • 解剖图、剖面图、分解层视图
  • 平面图、建筑改造图
  • 叙事旅程(X 的生命周期、Y 的流程)
  • 中心辐射式系统集成(智慧城市、物联网网络、电网)
  • 任何领域的教育/教科书风格可视化
  • 定量图表(分组柱状图、能量分布图)

请优先考虑其他工具的场景:

  • 具有深色科技美学的专用软件/云基础设施架构(如有 architecture-diagram 可用,请考虑使用)
  • 手绘白板草图(如有 excalidraw 可用,请考虑使用)
  • 动画解说或视频输出(请考虑使用动画技能)

如果该主题有更专门的技能可用,请优先使用。如果没有合适的,此技能可作为通用 SVG 图表后备方案——输出将带有下文所述的干净教育美学风格,这几乎是任何主题的合理默认选择。

工作流程

  1. 确定图表类型(参见下方“图表类型”)。
  2. 使用设计系统规则布局组件。
  3. templates/template.html 为包装器编写完整的 HTML 页面 — 将你的 SVG 粘贴到模板中 <!-- PASTE SVG HERE --> 的位置。
  4. 保存为独立的 .html 文件(例如 ~/my-diagram.html./my-diagram.html)。
  5. 用户直接在浏览器中打开 — 无需服务器,无需依赖。

可选:如果用户想要一个可浏览的多图表画廊,请参见底部的“本地预览服务器”。

加载 HTML 模板:

skill_view(name="concept-diagrams", file_path="templates/template.html")

该模板嵌入了完整的 CSS 设计系统(c-* 颜色类、文本类、亮/暗模式变量、箭头标记样式)。你生成的 SVG 依赖于这些类存在于宿主页面上。


设计系统

设计理念

  • 扁平:无渐变、无投影、无模糊、无发光或霓虹效果。
  • 极简:只展示核心内容。框内无装饰性图标。
  • 一致:每个图表使用相同的颜色、间距、排版和描边宽度。
  • 暗模式就绪:所有颜色通过 CSS 类自动适配 — 无需按模式设置 SVG。

调色板

9 个颜色梯度,每个有 7 个色阶。将类名放在 &lt;g&gt; 或形状元素上;模板 CSS 会处理两种模式。

类名50(最浅)100200400600800900(最深)
c-purple#EEEDFE#CECBF6#AFA9EC#7F77DD#534AB7#3C3489#26215C
c-teal#E1F5EE#9FE1CB#5DCAA5#1D9E75#0F6E56#085041#04342C
c-coral#FAECE7#F5C4B3#F0997B#D85A30#993C1D#712B13#4A1B0C
c-pink#FBEAF0#F4C0D1#ED93B1#D4537E#993556#72243E#4B1528
c-gray#F1EFE8#D3D1C7#B4B2A9#888780#5F5E5A#444441#2C2C2A
c-blue#E6F1FB#B5D4F4#85B7EB#378ADD#185FA5#0C447C#042C53
c-green#EAF3DE#C0DD97#97C459#639922#3B6D11#27500A#173404
c-amber#FAEEDA#FAC775#EF9F27#BA7517#854F0B#633806#412402
c-red#FCEBEB#F7C1C1#F09595#E24B4A#A32D2D#791F1F#501313

颜色分配规则

颜色编码的是含义,而非顺序。切勿像彩虹一样循环使用颜色。

  • 类别对节点分组——同一类型的所有节点共享一种颜色。
  • 使用 c-gray 表示中性/结构节点(开始、结束、通用步骤、用户)。
  • 每个图表使用 2-3 种颜色,而不是 6 种以上。
  • 对于一般类别,优先使用 c-purplec-tealc-coralc-pink
  • c-bluec-greenc-amberc-red 保留给语义含义(信息、成功、警告、错误)。

明/暗模式停止映射(由模板 CSS 处理——只需使用类名):

  • 浅色模式:50 填充 + 600 描边 + 800 标题 / 600 副标题
  • 深色模式:800 填充 + 200 描边 + 100 标题 / 200 副标题

排版

只有两种字号,没有例外。

类名字号字重用途
th14px500节点标题、区域标签
ts12px400副标题、描述、箭头标签
t14px400通用文本
  • 始终使用句子大小写。 不要使用标题大小写,也不要全大写。
  • 每个 &lt;text&gt; 必须带有类名(ttsth)。不允许有无类名的文本。
  • 所有框内文本设置 dominant-baseline="central"
  • 框内居中文本设置 text-anchor="middle"

宽度估算(近似):

  • 14px 字重 500:每个字符约 8px
  • 12px 字重 400:每个字符约 6.5px
  • 始终验证:box_width >= (char_count × px_per_char) + 48(每边 24px 内边距)

间距与布局

  • ViewBoxviewBox="0 0 680 H",其中 H = 内容高度 + 40px 缓冲。
  • 安全区域:x=40 到 x=640,y=40 到 y=(H-40)。
  • 框之间:最小间距 60px。
  • 框内部:水平内边距 24px,垂直内边距 12px。
  • 箭头间隙:箭头与框边缘之间 10px。
  • 单行框:高度 44px。
  • 双行框:高度 56px,标题与副标题基线之间 18px。
  • 容器内边距:每个容器内部至少 20px。
  • 最大嵌套:2-3 层。更深层次在 680px 宽度下会难以阅读。

描边与形状

  • 描边宽度:所有节点边框均为 0.5px。不要用 1px 或 2px。
  • 矩形圆角:节点使用 rx="8",内部容器使用 rx="12",外部容器使用 rx="16"rx="20"
  • 连接线路径:必须设置 fill="none"。否则 SVG 默认会填充黑色。

箭头标记

每个 SVG 的开头包含以下 &lt;defs&gt; 代码块:

<defs>
<marker id="arrow" viewBox="0 0 10 10" refX="8" refY="5"
markerWidth="6" markerHeight="6" orient="auto-start-reverse">
<path d="M2 1L8 5L2 9" fill="none" stroke="context-stroke"
stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"/>
</marker>
</defs>

在线上使用 marker-end="url(#arrow)"。箭头会通过 context-stroke 继承线条颜色。

CSS 类(由模板提供)

模板页面提供了以下 CSS 类:

  • 文本:.t.ts.th
  • 中性:.box.arr.leader.node
  • 色阶:.c-purple.c-teal.c-coral.c-pink.c-gray.c-blue.c-green.c-amber.c-red(均支持自动亮色/暗色模式)

无需重新定义这些类——只需在 SVG 中应用它们即可。模板文件中包含完整的 CSS 定义。


SVG 模板

模板页面中的每个 SVG 都以以下精确结构开头:

<svg width="100%" viewBox="0 0 680 {HEIGHT}" xmlns="http://www.w3.org/2000/svg">
<defs>
<marker id="arrow" viewBox="0 0 10 10" refX="8" refY="5"
markerWidth="6" markerHeight="6" orient="auto-start-reverse">
<path d="M2 1L8 5L2 9" fill="none" stroke="context-stroke"
stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"/>
</marker>
</defs>

<!-- 在此处放置图表内容 -->

</svg>

{HEIGHT} 替换为实际计算的高度(最后一个元素底部 + 40px)。

节点模式

单行节点(44px):

<g class="node c-blue">
<rect x="100" y="20" width="180" height="44" rx="8" stroke-width="0.5"/>
<text class="th" x="190" y="42" text-anchor="middle" dominant-baseline="central">Service name</text>
</g>

双行节点(56px):

<g class="node c-teal">
<rect x="100" y="20" width="200" height="56" rx="8" stroke-width="0.5"/>
<text class="th" x="200" y="38" text-anchor="middle" dominant-baseline="central">Service name</text>
<text class="ts" x="200" y="56" text-anchor="middle" dominant-baseline="central">Short description</text>
</g>

连接线(无标签):

<line x1="200" y1="76" x2="200" y2="120" class="arr" marker-end="url(#arrow)"/>

容器(虚线或实线):

<g class="c-purple">
<rect x="40" y="92" width="600" height="300" rx="16" stroke-width="0.5"/>
<text class="th" x="66" y="116">Container label</text>
<text class="ts" x="66" y="134">Subtitle info</text>
</g>

图表类型

根据主题选择合适的布局:

  1. 流程图 — CI/CD 流水线、请求生命周期、审批工作流、数据处理。单向流动(自上而下或从左到右)。每行最多 4-5 个节点。
  2. 结构/包含图 — 云基础设施嵌套、分层系统架构。大型外部容器包含内部区域。虚线矩形表示逻辑分组。
  3. API/端点映射图 — REST 路由、GraphQL 模式。从根节点出发的树形结构,分支到资源组,每个组包含端点节点。
  4. 微服务拓扑图 — 服务网格、事件驱动系统。服务作为节点,箭头表示通信模式,中间有消息队列。
  5. 数据流图 — ETL 流水线、流式架构。从左到右流动,从数据源经过处理到达目标。
  6. 物理/结构图 — 车辆、建筑、硬件、解剖结构。使用与物理形态匹配的形状——&lt;path&gt; 用于曲线主体,&lt;polygon&gt; 用于锥形形状,&lt;ellipse&gt;/&lt;circle&gt; 用于圆柱形部件,嵌套的 &lt;rect&gt; 用于隔间。参见 references/physical-shape-cookbook.md
  7. 基础设施/系统集成图 — 智慧城市、物联网网络、多域系统。中心辐射布局,中央平台连接子系统。语义线型(.data-line.power-line.water-pipe.road)。参见 references/infrastructure-patterns.md
  8. UI/仪表盘模拟图 — 管理面板、监控仪表盘。屏幕框架内嵌套图表/仪表/指示器元素。参见 references/dashboard-patterns.md。 对于物理架构图、基础设施图以及仪表盘图,请在生成前加载对应的参考文件——每个文件都提供了现成的 CSS 类和形状基元。

验证清单

在最终确定任何 SVG 之前,请验证以下所有项:

  1. 每个 &lt;text&gt; 都带有 ttsth 类。
  2. 盒子内的每个 &lt;text&gt; 都设置了 dominant-baseline="central"
  3. 用作箭头的每个连接 &lt;path&gt;&lt;line&gt; 都带有 fill="none"
  4. 没有箭头线穿过不相关的盒子。
  5. 对于 14px 文本,box_width >= (最长标签字符数 × 8) + 48
  6. 对于 12px 文本,box_width >= (最长标签字符数 × 6.5) + 48
  7. ViewBox 高度 = 最底部元素 + 40px。
  8. 所有内容保持在 x=40 到 x=640 范围内。
  9. 颜色类(c-*)应用于 &lt;g&gt; 或形状元素,绝不能用于 &lt;path&gt; 连接器。
  10. 箭头 &lt;defs&gt; 块必须存在。
  11. 不能有渐变、阴影、模糊或发光效果。
  12. 所有节点边框的描边宽度为 0.5px。

输出与预览

默认:独立 HTML 文件

编写一个用户可以直接打开的单个 .html 文件。无需服务器,无需依赖,离线可用。模式如下:

# 1. 加载模板
template = skill_view("concept-diagrams", "templates/template.html")

# 2. 填入标题、副标题,并粘贴你的 SVG
html = template.replace(
"<!-- DIAGRAM TITLE HERE -->", "SN2 反应机理"
).replace(
"<!-- OPTIONAL SUBTITLE HERE -->", "双分子亲核取代反应"
).replace(
"<!-- PASTE SVG HERE -->", svg_content
)

# 3. 写入用户选择的路径(默认写入 ./)
write_file("./sn2-mechanism.html", html)

告诉用户如何打开它:

# macOS
open ./sn2-mechanism.html
# Linux
xdg-open ./sn2-mechanism.html

仅当用户明确想要一个可浏览的多图画廊时使用。

规则:

  • 仅绑定到 127.0.0.1。绝不要用 0.0.0.0。将图表暴露在所有网络接口上,在共享网络中存在安全隐患。
  • 选择一个空闲端口(不要硬编码),并告知用户所选 URL。
  • 该服务器是可选的,且需主动启用——优先使用独立的 HTML 文件。

推荐做法(让操作系统选择一个空闲的临时端口):

# 将每个图表放在 .diagrams/ 下的独立文件夹中
mkdir -p .diagrams/sn2-mechanism
# ...写入 .diagrams/sn2-mechanism/index.html...

# 仅在回环地址上提供服务,使用空闲端口
cd .diagrams && python3 -c "
import http.server, socketserver
with socketserver.TCPServer(('127.0.0.1', 0), http.server.SimpleHTTPRequestHandler) as s:
print(f'Serving at http://127.0.0.1:{s.server_address[1]}/')
s.serve_forever()
" &

如果用户坚持使用固定端口,请使用 127.0.0.1:<端口>——仍然不要用 0.0.0.0。记录如何停止服务器(kill %1pkill -f "http.server")。


示例参考

examples/ 目录提供了 15 个完整且经过测试的图表。在编写类似类型的新图表之前,先浏览它们以了解可用的模式:

文件类型说明
hospital-emergency-department-flow.md流程图使用语义颜色的优先级路由
feature-film-production-pipeline.md流程图分阶段工作流,水平子流程
automated-password-reset-flow.md流程图带错误分支的认证流程
autonomous-llm-research-agent-flow.md流程图回环箭头,决策分支
place-order-uml-sequence.md时序图UML 时序图风格
commercial-aircraft-structure.md物理结构路径、多边形、椭圆以呈现真实形状
wind-turbine-structure.md物理截面地下/地上分离,颜色编码
smartphone-layer-anatomy.md分解视图左右交替标签,分层组件
apartment-floor-plan-conversion.md平面图墙壁、门,用红色虚线表示建议的改动
banana-journey-tree-to-smoothie.md叙事旅程蜿蜒路径,渐进状态变化
cpu-ooo-microarchitecture.md硬件流水线扇出,内存层次侧边栏
sn2-reaction-mechanism.md化学分子,弯曲箭头,能量曲线
smart-city-infrastructure.md中心辐射按系统区分的语义线型
electricity-grid-flow.md多阶段流程电压层级,流向标记
ml-benchmark-grouped-bar-chart.md图表分组柱状图,双轴
用以下代码加载任意示例:
skill_view(name="concept-diagrams", file_path="examples/<filename>")

快速参考:何时使用哪种图

用户说图表类型建议颜色
"展示管道"流程图灰色开始/结束,紫色步骤,红色错误,青色部署
"绘制数据流"数据管道(从左到右)灰色数据源,紫色处理,青色数据汇
"可视化系统"结构图(包含关系)紫色容器,青色服务,珊瑚色数据
"映射端点"API 树紫色根节点,每个资源组一个分支
"展示服务"微服务拓扑灰色入口,青色服务,紫色总线,珊瑚色工作节点
"绘制飞行器/车辆"物理图路径、多边形、椭圆以呈现真实形状
"智慧城市 / 物联网"中心辐射集成图每个子系统使用语义线型
"展示仪表盘"UI 线框图深色屏幕,图表颜色:青色、紫色、珊瑚色用于告警
"电网 / 电力"多级流程图电压层级(高压/中压/低压线宽)
"风力发电机 / 涡轮机"物理剖面图基础 + 塔筒剖视图 + 机舱颜色编码
"X 的旅程 / 生命周期"叙事旅程图蜿蜒路径,渐进状态变化
"X 的层次 / 分解图"分解层视图垂直堆叠,交替标签
"CPU / 流水线"硬件流水线垂直阶段,扇出到执行端口
"平面图 / 公寓"平面图墙壁、门,建议变更用红色虚线
"反应机理"化学图原子、键、弯箭头、过渡态、能量曲线