http://www.sohu.com/a/236241465_100000368

Cura是Ultimaker公司开发的3D打印开源软件,在所有的3D打印开源软件中应属上乘之作,很有研究的价值。国内不少高校对其有深入研究,研究成果体现在其毕业论文之中。国内互联网上也有很多文章对其代码进行了剖析。

最近一段时间,读了几篇论文,分析了Cura的部分代码,打算写上若干篇分析文章。这里的视角与他人不一样,并不具体讲代码,不拘泥于具体的切片算法,而是通过使用软件与阅读代码后总结描述其软件的设计与架构。

所分析的代码是Cura最新的代码,分析过程中直接同步GitHub上的代码库,发现软件开发目前很活跃的,代码提交比较频繁,开发库中的版本已经合并到3.4了。

本篇主要描述:

  1. Cura软件使用的开发语言以及使用的第三方开源库;
  2. 切片引擎CuraEngine程序的四种命令行参数调用接口;
  3. Cura软件代码总体评价。

Cura软件简介

Cura软件实际上包含两个软件:Cura与CuraEngine。前者是图形界面程序,后者是专用于切片的后台程序,前者依赖于后者,在切片时将调用后者。

两个软件使用的编程语言与第三方库

 

Cura

CuraEngine

开源库网址 https://github.com/Ultimaker/Cura https://github.com/Ultimaker/CuraEngine

开发语言

Python,细致点说还有Qt的QML语言

C++

第三方库

PyQt,QtQuick,Protobuf,Arcus

Protobuf,Arcus,clipper,rapidjson

图形界面

使用的是QtQuick而不是传统的QtWidgets,图形界面很新潮

控制台程序,无图形界面

第三方库的功用

开源库

说明

Protobuf

Google的开源库,用于Cura与CuraEngine之间的结构数据序列化,简单说就是保证两个软件之间可以互相传递结构化的数据。目前支持多种语言,这里就使用了C++,Python

Arcus

包含C++代码与Python3的绑定,基于Protobuf库在一个线程中创建一个socket,然后发送与接受结构化的消息数据

PyQt,QtQuick

Python语言下Qt库的包装,也就是可以使用Python语言访问Qt相关库了,Cura使用了QtQuick图形界面库

rapidjson

C++库,用于解读JSON格式的文件,CuraEngine使用它解读打印机配置参数的JSON文件

clipper

C++库,一个用于二维图形裁剪与偏移等功能的算法库,CuraEngine对模型上切出来的所有切片调用此库进行二维图形操作

在编译CuraEngine软件时也可不启用Arcus与protobuf库,这样编译出来的软件将导致Cura无法调用它,而只能单独使用。 CuraEngine软件命令行接口

CuraEngine是一个控制台程序,在cmd中运行CuraEngine help后,将打印其用法信息:

usage:

CuraEngine help

Show thishelp message

CuraEngine connect<host>[:<port>] [-j <settings.def.json>]

--connect<host>[:<port>]

Connect to<host> via a command socket,

instead ofpassing information via the command line

-j<settings.def.json>

Loadsettings.json file to register all settings and their defaults

-v

Increasethe verbose level (show log messages).

-m<thread_count>

Set thedesired number of threads. Supports only a single digit.

CuraEngine slice[-v] [-p] [-j <settings.json>] [-s<settingkey>=<value>] [-g] [-e<extruder_nr>] [-o<output.gcode>] [-l <model.stl>] [--next]

-v

Increasethe verbose level (show log messages).

-m<thread_count>

Set the desired number of threads.

-p

Logprogress information.

-j

Loadsettings.def.json file to register all settings and their defaults.

-s<setting>=<value>

Set asetting to a value for the last supplied object,

extruder train, or general settings.

-l<model_file>

Load an STLmodel.

-g

Switchsetting focus to the current mesh group only.

Used forone-at-a-time printing.

-e<extruder_nr>

Switchsetting focus to the extruder train with the given number.

--next

Generategcode for the previously supplied mesh group and append that to

