咱之前说过,可以通过在Three.js里加载Draco来压缩模型。它主要处理的是几何数据,比如顶点、面片、法线这些,用来解决模型传输和存储层面的压力。
但在实际做项目的时候会发现很多场景就算几何体已经压过了,页面还是不够轻。特别是一些看起来面数不算高的模型,加载还是很慢。后来排查下来,问题却是在纹理上。
最常见的情况就是:贴图分辨率高,数量还多。
像基础色、法线、粗糙度、金属度、AO这些材质图,要是全都配齐,显存占用会非常明显。
所以在Draco之外,我现在通常还会关注另一个点:KTX2纹理压缩。
轻装3D 是怎么做到KTX2纹理压缩的?
普通图片格式比如PNG、JPG,虽然也能压缩体积,但在渲染的时候,还是要被解码、上传,显存开销并不会特别理想。KTX2不是单纯"把图片变小",而是让纹理在传输、解码、上传、渲染这整个过程中都变得更轻。但是法线、粗糙度、金属度、AO这些贴图本身就是项目里最容易堆体积的东西,我们不可能一个个贴图检查过来,那维护成本也太高了。
轻装3D就是把纹理压缩纳入统一流程里做,而不是让我再单独切换工具处理。这点对前端来说真的很重要!只需要几个简单的步骤就能轻松搞定。
1.选择模型文件
把需要轻量化处理的文件添加到软件里。

2.KTX2纹理压缩
软件会自动进行扫描,扫描完成后勾选操作选项,然后开始轻量化。

3.开始轻量化
软件会自动进行模型的轻量化操作。包括物体数量优化、贴图优化以及KTX2纹理压缩。

4.预览
点击预览就能看到轻量化之后的结果了。

总的来说
咱在做Three.js项目时,一般不会只盯几何体,而是会把几何压缩和纹理压缩一起看。因为真正影响体验的,往往不是某一个单点,而是整套资源是否足够轻。对于需要兼顾加载速度、画面效果和移动端稳定性的项目,有一个好用的工具往往能达到事半功倍的效果。