znlgis 博客

GIS开发与技术分享

第08章:参数化零件库与复用设计

1. 为什么需要库

当模型从一个零件发展到一组产品时,重复代码会迅速失控。孔、圆角板、螺丝柱、卡扣、盒体、齿轮、滑轨、铰链、标识文字都应该抽象成可复用模块。OpenSCAD 的库设计不追求面向对象层级,而追求简单、纯粹、参数明确。

2. 库文件原则

一个好的库文件应满足:

  • 顶层不生成实际几何,避免被 include 时意外显示。
  • 模块参数有默认值,能独立预览。
  • 坐标原点、方向、单位在注释中说明。
  • 参数校验清晰,错误信息可读。
  • 不依赖隐含全局变量,除非是明确的配置文件。
  • 示例与测试模型单独放置。

3. 基础紧固件模块

module clearance_hole(d = 3.2, h = 10) {
    cylinder(h = h, d = d, center = true);
}

module counterbore(d = 3.2, head_d = 6.2, head_h = 3, h = 10) {
    union() {
        cylinder(h = h, d = d, center = true);
        translate([0,0,h/2-head_h/2]) cylinder(h = head_h, d = head_d, center = true);
    }
}

使用时作为差集刀具:

difference() {
    cube([40, 20, 6], center = true);
    counterbore(h = 8);
}

4. 圆角板模块

module rounded_plate(size = [60, 30, 4], r = 4) {
    assert(size[0] >= 2*r && size[1] >= 2*r, "corner radius too large");
    hull() {
        for (x = [-size[0]/2+r, size[0]/2-r])
            for (y = [-size[1]/2+r, size[1]/2-r])
                translate([x,y,0]) cylinder(h = size[2], r = r, center = true);
    }
}

注意这个模块的原点在板中心,厚度沿 Z 对称。调用者可以轻松装配和布尔。

5. 配置文件模式

项目可把产品规格放在配置文件中:

// config_small.scad
box_size = [60, 40, 20];
wall = 2;
hole_d = 3.2;

主文件:

include <config_small.scad>
use <parts/box.scad>

box(size = box_size, wall = wall);

如果要命令行覆盖,也可使用 -D 'box_size=[80,50,25]'。需要注意命令行表达式的引号和 shell 转义。

6. MCAD 与第三方库

官方仓库子模块中包含 MCAD 库。社区也常用 BOSL/BOSL2 等库。使用第三方库时应关注:

  • 许可证是否适合项目。
  • 支持的 OpenSCAD 版本。
  • 模块命名是否与自有代码冲突。
  • 是否影响渲染性能。
  • 是否有稳定文档和示例。
  • 是否需要把库作为 Git 子模块、包管理依赖或直接复制。

学习时可以借鉴库的参数设计,但团队项目不建议无选择地引入大量第三方模块。

7. 装配入口设计

常见做法是用一个变量控制显示内容:

show = "assembly";

if (show == "base") base();
else if (show == "cover") cover();
else if (show == "exploded") exploded_view();
else assembly();

命令行导出不同零件:

openscad -D 'show="base"' -o base.stl main.scad
openscad -D 'show="cover"' -o cover.stl main.scad

8. 坐标接口

库模块之间最容易出错的是坐标接口。建议为每个模块定义:

  • 原点位置。
  • X/Y/Z 正方向含义。
  • 安装面在哪个平面。
  • 输入尺寸是外尺寸还是内尺寸。
  • 孔位坐标相对哪个基准。
  • 返回几何是否居中。

这些约定应写在模块注释或教程文档中。

9. 版本兼容

OpenSCAD 语言特性会随版本演进。共享库时应说明最低 OpenSCAD 版本。若使用较新的列表推导、letassert 或实验特性,应在文档中注明。

10. 库质量检查

  • 默认参数是否能正常 F6 渲染?
  • 极端参数是否触发可读错误?
  • 模块是否可作为差集刀具使用?
  • 是否存在隐藏全局状态?
  • 是否能在多个项目中独立复用?
  • 是否有最小示例和预览图?
  • 是否避免过度复杂的通用化?