the gcodeof further models for one-at-a-time printing.

-o<output_file>

Specify afile to which to write the generated gcode.

The settings are appended to the last supplied object:

CuraEngine slice [general settings]

-g [currentgroup settings]

-e0[extruder train 0 settings]

-lobj_inheriting_from_last_extruder_train.stl [object settings]

--next[next group settings]

... etc.

In order to load machine definitions from customlocations, you need to create the environment variable CURA_ENGINE_SEARCH_PATH,which should contain all search paths delimited by a (semi-)colon.

上面打印了三种命令行接口,实际上读其源代码发现有四种接口的,只是第四种适合于开发者使用。

下面罗列CuraEngine的四种命令行调用接口:

参数

说明

help

第一种接口用法。打印上面的帮助信息。

connect

第二种接口用法。在Cura中执行切片功能时就是这种用法。典型的调用方式是:CuraEngine.exe connect 127.0.0.1:49674 -j “d:Program FilesUltimaker Cura 3.3resourcesdefinitionsfdmprinter.def.json” “”

注意上面并没有传递stl文件之类的参数,模型数据是通过socket传递的,也即上面提到的Arcus与Protobuf库提供的功能。-j指定打印机的json文件。

slice

第三种用法。不是通过Cura调用,直接传递stl模型文件等参数,进行切片操作。

CuraEngine slice[-v] [-p] [-j <settings.json>] [-s<settingkey>=<value>] [-g] [-e<extruder_nr>] [-o<output.gcode>] [-l <model.stl>] [--next]

这种方式的命令行参数比较多,具体的例子以后提供。这里再提供一个通过阅读代码发现的一个用法:-v 可以打印出日志信息,但不会打印调试信息,当你要更多的输出日志信息时,可以连写两个-v参数。

analyse

第四种用法,不看源代码是不知道这个用法的,主要给开发者用。可以输出打印机设置json文件中的信息。调用方法:CuraEngineanalyse[json][output.gv][engine_settings]-[p|i|e|w]

p=showparent-childrelations

i=show inheritance function

e=show error functions

w=show warning functions

示例:CuraEngine analyse /home/cubetan/code/fdmprinter.def.json /home/cubetan/code/output.gv -p -i -e -w

生成的output.gv文件可通过dot程序创建一个图片文件,如dot output.gv > abc.png

Cura软件代码总体评价

Cura软件新版本根据 https://github.com/Ultimaker/Cura 中的描述:

This is the new, shiny frontend for Cura. Check daid/LegacyCurafor the legacy Cura that everyone knows and loves/hates. We re-worked the whole GUI code at Ultimaker, because the old code started to become unmaintainable.

