| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687 | import { LineSegmentsGeometry } from '../lines/LineSegmentsGeometry.js';class LineGeometry extends LineSegmentsGeometry {	constructor() {		super();		this.type = 'LineGeometry';	}	setPositions( array ) {		// converts [ x1, y1, z1,  x2, y2, z2, ... ] to pairs format		var length = array.length - 3;		var points = new Float32Array( 2 * length );		for ( var i = 0; i < length; i += 3 ) {			points[ 2 * i ] = array[ i ];			points[ 2 * i + 1 ] = array[ i + 1 ];			points[ 2 * i + 2 ] = array[ i + 2 ];			points[ 2 * i + 3 ] = array[ i + 3 ];			points[ 2 * i + 4 ] = array[ i + 4 ];			points[ 2 * i + 5 ] = array[ i + 5 ];		}		super.setPositions( points );		return this;	}	setColors( array ) {		// converts [ r1, g1, b1,  r2, g2, b2, ... ] to pairs format		var length = array.length - 3;		var colors = new Float32Array( 2 * length );		for ( var i = 0; i < length; i += 3 ) {			colors[ 2 * i ] = array[ i ];			colors[ 2 * i + 1 ] = array[ i + 1 ];			colors[ 2 * i + 2 ] = array[ i + 2 ];			colors[ 2 * i + 3 ] = array[ i + 3 ];			colors[ 2 * i + 4 ] = array[ i + 4 ];			colors[ 2 * i + 5 ] = array[ i + 5 ];		}		super.setColors( colors );		return this;	}	fromLine( line ) {		var geometry = line.geometry;		if ( geometry.isGeometry ) {			console.error( 'THREE.LineGeometry no longer supports Geometry. Use THREE.BufferGeometry instead.' );			return;		} else if ( geometry.isBufferGeometry ) {			this.setPositions( geometry.attributes.position.array ); // assumes non-indexed		}		// set colors, maybe		return this;	}}LineGeometry.prototype.isLineGeometry = true;export { LineGeometry };
 |