添加关照、全局等高线、修改图层问题
This commit is contained in:
106
dist/electron/static/sdk/three/jsm/loaders/XYZLoader.js
vendored
Normal file
106
dist/electron/static/sdk/three/jsm/loaders/XYZLoader.js
vendored
Normal file
@ -0,0 +1,106 @@
|
||||
import {
|
||||
BufferGeometry,
|
||||
Color,
|
||||
FileLoader,
|
||||
Float32BufferAttribute,
|
||||
Loader
|
||||
} from 'three';
|
||||
|
||||
class XYZLoader extends Loader {
|
||||
|
||||
load( url, onLoad, onProgress, onError ) {
|
||||
|
||||
const scope = this;
|
||||
|
||||
const loader = new 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 = [];
|
||||
const color = new Color();
|
||||
|
||||
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 ] ) );
|
||||
|
||||
const r = parseFloat( lineValues[ 3 ] ) / 255;
|
||||
const g = parseFloat( lineValues[ 4 ] ) / 255;
|
||||
const b = parseFloat( lineValues[ 5 ] ) / 255;
|
||||
|
||||
color.set( r, g, b ).convertSRGBToLinear();
|
||||
|
||||
colors.push( color.r, color.g, color.b );
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
const geometry = new BufferGeometry();
|
||||
geometry.setAttribute( 'position', new Float32BufferAttribute( vertices, 3 ) );
|
||||
|
||||
if ( colors.length > 0 ) {
|
||||
|
||||
geometry.setAttribute( 'color', new Float32BufferAttribute( colors, 3 ) );
|
||||
|
||||
}
|
||||
|
||||
return geometry;
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
export { XYZLoader };
|
Reference in New Issue
Block a user