目前的导入方式,是将CATIA格式模型转为FBX格式,再导入到Unity3D中。在仿真过程的验证中发现,目前的模型占用资源很大,在运行加载过程中反应较慢,在一些性能不佳的 计算 机上甚至无法运行。另外如果能将模型轻量化,那么在计算机性能的支持下就可以提升3Dmaxs中的模型分辨率,增强模型在Unity3D中的仿真效果。

图1 Skin Track (模型件和轨道的结合体)
CGR格式只保存了零件的外形信息,不包含任何参数化的数据,非常符合我们对模型特征的要求。结合04环轨自动钻铆机模型,对图1进行格式转换,并对转换后的FBX文件进行响应测试。FBX 格式是通用的转换格式。
将该文件另存为两个文件,一个是CATProduct格式,另一个是CGR格式。然后将两个文件都经过在3DMaxs中渲染,得到两个FBX文件。在比对二者的文件大小时,发现CGR格式导出的FBX文件明显比CATProduct格式大得多。(如图组2.2)



图组2.2 两种CATIA模型FBX格式转换后内存大小
通过测量模型导入到 Unity 中耗时和模型实例化响应耗时对比分析,可知FBX文件的大小直接决定了导入耗时和实例化响应耗时,并且基本符合正比关系,即不存在内存换取速度的情况。(具体测量数据如表1)也就是说如果轻量化模型经过3DMaxs渲染后FBX格式下文件反而变大了,那么在CATIA中的轻量化操作也就没有意义了。
表1 导入和响应耗时时间统计
| 模型名称 | 文件大小 | 导入耗时(s) | 实例化耗时(ms) |
| Skin Track.FBX | 27.0MB | 15.93 | 3533.8 |
| Skin Track(Thin).FBX | 71.6MB | 42.76 | 16475.4 |
在多次尝试后发现,CGR文件转换成FBX格式时内存总是要比原CATIA格式转换成FBX格式时要大。(如表2所示)在尝试将CATProduct格式文件先转换成CATPart,再转换成CGR格式,最后转换成FBX格式的时候发现文件大小竟然基本吻合。(如表3所示)再次说明了原CATIA格式转FBX格式内存更小。而利用CGR格式进行 轻量化模型 ,以达到减少Unity3D资源消耗的目标是不可行的。
表2 三种模型转FBX格式后占用内存大小对比(单位 KB)
| 模型格式/名 | Skin Track (CATProduct) | Skin of Equipment (CATPart) | Track of Equipment (CATProduct) |
| 原CATIA格式 | 951 | 31716 | 946 |
| 轻CGR格式 | 7136 | 6456 | 1182 |
| 原FBX格式 | 27729 | 4141 | 23561 |
| 轻FBX格式 | 73388 | 6390 | 65257 |
表3 两种CATIA格式转FBX格式后占用内存大小对比(单位 KB)
| 模型名/格式 | Skin Track(CATProduct) | Skin Track(CATpart) |
| 原CATIA格式 | 951 | 143484 |
| 轻CGR格式 | 7136 | 43055 |
| 原FBX格式 | 27729 | 27948 |
| 轻FBX格式 | 73388 | 72339 |
通过对比实验,我们发现由CATIA文件转换成的CGR轻量化文件,在转FBX格式时,所占内存空间反而会变大。我认为是CATIA文件与FBX格式之间的转换算法和CGR轻量化文件与FBX格式之间的转换算法不同导致的。

免责声明:本文系网络转载或改编,未找到原创作者,版权归原作者所有。如涉及版权,请联系删