three.js: 透明物体内的 lensflare

three.js: lensflare inside transparent object

使用 three.js 我想创建从球体中心射出明亮光线的效果。

使用 THREE.lensflare() 我得到了一个很好的光,但是一旦我把它放在一个球体中,它就消失了。我为 renderOrder 尝试了不同的值,但无济于事。

我的 JSFiddle 在这里:http://jsfiddle.net/blwoodley/ds8ydm4t/8/

您可以通过简单地注释掉我将球体网格添加到场景中的行(第 33 行)来确认镜头光晕正在工作。

r71.

var SCREEN_WIDTH = window.innerWidth - 100;
var SCREEN_HEIGHT = window.innerHeight - 100;

var camera, scene, _planeMesh;
var canvasRenderer, webglRenderer;

var container, mesh, geometry, plane;

container = document.createElement('div');
document.body.appendChild(container);
scene = new THREE.Scene();
camera = new THREE.PerspectiveCamera(30, window.innerWidth / window.innerHeight, 1, 100000);
camera.position.set( 380, 80, 100 );
var spotLight = new THREE.SpotLight( 0xffffff );
spotLight.position.set( 180, 160, 0 );
var grid = new THREE.Mesh( new THREE.PlaneGeometry( 10000, 10000 ),
                                   new THREE.MeshBasicMaterial( { color: 0xaaaaaa } ) );
var grid = new THREE.GridHelper(400, 40);
//grid.rotation.x = -1.57;
grid.position.y = -20;
scene.add(grid);       

scene.add(spotLight);

camera.lookAt( scene.position );
var transparentmaterial = new THREE.MeshLambertMaterial( {
    color: 0xaaaa00,
    shading: THREE.SmoothShading,
    opacity: .5, transparent: true } );

var sphereGeo = new THREE.SphereGeometry( 32.0, 32, 16 );
var mesh = new THREE.Mesh( sphereGeo,transparentmaterial);
scene.add(mesh);

addLight(scene,0.55, 0.9, 0.5,0,0,0);

// RENDERER
webglRenderer = new THREE.WebGLRenderer({antialias: true, alpha: true });
webglRenderer.setSize(SCREEN_WIDTH, SCREEN_HEIGHT);
webglRenderer.domElement.style.position = "relative";
webglRenderer.setClearColor( 0x000000 );

container.appendChild(webglRenderer.domElement);
animate();

function addLight(scene, h, s, l, x, y, z ) {
        THREE.ImageUtils.crossOrigin = '';
        var textureFlare0 = THREE.ImageUtils.loadTexture('https://s3.amazonaws.com/jsfiddle1234/lensflare0.png');

    var light = new THREE.PointLight( 0xffffff, 1.5, 10 );
    light.color.setHSL( h, s, l );
    light.position.set( x, y, z );
    scene.add( light );
    light = light;

    var flareColor = new THREE.Color( 0xffffff );
    flareColor.setHSL( h, s, l + 0.5 );

    var lensFlare = new THREE.LensFlare( textureFlare0, 200, 0.0, THREE.AdditiveBlending, flareColor );

    lensFlare.position.copy( light.position );
    var lensFlare = lensFlare;

    scene.add( lensFlare );

}   


function animate() {
    requestAnimationFrame(animate);
    render();
}

function render() {
    webglRenderer.render(scene, camera);
}

最后渲染镜头光晕 -- 在透明对象之后。

问题是由于深度测试没有渲染镜头光晕。

该问题的一个解决方案是在渲染透明球体时防止深度写入:

transparentmaterial.depthWrite = false;

已更新 fiddle:http://jsfiddle.net/ds8ydm4t/10/

另一个解决方案是有两个场景和两个渲染通道——在第一通道后清除深度缓冲区。 (How to change the zOrder of object with Threejs?)

three.js r.71