XHRLoader.js 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. /**
  2. * @author mrdoob / http://mrdoob.com/
  3. */
  4. THREE.XHRLoader = function ( manager ) {
  5. this.manager = ( manager !== undefined ) ? manager : THREE.DefaultLoadingManager;
  6. };
  7. THREE.XHRLoader.prototype = {
  8. constructor: THREE.XHRLoader,
  9. load: function ( url, onLoad, onProgress, onError ) {
  10. if ( this.path !== undefined ) url = this.path + url;
  11. var scope = this;
  12. var cached = THREE.Cache.get( url );
  13. if ( cached !== undefined ) {
  14. if ( onLoad ) {
  15. setTimeout( function () {
  16. onLoad( cached );
  17. }, 0 );
  18. }
  19. return cached;
  20. }
  21. var request = new XMLHttpRequest();
  22. request.open( 'GET', url, true );
  23. request.addEventListener( 'load', function ( event ) {
  24. var response = event.target.response;
  25. THREE.Cache.add( url, response );
  26. if ( this.status == 200 && this.readyState == 4 ) {
  27. if ( onLoad ) onLoad( response );
  28. } else {
  29. if ( onError ) onError( event );
  30. }
  31. scope.manager.itemEnd( url );
  32. }, false );
  33. if ( onProgress !== undefined ) {
  34. request.addEventListener( 'progress', function ( event ) {
  35. onProgress( event );
  36. }, false );
  37. }
  38. request.addEventListener( 'error', function ( event ) {
  39. if ( onError ) onError( event );
  40. scope.manager.itemError( url );
  41. }, false );
  42. if ( this.crossOrigin !== undefined ) request.crossOrigin = this.crossOrigin;
  43. if ( this.responseType !== undefined ) request.responseType = this.responseType;
  44. if ( this.withCredentials !== undefined ) request.withCredentials = this.withCredentials;
  45. request.send( null );
  46. scope.manager.itemStart( url );
  47. return request;
  48. },
  49. setCrossOrigin: function ( value ) {
  50. this.crossOrigin = value;
  51. },
  52. setResponseType: function ( value ) {
  53. this.responseType = value;
  54. },
  55. setPath: function ( value ) {
  56. this.path = value;
  57. },
  58. setWithCredentials: function ( value ) {
  59. this.withCredentials = value;
  60. }
  61. };