FileLoader.js 4.5 KB
Newer Older
M
Mr.doob 已提交
1 2 3 4
/**
 * @author mrdoob / http://mrdoob.com/
 */

B
bentok 已提交
5 6
import { Cache } from './Cache.js';
import { DefaultLoadingManager } from './LoadingManager.js';
M
Mr.doob 已提交
7

M
Mr.doob 已提交
8
function FileLoader( manager ) {
M
Mr.doob 已提交
9

R
Rich Harris 已提交
10
	this.manager = ( manager !== undefined ) ? manager : DefaultLoadingManager;
M
Mr.doob 已提交
11

M
Mr.doob 已提交
12
}
M
Mr.doob 已提交
13

M
Mr.doob 已提交
14
Object.assign( FileLoader.prototype, {
M
Mr.doob 已提交
15 16 17

	load: function ( url, onLoad, onProgress, onError ) {

18 19
		if ( url === undefined ) url = '';

M
Mr.doob 已提交
20 21
		if ( this.path !== undefined ) url = this.path + url;

22 23
		var scope = this;

R
Rich Harris 已提交
24
		var cached = Cache.get( url );
25 26 27

		if ( cached !== undefined ) {

28
			scope.manager.itemStart( url );
D
dubejf 已提交
29

30 31
			setTimeout( function () {

M
Mr.doob 已提交
32
				if ( onLoad ) onLoad( cached );
D
dubejf 已提交
33

34
				scope.manager.itemEnd( url );
D
dubejf 已提交
35

36
			}, 0 );
D
dubejf 已提交
37

38
			return cached;
39 40 41

		}

42 43 44
		// Check for data: URI
		var dataUriRegex = /^data:(.*?)(;base64)?,(.*)$/;
		var dataUriRegexResult = url.match( dataUriRegex );
M
Mr.doob 已提交
45

46 47
		// Safari can not handle Data URIs through XMLHttpRequest so process manually
		if ( dataUriRegexResult ) {
M
Mr.doob 已提交
48

M
Mr.doob 已提交
49 50 51
			var mimeType = dataUriRegexResult[ 1 ];
			var isBase64 = !! dataUriRegexResult[ 2 ];
			var data = dataUriRegexResult[ 3 ];
M
Mr.doob 已提交
52

M
Mr.doob 已提交
53
			data = window.decodeURIComponent( data );
54

M
Mr.doob 已提交
55
			if ( isBase64 ) data = window.atob( data );
56

57
			try {
58

59 60
				var response;
				var responseType = ( this.responseType || '' ).toLowerCase();
61

62
				switch ( responseType ) {
63

64 65
					case 'arraybuffer':
					case 'blob':
66

K
kkruups 已提交
67 68
					 
						var view = new Uint8Array( data.length );
M
Mr.doob 已提交
69

70
						for ( var i = 0; i < data.length; i ++ ) {
M
Mr.doob 已提交
71

M
Mr.doob 已提交
72
							view[ i ] = data.charCodeAt( i );
M
Mr.doob 已提交
73

74
						}
75

76
						if ( responseType === 'blob' ) {
M
Mr.doob 已提交
77

K
kkruups 已提交
78
							response = new Blob( [ view.buffer ], { type: mimeType } );
M
Mr.doob 已提交
79

K
kkruups 已提交
80 81 82 83
						} else {
						   
							response = view.buffer;	
						}	
84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107

						break;

					case 'document':

						var parser = new DOMParser();
						response = parser.parseFromString( data, mimeType );

						break;

					case 'json':

						response = JSON.parse( data );

						break;

					default: // 'text' or other

						response = data;

						break;

				}

K
kkruups 已提交
108
				// Wait for next browser tick like standard XMLHttpRequest event dispatching does
M
Mr.doob 已提交
109
				window.setTimeout( function () {
110 111 112 113 114

					if ( onLoad ) onLoad( response );

					scope.manager.itemEnd( url );

M
Mr.doob 已提交
115
				}, 0 );
116 117 118

			} catch ( error ) {

K
kkruups 已提交
119
				// Wait for next browser tick like standard XMLHttpRequest event dispatching does
M
Mr.doob 已提交
120
				window.setTimeout( function () {
121 122 123

					if ( onError ) onError( error );

124
					scope.manager.itemEnd( url );
125 126
					scope.manager.itemError( url );

M
Mr.doob 已提交
127
				}, 0 );
128

129
			}
M
Mr.doob 已提交
130

131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152
		} else {

			var request = new XMLHttpRequest();
			request.open( 'GET', url, true );

			request.addEventListener( 'load', function ( event ) {

				var response = event.target.response;

				Cache.add( url, response );

				if ( this.status === 200 ) {

					if ( onLoad ) onLoad( response );

					scope.manager.itemEnd( url );

				} else if ( this.status === 0 ) {

					// Some browsers return HTTP Status 0 when using non-http protocol
					// e.g. 'file://' or 'data://'. Handle as success.

M
Mr.doob 已提交
153
					console.warn( 'THREE.FileLoader: HTTP Status 0 received.' );
154 155 156 157

					if ( onLoad ) onLoad( response );

					scope.manager.itemEnd( url );
M
Mr.doob 已提交
158

159
				} else {
M
Mr.doob 已提交
160

161
					if ( onError ) onError( event );
M
Mr.doob 已提交
162

163
					scope.manager.itemEnd( url );
164 165 166
					scope.manager.itemError( url );

				}
M
Mr.doob 已提交
167 168 169

			}, false );

170 171 172 173 174 175 176 177 178 179 180
			if ( onProgress !== undefined ) {

				request.addEventListener( 'progress', function ( event ) {

					onProgress( event );

				}, false );

			}

			request.addEventListener( 'error', function ( event ) {
M
Mr.doob 已提交
181

182
				if ( onError ) onError( event );
M
Mr.doob 已提交
183

184
				scope.manager.itemEnd( url );
185
				scope.manager.itemError( url );
M
Mr.doob 已提交
186

187
			}, false );
M
Mr.doob 已提交
188

189 190
			if ( this.responseType !== undefined ) request.responseType = this.responseType;
			if ( this.withCredentials !== undefined ) request.withCredentials = this.withCredentials;
M
Mr.doob 已提交
191

192
			if ( request.overrideMimeType ) request.overrideMimeType( this.mimeType !== undefined ? this.mimeType : 'text/plain' );
M
Mr.doob 已提交
193

T
Takahiro 已提交
194
			for ( var header in this.requestHeader ) {
195

T
Takahiro 已提交
196
				request.setRequestHeader( header, this.requestHeader[ header ] );
197 198 199

			}

200
			request.send( null );
201

202
		}
M
Mr.doob 已提交
203

M
Mr.doob 已提交
204 205
		scope.manager.itemStart( url );

J
Josh Sacks 已提交
206 207
		return request;

M
Mr.doob 已提交
208 209
	},

210
	setPath: function ( value ) {
M
Mr.doob 已提交
211

212
		this.path = value;
M
Mr.doob 已提交
213
		return this;
M
Mr.doob 已提交
214 215 216

	},

217 218 219
	setResponseType: function ( value ) {

		this.responseType = value;
M
Mr.doob 已提交
220
		return this;
221 222 223

	},

224 225 226
	setWithCredentials: function ( value ) {

		this.withCredentials = value;
M
Mr.doob 已提交
227
		return this;
228

229 230 231 232 233 234 235
	},

	setMimeType: function ( value ) {

		this.mimeType = value;
		return this;

236 237 238 239 240 241 242
	},

	setRequestHeader: function ( value ) {

		this.requestHeader = value;
		return this;

M
Mr.doob 已提交
243 244
	}

M
Mr.doob 已提交
245
} );
R
Rich Harris 已提交
246 247


M
Mr.doob 已提交
248
export { FileLoader };