CAD制图编辑器cad-editor

CAD Editor(ClawHub)


name: cad-editor

author: 王教成 Wang Jiaocheng (波动几何)
description: >
CAD制图编辑器 --- 用自然语言生成工程图纸(建筑平面图/机械零件/电气布置/管道系统/结构详图)。
支持DXF文件创建、渲染预览、批量导出。触发词:画平面图、CAD、工程图、建筑图、机械图、电气图、
管道图、结构图、画线/圆/矩形/多边形、尺寸标注、DXF、AutoCAD、施工图、配筋图、齿轮、轴承、
阀门、弯头、三通、法兰、门窗、楼梯、墙体、梁板柱基础、螺栓螺母弹簧垫圈销钉键槽、
开关插座灯具配电箱断路器导线组、直管弯头阀门法兰大小头管帽。

CAD Editor Skill

将自然语言指令转换为工程图纸(DXF + PNG/SVG/PDF)。覆盖建筑、机械、电气、管道、结构五大领域,

遵循 GB/T 制图标准。

触发条件

当用户要求绘制 CAD 图纸、工程图、施工图、配筋图,或提及以下任一领域时使用本技能:

  • 建筑图纸:平面图、立面图、剖面图、门窗、楼梯、墙体、梁板柱基础
  • 机械图纸:螺栓、齿轮、轴承、弹簧、垫圈、螺母、销钉、键槽
  • 电气图纸:开关、插座、灯具、配电箱、断路器、导线组
  • 管道图纸:直管、弯头、三通、法兰、阀门、大小头、管帽
  • 结构详图:梁断面、楼板配筋、条形基础、独立基础
  • 通用几何:线、圆、弧、矩形、多边形、尺寸标注

工作流

步骤 1:解析自然语言指令

调用 NL 解析器识别意图并提取参数:

python 复制代码
import sys
sys.path.insert(0, 'cad-editor/scripts')

from nl_parser.intent_classifier import IntentClassifier
from nl_parser.param_extractor import ParamExtractor

classifier = IntentClassifier()
intent = classifier.classify(user_input)       # → intent_dict
extractor = ParamExtractor(intent['domain'])
params = extractor.extract(user_input)          # → param_dict

references/intent_templates.json 包含 52 条预定义意图映射模板,涵盖 6 大类图纸。

步骤 2:生成绘图脚本

根据意图类型调用脚本生成器:

python 复制代码
from nl_parser.script_generator import ScriptGenerator

gen = ScriptGenerator()
script_code = gen.generate(intent, params)      # → Python str

生成器内置 18 套脚本模板,按领域分:

领域 模板数 覆盖组件
architectural 5 墙/门/窗/柱/楼梯
mechanical 4 螺栓/齿轮/轴承/弹簧
electrical 3 开关/插座/灯具/导线组
piping 3 直管/弯头/三通/阀门
structural 3 梁断面/楼板/基础

步骤 3:执行脚本生成 DXF

python 复制代码
# 将 script_code 写入临时文件后执行,或直接 exec
exec(script_code)
# 输出:{output_dir}/{name}.dxf

步骤 4:渲染预览图片

python 复制代码
from core.renderer import Renderer
Renderer.render_quick(doc, output_dir='output', name='drawing_name')
# 输出:{output_dir}/drawing_name.png (自动生成)

步骤 5:交付结果

向用户展示 PNG 预览图,同时提供 DXF 文件路径。

直接 API 调用方式(跳过 NL 解析)

当需要精确控制或编程调用时,直接使用 Python API:

python 复制代码
import sys
sys.path.insert(0, 'cad-editor/scripts')

from core.document import CADDocument
from core.renderer import Renderer
from layer.manager import LayerManager
from layer.linetypes import Linetypes
from entities import *
from templates.architectural import ArchitecturalTemplates
from dimension import LinearDimension
from layout.paperspace import PaperSpace

doc = CADDocument.new(version='R2010')
msp = doc.modelspace()

Linetypes.load_standard(doc)
LayerManager(doc).setup_template('arch')

ArchitecturalTemplates.wall(msp, [(0,0), (5000,0), (5000,3500), (0,3500)], thickness=240)
ArchitecturalTemplates.door_single(msp, (2500, 0), width=900)
ArchitecturalTemplates.window(msp, (800, 240), (2000, 240))
LinearDimension.chain_horizontal(msp, [(0,-600),(0,0),(5000,0),(5000,-600)], offset=800)
PaperSpace.draw_title_block(msp, (0,0), size='A3', title='图纸标题')

CADDocument.save(doc, 'output/drawing.dxf')
Renderer.render_quick(doc, output_dir='output', name='drawing')

支持的图纸类型与指令示例

建筑制图 (GB/T)

指令示例 生成内容
画一个4000x3000的建筑平面图 外墙+门+窗+标注+图框
3600x4800房间开一扇900宽的门两扇1200的窗 指定尺寸的户型
画一个双开门1500mm 双扇平开
12步直跑楼梯宽度1200 楼梯平面+折断线+方向箭头

机械制图 (GB/T)

指令示例 生成内容
M16六角螺栓头俯视图 六角头+内切圆+中心十字线
20齿齿轮端面视图D100 齿顶圆+齿根圆+轴孔+径向齿形线
轴承6205侧面图 内外圈+滚动体
压缩弹簧线径2外径16有效圈数6 锯齿形侧视图

电气制图

