threejs.org/examples/#w…

const dpr = window.devicePixelRatio;
const textureSize = 128 * dpr;
const width = window.innerWidth;
const height = window.innerHeight;
camera = new THREE.PerspectiveCamera( 70, width / height, 1, 1000 );
camera.position.z = 20;
cameraOrtho = new THREE.OrthographicCamera( - width / 2, width / 2, height / 2, - height / 2, 1, 10 );
cameraOrtho.position.z = 10;
- 添加线

const points = GeometryUtils.gosper( 8 );
const geometry = new THREE.BufferGeometry();
const positionAttribute = new THREE.Float32BufferAttribute( points, 3 );
geometry.setAttribute( 'position', positionAttribute );
geometry.center();
const colorAttribute = new THREE.BufferAttribute( new Float32Array( positionAttribute.array.length ), 3 );
colorAttribute.setUsage( THREE.DynamicDrawUsage );
geometry.setAttribute( 'color', colorAttribute );
const material = new THREE.LineBasicMaterial( { vertexColors: true } );
line = new THREE.Line( geometry, material );
line.scale.setScalar( 0.05 );
scene.add( line );
const spriteMaterial = new THREE.SpriteMaterial( { map: texture } );
sprite = new THREE.Sprite( spriteMaterial );
sprite.scale.set( textureSize, textureSize, 1 );
sceneOrtho.add( sprite );
const halfWidth = window.innerWidth / 2;
const halfHeight = window.innerHeight / 2;
const halfImageWidth = textureSize / 2;
const halfImageHeight = textureSize / 2;
sprite.position.set( - halfWidth + halfImageWidth, halfHeight - halfImageHeight, 1 );
const data = new Uint8Array( textureSize * textureSize * 3 );
texture = new THREE.DataTexture( data, textureSize, textureSize, THREE.RGBFormat );
texture.minFilter = THREE.NearestFilter;
texture.magFilter = THREE.NearestFilter;
- 两个render意味着渲染两帧出来 然后重叠在一起
renderer.clear();
renderer.render( scene, camera );
vector.x = ( window.innerWidth * dpr / 2 ) - ( textureSize / 2 );
vector.y = ( window.innerHeight * dpr / 2 ) - ( textureSize / 2 );
renderer.copyFramebufferToTexture( vector, texture );
renderer.clearDepth();
renderer.render( sceneOrtho, cameraOrtho );