Spaces:
Running
Running
import { Sphere } from '../math/Sphere.js'; | |
import { Vector3 } from '../math/Vector3.js'; | |
import { BufferAttribute } from '../core/BufferAttribute.js'; | |
import { BufferGeometry } from '../core/BufferGeometry.js'; | |
import { FileLoader } from './FileLoader.js'; | |
import { DefaultLoadingManager } from './LoadingManager.js'; | |
/** | |
* @author mrdoob / http://mrdoob.com/ | |
*/ | |
function BufferGeometryLoader( manager ) { | |
this.manager = ( manager !== undefined ) ? manager : DefaultLoadingManager; | |
} | |
Object.assign( BufferGeometryLoader.prototype, { | |
load: function ( url, onLoad, onProgress, onError ) { | |
var scope = this; | |
var loader = new FileLoader( scope.manager ); | |
loader.setPath( scope.path ); | |
loader.load( url, function ( text ) { | |
onLoad( scope.parse( JSON.parse( text ) ) ); | |
}, onProgress, onError ); | |
}, | |
parse: function ( json ) { | |
var geometry = new BufferGeometry(); | |
var index = json.data.index; | |
if ( index !== undefined ) { | |
var typedArray = new TYPED_ARRAYS[ index.type ]( index.array ); | |
geometry.setIndex( new BufferAttribute( typedArray, 1 ) ); | |
} | |
var attributes = json.data.attributes; | |
for ( var key in attributes ) { | |
var attribute = attributes[ key ]; | |
var typedArray = new TYPED_ARRAYS[ attribute.type ]( attribute.array ); | |
var bufferAttribute = new BufferAttribute( typedArray, attribute.itemSize, attribute.normalized ); | |
if ( attribute.name !== undefined ) bufferAttribute.name = attribute.name; | |
geometry.addAttribute( key, bufferAttribute ); | |
} | |
var morphAttributes = json.data.morphAttributes; | |
if ( morphAttributes ) { | |
for ( var key in morphAttributes ) { | |
var attributeArray = morphAttributes[ key ]; | |
var array = []; | |
for ( var i = 0, il = attributeArray.length; i < il; i ++ ) { | |
var attribute = attributeArray[ i ]; | |
var typedArray = new TYPED_ARRAYS[ attribute.type ]( attribute.array ); | |
var bufferAttribute = new BufferAttribute( typedArray, attribute.itemSize, attribute.normalized ); | |
if ( attribute.name !== undefined ) bufferAttribute.name = attribute.name; | |
array.push( bufferAttribute ); | |
} | |
geometry.morphAttributes[ key ] = array; | |
} | |
} | |
var groups = json.data.groups || json.data.drawcalls || json.data.offsets; | |
if ( groups !== undefined ) { | |
for ( var i = 0, n = groups.length; i !== n; ++ i ) { | |
var group = groups[ i ]; | |
geometry.addGroup( group.start, group.count, group.materialIndex ); | |
} | |
} | |
var boundingSphere = json.data.boundingSphere; | |
if ( boundingSphere !== undefined ) { | |
var center = new Vector3(); | |
if ( boundingSphere.center !== undefined ) { | |
center.fromArray( boundingSphere.center ); | |
} | |
geometry.boundingSphere = new Sphere( center, boundingSphere.radius ); | |
} | |
if ( json.name ) geometry.name = json.name; | |
if ( json.userData ) geometry.userData = json.userData; | |
return geometry; | |
}, | |
setPath: function ( value ) { | |
this.path = value; | |
return this; | |
} | |
} ); | |
var TYPED_ARRAYS = { | |
Int8Array: Int8Array, | |
Uint8Array: Uint8Array, | |
// Workaround for IE11 pre KB2929437. See #11440 | |
Uint8ClampedArray: typeof Uint8ClampedArray !== 'undefined' ? Uint8ClampedArray : Uint8Array, | |
Int16Array: Int16Array, | |
Uint16Array: Uint16Array, | |
Int32Array: Int32Array, | |
Uint32Array: Uint32Array, | |
Float32Array: Float32Array, | |
Float64Array: Float64Array | |
}; | |
export { BufferGeometryLoader }; | |