ImageLoader.js 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. /**
  2. * @author mrdoob / http://mrdoob.com/
  3. */
  4. import { Cache } from './Cache';
  5. import { DefaultLoadingManager } from './LoadingManager';
  6. function ImageLoader( manager ) {
  7. this.manager = ( manager !== undefined ) ? manager : DefaultLoadingManager;
  8. }
  9. Object.assign( ImageLoader.prototype, {
  10. load: function ( url, onLoad, onProgress, onError ) {
  11. if ( url === undefined ) url = '';
  12. if ( this.path !== undefined ) url = this.path + url;
  13. var scope = this;
  14. var cached = Cache.get( url );
  15. if ( cached !== undefined ) {
  16. scope.manager.itemStart( url );
  17. setTimeout( function () {
  18. if ( onLoad ) onLoad( cached );
  19. scope.manager.itemEnd( url );
  20. }, 0 );
  21. return cached;
  22. }
  23. var image = document.createElementNS( 'http://www.w3.org/1999/xhtml', 'img' );
  24. image.addEventListener( 'load', function () {
  25. Cache.add( url, this );
  26. if ( onLoad ) onLoad( this );
  27. scope.manager.itemEnd( url );
  28. }, false );
  29. /*
  30. image.addEventListener( 'progress', function ( event ) {
  31. if ( onProgress ) onProgress( event );
  32. }, false );
  33. */
  34. image.addEventListener( 'error', function ( event ) {
  35. if ( onError ) onError( event );
  36. scope.manager.itemError( url );
  37. }, false );
  38. if ( this.crossOrigin !== undefined ) image.crossOrigin = this.crossOrigin;
  39. scope.manager.itemStart( url );
  40. image.src = url;
  41. return image;
  42. },
  43. setCrossOrigin: function ( value ) {
  44. this.crossOrigin = value;
  45. return this;
  46. },
  47. setPath: function ( value ) {
  48. this.path = value;
  49. return this;
  50. }
  51. } );
  52. export { ImageLoader };
粤ICP备19079148号