当前位置: 首页 > news >正文

第10章:导入导出、命令行与自动化

第10章:导入导出、命令行与自动化

1. 支持的常见格式

OpenSCAD 官方 README 提到可读取和创建 STL、OFF,并使用 DXF 作为二维轮廓交换格式;当前版本还支持更多格式,如 3MF、AMF、SVG、PNG 等,具体以所安装版本的帮助输出为准。

常见用途:

  • STL:3D 打印最常见三角网格格式。
  • 3MF:现代 3D 打印格式,可携带更多元数据。
  • OFF:几何网格交换和测试。
  • DXF/SVG:二维轮廓、激光切割、投影输出。
  • PNG:文档预览图、CI 快照、网页展示。

2. import 导入

import("part.stl");
linear_extrude(3) import("profile.dxf");

导入模型常用于增加外部零件参考、组合扫描件、加工现有网格或使用外部二维轮廓。需要注意:

  • STL 没有单位信息,比例必须确认。
  • 外部网格可能非流形,布尔运算容易失败。
  • DXF/SVG 轮廓必须清理闭合。
  • 导入文件路径相对当前 .scad 文件或工作目录,自动化时应固定路径。

3. 导出 STL

图形界面中通常先 F6 渲染,再导出 STL。命令行:

openscad -o exports/part.stl src/main.scad

建议导出前检查控制台警告。对 3D 打印件,还应在切片软件中检查模型尺寸、法线、非流形和支撑。

4. 使用 -D 覆盖参数

openscad -D 'part="base"' -D 'wall=2.4' -o base.stl main.scad

-D 是批量生成的核心。注意字符串需要引号,shell 中可能要嵌套转义。建议在 CI 中把命令写得明确,不依赖交互环境。

5. 生成多规格产品

openscad -D 'variant="small"' -o exports/small.stl product.scad
openscad -D 'variant="medium"' -o exports/medium.stl product.scad
openscad -D 'variant="large"' -o exports/large.stl product.scad

.scad 中:

variant = "small";
size = variant == "small" ? [60,40,20] :variant == "medium" ? [80,50,25] : [100,60,30];

6. 导出图片

命令行可生成预览图,用于文档或回归比较:

openscad -o preview.png --imgsize=1200,800 --viewall --autocenter model.scad

图片导出适合博客教程、README 之外的文档页面、发布说明和模型库索引。要得到稳定图片,应固定相机、尺寸、颜色和 OpenSCAD 版本。

7. 自动化构建建议

可使用 Makefile:

OPENSCAD=openscad
SRC=src/main.scadexports/base.stl: $(SRC)
$(OPENSCAD) -D 'part="base"' -o $@ $(SRC)exports/cover.stl: $(SRC)
$(OPENSCAD) -D 'part="cover"' -o $@ $(SRC)

自动化流程应包含:

  • 清理旧导出。
  • 生成 STL/3MF。
  • 生成 PNG 预览。
  • 检查文件是否非空。
  • 可选:运行网格检查工具。
  • 可选:上传构建产物。

8. CI 中使用 OpenSCAD

CI 可用于保证模型至少能渲染导出:

  1. 安装 OpenSCAD。
  2. 运行命令行导出关键模型。
  3. 保存 STL 和 PNG 作为构建产物。
  4. 对生成文件大小、数量和日志进行检查。
  5. 对参数矩阵运行多规格导出。

OpenSCAD 官方仓库自身包含 GitHub Actions、CircleCI、本地 CI 说明和大量测试,说明命令行与自动化是项目的重要组成部分。

9. 路径与依赖管理

自动化最常见的问题是路径不一致。建议:

  • 所有导出命令从项目根目录运行。
  • .scad 内使用相对自身清晰的路径。
  • 第三方库固定版本。
  • 不依赖用户本机字体,除非已在 CI 安装。
  • 导出目录由脚本创建,不手工维护。

10. 导入导出检查清单

  • 命令行版本是否与本地 GUI 版本一致?
  • -D 参数是否正确转义?
  • 导入文件单位是否明确?
  • 导出 STL 是否经过 F6 或等价命令完整渲染?
  • 图片导出相机是否固定?
  • CI 是否能复现本地结果?
  • 大型二进制导出是否需要 Git LFS 或构建产物管理?
http://www.jsqmd.com/news/764536/

相关文章:

  • 通过Taotoken控制台实时观测各模型API调用成功率与状态
  • 为内部知识问答机器人集成Taotoken多模型后备增强回答可靠性
  • MelonLoader终极指南:Unity游戏模组加载器从入门到精通
  • 第09章:列表推导、递归与算法建模
  • 使用curl命令直接测试Taotoken的API连通性与基础功能
  • 5个步骤将Jupyter Docker Stacks快速部署到Google Cloud Run:Serverless容器完整指南
  • 如何通过社交媒体成功推广你的JPL开源火星探测车项目
  • Lazy Line Painter 性能优化:如何提升SVG动画流畅度的终极指南
  • 浙江移动魔百盒HM201有线网络时序依赖问题的深度分析与解决方案
  • 深度分析:青岛快学教育靠不靠谱? - GrowthUME
  • QTTabBar:彻底改变Windows资源管理器的标签页革命
  • 生成式人工智能服务管理暂行办法
  • 测试开发全日制学徒班7期第8天“-循环语句
  • Taotoken模型广场功能在项目初期技术选型中的辅助作用
  • 3步拯救你的魔兽地图:告别版本兼容性噩梦
  • 从GoPro视频中高效提取GPS轨迹数据的实用指南:gopro2gpx完整解决方案
  • 游戏设计入门:从创意策划到工程实践——一个独立开发者的完整工具箱
  • 第08章:参数化零件库与复用设计
  • 青少年家庭教育与心理支持服务选型指南 - GrowthUME
  • 2026年,附近这家水性聚氨酯树脂订制厂有何独特之处? - GrowthUME
  • D2DX:让暗黑破坏神2在现代PC上焕发新生的魔法引擎
  • CSS 中的 opacity 属性用于设置一个元素的整体不透明度。它会影响该元素本身及其所有子元素的可见性。
  • 2026年贵阳毛坯房装修全链条解决方案深度评测:透明报价、工艺对标与官方直达2026年贵阳毛坯房装修全链条解决方案深度评测:透明报价、工艺对标与官方直达 - 年度推荐企业名录
  • 新服务器到手第一步:保姆级教程搞定Ubuntu 20.04 Server网络、时区和硬盘挂载
  • 第11章:预览、渲染、网格精度与性能优化
  • OpenClaw滑块验证码破解:图像识别与拟人轨迹实战
  • 告别重复劳动:用快马ai一键生成高完成度element登录弹窗代码
  • 基于向量检索与LLM的代码库智能问答系统RepoGPT部署与实战
  • VideoAdGuard:基于浏览器扩展的视频广告智能拦截技术实践
  • GoPro GPS数据提取完全指南:从GPMF流到GPX轨迹的专业级解析