DataTextureLoader.js 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. import { LinearFilter, LinearMipMapLinearFilter, ClampToEdgeWrapping } from '../constants';
  2. import { FileLoader } from './FileLoader';
  3. import { DataTexture } from '../textures/DataTexture';
  4. import { DefaultLoadingManager } from './LoadingManager';
  5. /**
  6. * @author Nikos M. / https://github.com/foo123/
  7. *
  8. * Abstract Base class to load generic binary textures formats (rgbe, hdr, ...)
  9. */
  10. function DataTextureLoader( manager ) {
  11. this.manager = ( manager !== undefined ) ? manager : DefaultLoadingManager;
  12. // override in sub classes
  13. this._parser = null;
  14. }
  15. Object.assign( DataTextureLoader.prototype, {
  16. load: function ( url, onLoad, onProgress, onError ) {
  17. var scope = this;
  18. var texture = new DataTexture();
  19. var loader = new FileLoader( this.manager );
  20. loader.setResponseType( 'arraybuffer' );
  21. loader.load( url, function ( buffer ) {
  22. var texData = scope._parser( buffer );
  23. if ( ! texData ) return;
  24. if ( undefined !== texData.image ) {
  25. texture.image = texData.image;
  26. } else if ( undefined !== texData.data ) {
  27. texture.image.width = texData.width;
  28. texture.image.height = texData.height;
  29. texture.image.data = texData.data;
  30. }
  31. texture.wrapS = undefined !== texData.wrapS ? texData.wrapS : ClampToEdgeWrapping;
  32. texture.wrapT = undefined !== texData.wrapT ? texData.wrapT : ClampToEdgeWrapping;
  33. texture.magFilter = undefined !== texData.magFilter ? texData.magFilter : LinearFilter;
  34. texture.minFilter = undefined !== texData.minFilter ? texData.minFilter : LinearMipMapLinearFilter;
  35. texture.anisotropy = undefined !== texData.anisotropy ? texData.anisotropy : 1;
  36. if ( undefined !== texData.format ) {
  37. texture.format = texData.format;
  38. }
  39. if ( undefined !== texData.type ) {
  40. texture.type = texData.type;
  41. }
  42. if ( undefined !== texData.mipmaps ) {
  43. texture.mipmaps = texData.mipmaps;
  44. }
  45. if ( 1 === texData.mipmapCount ) {
  46. texture.minFilter = LinearFilter;
  47. }
  48. texture.needsUpdate = true;
  49. if ( onLoad ) onLoad( texture, texData );
  50. }, onProgress, onError );
  51. return texture;
  52. }
  53. } );
  54. export { DataTextureLoader };