LoadingManager.html 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="utf-8" />
  5. <base href="../../../../" />
  6. <script src="list.js"></script>
  7. <script src="page.js"></script>
  8. <link type="text/css" rel="stylesheet" href="page.css" />
  9. </head>
  10. <body>
  11. <h1>[name]</h1>
  12. <p class="desc">
  13. 其功能时处理并跟踪已加载和待处理的数据。如果未手动设置加强管理器,则会为加载器创建和使用默认全局实例加载器管理器
  14. - 请参阅 [page:DefaultLoadingManager].<br /><br />
  15. 一般来说,默认的加载管理器已足够使用了,但有时候也需要设置单独的加载器 - 例如,如果你想为对象和纹理显示单独的加载条。
  16. </p>
  17. <h2>代码示例</h2>
  18. <p>
  19. 下面的例子将介绍,如何使用加载管理器来跟踪 [page:OBJLoader] 的加载进度流程。
  20. </p>
  21. <code>
  22. var manager = new THREE.LoadingManager();
  23. manager.onStart = function ( url, itemsLoaded, itemsTotal ) {
  24. console.log( 'Started loading file: ' + url + '.\nLoaded ' + itemsLoaded + ' of ' + itemsTotal + ' files.' );
  25. };
  26. manager.onLoad = function ( ) {
  27. console.log( 'Loading complete!');
  28. };
  29. manager.onProgress = function ( url, itemsLoaded, itemsTotal ) {
  30. console.log( 'Loading file: ' + url + '.\nLoaded ' + itemsLoaded + ' of ' + itemsTotal + ' files.' );
  31. };
  32. manager.onError = function ( url ) {
  33. console.log( 'There was an error loading ' + url );
  34. };
  35. var loader = new THREE.OBJLoader( manager );
  36. loader.load( 'file.obj', function ( object ) {
  37. //
  38. } );
  39. </code>
  40. <p>
  41. 除了观察进度流程之外,还可以使用LoadingManager在加载期间覆写资源URL。当某资源来自拖拽事件、
  42. WebSockets、WebRTC或其他API时,此方法可以有所帮助。下面显示了如何使用Blob URL加载内存模型的示例。
  43. </p>
  44. <code>
  45. // 将文件拖入网页时创建的Blob或File对象。
  46. var blobs = {'fish.gltf': blob1, 'diffuse.png': blob2, 'normal.png': blob3};
  47. var manager = new THREE.LoadingManager();
  48. // 使用URL回调初始化加载管理器。
  49. var objectURLs = [];
  50. manager.setURLModifier( ( url ) => {
  51. url = URL.createObjectURL( blobs[ url ] );
  52. objectURLs.push( url );
  53. return url;
  54. } );
  55. // 像通常一样加载,然后撤消blob URL
  56. var loader = new THREE.GLTFLoader( manager );
  57. loader.load( 'fish.gltf', (gltf) => {
  58. scene.add( gltf.scene );
  59. objectURLs.forEach( ( url ) => URL.revokeObjectURL( url ) );
  60. });
  61. </code>
  62. <h2>例子</h2>
  63. <p>
  64. [example:webgl_loader_fbx WebGL / loader / fbx]<br />
  65. [example:webgl_loader_obj WebGL / loader / obj]<br />
  66. [example:webgl_materials_physical_reflectivity WebGL / materials / physical / reflectivity]<br />
  67. [example:webgl_postprocessing_outline WebGL / postprocesing / outline]
  68. </p>
  69. <h2>构造方法</h2>
  70. <h3>[name]( [param:Function onLoad], [param:Function onProgress], [param:Function onError] )</h3>
  71. <p>
  72. [page:Function onLoad] — (可选) 所有加载器加载完成后,将调用此函数。<br />
  73. [page:Function onProgress] — (可选) 当每个项目完成后,将调用此函数。<br />
  74. [page:Function onError] — (可选) 当一个加载器遇到错误时,将调用此函数。 <br />
  75. 创建一个新的 [name].
  76. </p>
  77. <h2>属性</h2>
  78. <h3>[property:Function onStart]</h3>
  79. <p>
  80. 此换上咋加载开始时,被调用.
  81. 有如下参数:<br />
  82. [page:String url] — 被加载的项的url。<br />
  83. [page:Integer itemsLoaded] — 目前已加载项的个数。<br />
  84. [page:Iteger itemsTotal] — 总共所需要加载项的个数。<br /><br />
  85. 此方法默认时未定义。
  86. </p>
  87. <h3>[property:Function onLoad]</h3>
  88. <p>
  89. 所有的项加载完成后将调用此函数。默认情况下,此方法时未定义的,除非在构造函数中进行传递。
  90. </p>
  91. <h3>[property:Function onProgress]</h3>
  92. <p>
  93. 此方法加载每一个项,加载完成时进行调用。
  94. 有如下参数:<br />
  95. [page:String url] — 被加载的项的url。<br />
  96. [page:Integer itemsLoaded] — 目前已加载项的个数。<br />
  97. [page:Iteger itemsTotal] — 总共所需要加载项的个数。<br /><br />
  98. 默认情况下,此方法时未定义的,除非在构造函数中进行传递。
  99. </p>
  100. <h3>[property:Function onError]</h3>
  101. <p>
  102. 此方法将在任意项加载错误时,进行调用。
  103. 有如下参数:<br />
  104. [page:String url] — 所加载出错误的项的url<br /><br />
  105. 默认情况下,此方法时未定义的,除非在构造函数中进行传递。
  106. </p>
  107. <h2>方法</h2>
  108. <h3>[method:LoadingManager addHandler]( [param:Object regex], [param:Loader loader] )</h3>
  109. <p>
  110. [page:Object regex] — A regular expression.<br />
  111. [page:Loader loader] — The loader.
  112. <p>
  113. Registers a loader with the given regular expression. Can be used to define what loader should be used in
  114. order to load specific files. A typical use case is to overwrite the default loader for textures.
  115. </p>
  116. <code>
  117. // add handler for TGA textures
  118. manager.addHandler( /\.tga$/i, new TGALoader() );
  119. </code>
  120. <h3>[method:null getHandler]( [param:String file] )</h3>
  121. <p>
  122. [page:String file] — The file path.
  123. <p>
  124. Can be used to retrieve the registered loader for the given file path.
  125. </p>
  126. <h3>[method:LoadingManager removeHandler]( [param:Object regex] )</h3>
  127. <p>
  128. [page:Object regex] — A regular expression.
  129. <p>
  130. Removes the loader for the given regular expression.
  131. </p>
  132. <h3>[method:String resolveURL]( [param:String url] )</h3>
  133. <p>
  134. [page:String url] — 所要加载的url<br /><br />
  135. 给定URL,使用URL修饰符回调(如果有)并返回已解析的URL。如果未设置URL修饰符,则返回原始URL。
  136. </p>
  137. <h3>[method:null setURLModifier]( [param:Function callback] )</h3>
  138. <p>
  139. [page:Function callback] — 设置URL修饰符成功时回调。使用url参数进行回调,并且必须返回 [page:String resolvedURL] 。<br /><br />
  140. 如果设置了回调,则在发送请求之前将向每个资源URL传递回调。回调可以返回最初的URL,也可以返回新URL以覆盖加载行为。
  141. 此行为可用于从.ZIP、拖拽API和数据URI中加载资源文件。
  142. </p>
  143. <br />
  144. <p>
  145. <em>Note: The following methods are designed to be called internally by loaders. You shouldn't call
  146. them directly.</em>
  147. </p>
  148. <h3>[method:null itemStart]( [param:String url] )</h3>
  149. <p>
  150. [page:String url] — 所要加载的url<br /><br />
  151. 任何使用管理器的加载器都会调用此方法, 当加载器需要开始加载URL时。
  152. </p>
  153. <h3>[method:null itemEnd]( [param:String url] )</h3>
  154. <p>
  155. [page:String url] — 所要加载的url<br /><br />
  156. 任何使用管理器的加载器都会调用此方法, 当加载器需要加载URL结束时。
  157. </p>
  158. <h3>[method:null itemError]( [param:String url] )</h3>
  159. <p>
  160. [page:String url] — 所要加载的url<br /><br />
  161. 任何使用管理器的加载器都会调用此方法, 当加载器出现加载错误时。
  162. </p>
  163. <h2>源</h2>
  164. <p>
  165. [link:https://github.com/mrdoob/three.js/blob/master/src/loaders/LoadingManager.js src/loaders/LoadingManager.js]
  166. </p>
  167. </body>
  168. </html>