[page:Loader] →

[name]

一个用于加载经过Draco压缩的图形库。

[link:https://google.github.io/draco/ Draco]是一个开源的库,主要用于压缩和解压缩三维模型及点云。 以客户端上解压缩为代价,显著减少压缩的图形。

独立的Draco文件后缀为`.drc`,其中包含顶点坐标,法线,颜色和其他的属性, Draco文件*不*包含材质,纹理,动画和节点结构-为了能使用这些特征,需要将Draco图形 嵌入到GLTF文件中。使用[link:https://github.com/AnalyticalGraphicsInc/gltf-pipeline glTF-Pipeline]可以将一个普通的GLTF文件转化为经过Draco压缩的GLTF文件。 当使用Draco压缩的GLTF模型时,[page:GLTFLoader]内部会调用DRACOLoader。

推荐创建一个DRACOLoader实例并重用,可以有效避免重复创建加载多个解压器实例。

导入

[name]是一个插件,必须显示引用。 请参考 [link:#manual/introduction/Installation Installation / Addons]。

import { DRACOLoader } from 'three/addons/loaders/DRACOLoader.js';

代码示例

// Instantiate a loader const loader = new DRACOLoader(); // Specify path to a folder containing WASM/JS decoding libraries. loader.setDecoderPath( '/examples/jsm/libs/draco/' ); // Optional: Pre-fetch Draco WASM/JS module. loader.preload(); // Load a Draco geometry loader.load( // resource URL 'model.drc', // called when the resource is loaded function ( geometry ) { const material = new THREE.MeshStandardMaterial( { color: 0x606060 } ); const mesh = new THREE.Mesh( geometry, material ); scene.add( mesh ); }, // called as loading progresses function ( xhr ) { console.log( ( xhr.loaded / xhr.total * 100 ) + '% loaded' ); }, // called when loading has errors function ( error ) { console.log( 'An error happened' ); } );

例子

[example:webgl_loader_draco]

浏览器兼容性

DRACOLoader会根据浏览器的特性,自动使用JS或者WASM解码库。



构造函数

[name]( [param:LoadingManager manager] )

[page:LoadingManager manager] — 加载器使用的[page:LoadingManager loadingManager]. 默认值为[page:LoadingManager THREE.DefaultLoadingManager].

创建一个新的[name].

属性

查看公共属性请参考基类[page:Loader]

方法

查看公共方法请查看基类[page:Loader]

[method:undefined load]( [param:String url], [param:Function onLoad], [param:Function onProgress], [param:Function onError] )

[page:String url] — 一个`.drc`文件的路径或者网络地址。
[page:Function onLoad] — 加载成功之后调用的函数。
[page:Function onProgress] — (可选的) 正在加载时调用的函数。参数为XMLHttpRequest实例,包含.[page:Integer total]和.[page:Integer loaded]
[page:Function onError] — (可选的)加载出现错误时调用的函数。该函将错误信息作为参数。

开始加载解压缩的图形并调用`onLoad`函数。

[method:this setDecoderPath]( [param:String value] )

[page:String value] — 包含JS和WASM解压缩库的文件夹路径。

[method:this setDecoderConfig]( [param:Object config] )

[page:String config.type] - (可选的) `"js"`或`"wasm"`。

为解压缩库提供配置,在解压开始后不能修改。

[method:this setWorkerLimit]( [param:Number workerLimit] )

[page:Number workerLimit] - 可以分配的最大线程数。默认值为4。

设置用于解码的[link:https://developer.mozilla.org/en-US/docs/Web/API/Web_Workers_API/Using_web_workers Web Workers]的最大值。如果线程也用于其他的任务,给定更小的限制会更合理。

[method:this preload]()

如果还没加载完成,则请求解压库。

[method:this dispose]()

处理解压资源和释放的内存。在处理后,解码器 [link:https://github.com/google/draco/issues/349 不能重新加载].

源代码

[link:https://github.com/mrdoob/three.js/blob/master/examples/jsm/loaders/DRACOLoader.js examples/jsm/loaders/DRACOLoader.js]