指令示例 生成内容
单极开关符号垂直放置 圆触点+倾斜动触杆+引线
三孔电源插座 半圆弧+底边+孔位
吸顶灯符号 圆形灯具标记
三相导线组间距30mm 三条平行导线

管道/暖通

指令示例 生成内容
DN50直管段带中心线 双线管+轴线
90度弯头R100 DN50东北走向 双线圆弧弯头
闸阀DN50 阀体+手轮
三通DN50/DN30 主管+支管接头

结构详图

指令示例 生成内容
250x500梁断面配3根16底部钢筋 截面轮廓+箍筋+纵筋+混凝土填充
楼板120厚双向配筋12@150/10@200 板轮廓+钢筋线+弯钩+标注
500x500柱下独立基础2000x2000深600 台阶式基础+受力筋+分布筋+标注

通用几何

指令示例 生成内容
画一个矩形400x300 矩形
正六边形外接圆半径100 正多边形
圆心(0,0)半径50的圆和直径80的同心圆 同心圆组

输出格式

格式 用途
.dxf 主输出,可导入 AutoCAD / FreeCAD / 中望CAD
.png 快速预览(自动生成)
.svg 矢量可缩放预览
.pdf 打印/交付文档

依赖库

用途 安装
ezdxf DXF 读写引擎 必须
matplotlib PNG/SVG/PDF 渲染后端 必须
numpy 数值计算 必须

安装命令:pip install ezdxf matplotlib numpy

架构与文件组织

复制代码
cad-editor/
├── SKILL.md                        # 本文件(技能说明书)
├── scripts/                        # 可执行代码
│   ├── nl_parser/                  # 自然语言解析器
│   │   ├── intent_classifier.py    #   意图分类(19 种规则)
│   │   ├── param_extractor.py     #   参数提取(5 大领域)
│   │   └── script_generator.py    #   脚本生成(18 套模板)
│   ├── core/                      #   文档创建 / 单位管理 / 渲染引擎
│   ├── entities/                  #   基础实体(线/圆/弧/多段线/文字)
│   ├── layer/                     #   图层管理 / 线型加载 / 行业图层模板
│   ├── dimension/                 #   标注(线性/径向/角度/引线)
│   ├── block/                     #   图块定义与插入
│   ├── hatch/                     #   图案填充(混凝土/砖/金属等)
│   ├── tools/                     #   编辑工具(偏移/裁剪/阵列/镜像/圆角倒角/测量)
│   ├── layout/                    #   图纸空间 / 视口 / 图框标题栏
│   ├── export/                    #   批量导出 SVG/PDF/PNG
│   └── templates/                 #   行业图库组件
│       ├── architectural.py       #     建筑(墙/门/窗/柱/楼梯/阳台)
│       ├── mechanical.py          #     机械(螺栓/齿轮/轴承/弹簧/键槽/垫圈/螺母/销)
│       ├── electrical.py          #     电气(开关/插座/灯具/导线/配电箱/断路器)
│       ├── piping.py              #     管道(直管/弯头/三通/阀门/法兰/大小头/管帽)
│       └── structural.py           #     结构(梁断面/楼板配筋/条基/独立基础)
├── references/                     # 参考文档(按需加载)
│   ├── color_index.md             #   ACI 颜色表(256色) + 行业配色规范
│   ├── layer_standards.md         #   GB/T 图层命名规范
│   ├── dxf_entity_codes.md        #   DXF 组码速查 + ezdxf API 映射
│   └── intent_templates.json      #   52 条 NL→参数映射模板
└── assets/                         # 输出资源(不加载到上下文)
    ├── fonts/                     #   CAD 字体文件
    ├── hatch_patterns/            #   自定义填充图案
    ├── linetypes/                 #   线型定义
    └── title_blocks/              #   图框标题栏模板(A0-A4)

参考文档索引

文档 内容 加载时机
references/color_index.md ACI 256 色表 + 建筑/机械/电气/管道/结构配色方案 需要设置颜色时
references/layer_standards.md GB/T 17825 图层命名规范,含 5 大行业预设 创建文档/设置图层时
references/dxf_entity_codes.md DXF 组码速查表 + ezdxf Python API 对照 操作底层实体时
references/intent_templates.json 52 条意图模板(NL 正则匹配→参数提取规则) NL 解析阶段自动读取
相关推荐
耿雨飞8 小时前
第三章:LangChain Classic vs. 新版 LangChain —— 架构演进与迁移指南
人工智能·架构·langchain
BizViewStudio8 小时前
甄选 2026:AI 重构新媒体代运营行业的三大核心变革与落地路径
大数据·人工智能·新媒体运营·媒体
俊哥V8 小时前
AI一周事件 · 2026年4月8日至4月14日
人工智能·ai
GitCode官方8 小时前
G-Star Gathering Day 杭州站回顾
人工智能·开源·atomgit
宇擎智脑科技9 小时前
开源 AI Agent 架构设计对比:Python 单体 vs TypeScript 插件化
人工智能·openclaw·hermes agent
冷色系里的一抹暖调10 小时前
OpenClaw Docker部署避坑指南:服务启动成功但网页打不开?
人工智能·docker·容器·openclaw
曹牧10 小时前
自动编程AI落地方案‌
人工智能
天云数据10 小时前
Harness革命:企业级AI从“失控野马”到“价值引擎”的跃迁
人工智能
汽车仪器仪表相关领域10 小时前
NHVOC-70系列固定污染源挥发性有机物监测系统:精准破局工业VOCs监测痛点,赋能环保合规升级
大数据·人工智能·安全性测试