Cura代码做了全部重写,以前用的是Python下的wxWidgets实现图形界面,实在维护不下去了,只好重写。现在用的是PyQt+QUICK实现,Cura的代码可读性不错,注释量偏少。阅读此代码如果不深究三维渲染,则需要对Python,Qt,QML,QUICK有一定基础,否则还需要深入研究Uranium(https://github.com/Ultimaker/Uranium)。

CuraEngine为了追求切片效率,代码是全部使用C++编写,代码可读性很好,注释较多,也能发现一些设计缺陷,以后会提到。在Windows下使用VC编译器编译不了,需要修改代码,我是在Ubuntu系统下编译的。CuraEngine是一个控制台程序,代码的主线逻辑非常简单,从main函数入手,顺着slice命令行调用模式的流程往下看,可很快了解代码顶层的设计实现。

转载于:https://www.cnblogs.com/mazhenyu/p/10712680.html

3D打印开源软件Cura分析(1) 【转】相关推荐

  1. 3D打印切片软件--cura的二次开发(2)(界面分析与汉化)(修改版增加图片)

    转载:https://blog.csdn.net/qq_29701359/article/details/75070507 在上次把CUR软件从github网站clone下来并在windows8系统, ...

  2. 3D打印切片软件cura的使用方法

    由于ANY CUBIC 无法在脱机的情况下打印stl文件,必须使用cura软件将STL文件转成gcode格式的文件. 使用的方法还是蛮简单的,具体如下: 1.下载cura 15.0.46并安装.密码: ...

  3. 3D打印切片软件--cura的二次开发

    本来前段时间就要写的,只因为那会的收效比较小,有些东西还一窍不通,当然现在也还是有些不大明白,但是最起码刚刚跳出了cura主界面还是不枉这几天工作: 废话不多说了,就把最近我做过的东西,学到的东西以及 ...

  4. 3D打印切片软件Cura入门

    安装好之后,添加一台打印机,参数可以随便设置. Cura安装包: 链接:https://pan.baidu.com/s/1T1MBcZYBCVfhtFKDBjypmQ?pwd=2022  提取码:20 ...

  5. 3D打印开源切片软件Cura配置步骤

    3D打印开源切片软件Cura配置步骤 Cura ==== Read this, it's important! =========================== If you are readi ...

  6. 3D 打印切片软件 CuraEngine 介绍

    Scientists study the world as it is, engineers create the world that never has been. 跳至正文 首页 ← Mac下各 ...

  7. 革命性3D打印数据处理软件 CHITUBOX Pro 1.3.0 Crack

    CHITUBOX PRO登场 革命性的3D打印数据处理软件,让你发挥3D打印的无限潜力 支持多种主流CAD文件格式 除了传统的stl和obj文件,CHITUBOX Pro还支持导入各种主流的CAD文件 ...

  8. 3d打印 开源_Hovalin:开源3D打印小提琴

    3d打印 开源 Twitter上最近关于开放源3D打印小提琴的消息使我寻找有关何瓦林的更多信息. 3D打印的宇宙大都与机器人和无人机有关,因此看到混合的小提琴让我停下来,对这个独特的项目感到好奇. 我 ...

  9. 3d打印 开源_公开地图以实现可持续性,在农场进行3D打印以及更多开源新闻

    3d打印 开源 在本周的开源新闻摘要中,我们介绍了Ubuntu 15.04 Vivid Vervet的新版本,服务器场中的3D打印,实现可持续性的开放式地图等等. 开源新闻摘要:2015年4月18日至 ...

最新文章

  1. 怎样预训练GNN能实现更好的迁移效果?
  2. Java的jar文件安装成windows 服务
  3. 云原生数据库_数据标签竞赛云原生地理空间冲刺
  4. [css] 用css画一个五边形和一个六边形
  5. 使用cookie保存用户名状态
  6. UVa 12657 双向链表
  7. 判断能否组成三角形(水题)
  8. pygame 安装方法
  9. 石墨烯的精细结构研究取得进展
  10. VarianceThreshold
  11. docker 部署jenkins + sonarqube + postgresql 代码扫描
  12. js判断当前浏览器的环境是微信、pc、还是手机端非微信环境
  13. 入门算法题——数学篇(一)
  14. win7桌面上的计算机图标不见了怎么办,win7桌面上计算机图标不见了要怎么办呢?...
  15. 几种抽奖方式之轮盘抽奖
  16. Java 一元、二元运算符、三目条件运算符(三元运算符)
  17. html中鱼眼效果,鱼眼效果和放大效果怎么做
  18. 手把手教你如何安装java环境_手把手教你安装JAVA环境
  19. C++算法——DFS(图解)
  20. html 转换为jade,html转jade.htm

热门文章

  1. html表格线条不显示,cline处理表格不显示线条
  2. 用计算机打字方法,电脑快速打字方法
  3. Hive-JDBC操作,springcloud高级面试题
  4. android 开发积累
  5. android 4.4官方下载,安卓系统电脑版-android x86 4.4 iso下载官方最新版【pc版】-西西软件下载...
  6. 具有检查点的恢复技术
  7. Hbase_Hbase 中 bloom filter 的设计与概念
  8. Hive sql : 查询连续登录天数
  9. 支付宝 SDK6001 错误码 或 支付繁忙
  10. 简单电子产品的蓝牙电路设计和PCB设计