| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091 | ( function () {	class XYZLoader extends THREE.Loader {		load( url, onLoad, onProgress, onError ) {			const scope = this;			const loader = new THREE.FileLoader( this.manager );			loader.setPath( this.path );			loader.setRequestHeader( this.requestHeader );			loader.setWithCredentials( this.withCredentials );			loader.load( url, function ( text ) {				try {					onLoad( scope.parse( text ) );				} catch ( e ) {					if ( onError ) {						onError( e );					} else {						console.error( e );					}					scope.manager.itemError( url );				}			}, onProgress, onError );		}		parse( text ) {			const lines = text.split( '\n' );			const vertices = [];			const colors = [];			for ( let line of lines ) {				line = line.trim();				if ( line.charAt( 0 ) === '#' ) continue; // skip comments				const lineValues = line.split( /\s+/ );				if ( lineValues.length === 3 ) {					// XYZ					vertices.push( parseFloat( lineValues[ 0 ] ) );					vertices.push( parseFloat( lineValues[ 1 ] ) );					vertices.push( parseFloat( lineValues[ 2 ] ) );				}				if ( lineValues.length === 6 ) {					// XYZRGB					vertices.push( parseFloat( lineValues[ 0 ] ) );					vertices.push( parseFloat( lineValues[ 1 ] ) );					vertices.push( parseFloat( lineValues[ 2 ] ) );					colors.push( parseFloat( lineValues[ 3 ] ) / 255 );					colors.push( parseFloat( lineValues[ 4 ] ) / 255 );					colors.push( parseFloat( lineValues[ 5 ] ) / 255 );				}			}			const geometry = new THREE.BufferGeometry();			geometry.setAttribute( 'position', new THREE.Float32BufferAttribute( vertices, 3 ) );			if ( colors.length > 0 ) {				geometry.setAttribute( 'color', new THREE.Float32BufferAttribute( colors, 3 ) );			}			return geometry;		}	}	THREE.XYZLoader = XYZLoader;} )();
 |