ImageLoader.js 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  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. crossOrigin: 'Anonymous',
  11. load: function ( url, onLoad, onProgress, onError ) {
  12. if ( url === undefined ) url = '';
  13. if ( this.path !== undefined ) url = this.path + url;
  14. var scope = this;
  15. var cached = Cache.get( url );
  16. if ( cached !== undefined ) {
  17. scope.manager.itemStart( url );
  18. setTimeout( function () {
  19. if ( onLoad ) onLoad( cached );
  20. scope.manager.itemEnd( url );
  21. }, 0 );
  22. return cached;
  23. }
  24. var image = document.createElementNS( 'http://www.w3.org/1999/xhtml', 'img' );
  25. image.addEventListener( 'load', function () {
  26. Cache.add( url, this );
  27. if ( onLoad ) onLoad( this );
  28. scope.manager.itemEnd( url );
  29. }, false );
  30. /*
  31. image.addEventListener( 'progress', function ( event ) {
  32. if ( onProgress ) onProgress( event );
  33. }, false );
  34. */
  35. image.addEventListener( 'error', function ( event ) {
  36. if ( onError ) onError( event );
  37. scope.manager.itemEnd( url );
  38. scope.manager.itemError( url );
  39. }, false );
  40. if ( url.substr( 0, 5 ) !== 'data:' ) {
  41. if ( this.crossOrigin !== undefined ) image.crossOrigin = this.crossOrigin;
  42. }
  43. scope.manager.itemStart( url );
  44. image.src = url;
  45. return image;
  46. },
  47. setCrossOrigin: function ( value ) {
  48. this.crossOrigin = value;
  49. return this;
  50. },
  51. setPath: function ( value ) {
  52. this.path = value;
  53. return this;
  54. }
  55. } );
  56. export { ImageLoader };