提交 a2a8589a 编写于 作者: M Mr.doob

ImageLoader: Use XHRLoader internally.

上级 8481242a
......@@ -14,71 +14,23 @@ THREE.ImageLoader.prototype = {
load: function ( url, onLoad, onProgress, onError ) {
if ( this.path !== undefined ) url = this.path + url;
var scope = this;
var cached = THREE.Cache.get( url );
if ( cached !== undefined ) {
scope.manager.itemStart( url );
if ( onLoad ) {
setTimeout( function () {
onLoad( cached );
scope.manager.itemEnd( url );
}, 0 );
} else {
scope.manager.itemEnd( url );
}
return cached;
}
var image = document.createElement( 'img' );
image.addEventListener( 'load', function ( event ) {
THREE.Cache.add( url, this );
if ( onLoad ) onLoad( this );
scope.manager.itemEnd( url );
}, false );
if ( onProgress !== undefined ) {
image.addEventListener( 'progress', function ( event ) {
onProgress( event );
}, false );
}
image.addEventListener( 'error', function ( event ) {
if ( onError ) onError( event );
var loader = new THREE.XHRLoader( this.manager );
loader.setPath( this.path );
loader.setResponseType( 'blob' );
loader.load( url, function ( blob ) {
scope.manager.itemError( url );
image.onload = function () {
}, false );
URL.revokeObjectURL( image.src );
if ( onLoad ) onLoad( image );
if ( this.crossOrigin !== undefined ) image.crossOrigin = this.crossOrigin;
};
scope.manager.itemStart( url );
image.src = URL.createObjectURL( blob );
image.src = url;
}, onProgress, onError );
return image;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册