我试图通过THREE.NoBlending hack将对象放在CSS3DObjects前面。但是我在最新版本中只看到没有CSS3DObject的黑色平面(试过r65和r66)。我做的一个小例子看起来像这样:
的index.html:
<!doctype html>
<script src="lib/three58.js"></script>
<script src="lib/CSS3dRenderer.js"></script>
<body>
<script>
var camera = new THREE.PerspectiveCamera(60, window.innerWidth / window.innerHeight, 0.01, 555);
camera.position.z += 20;
var rendererCSS = new THREE.CSS3DRenderer();
rendererCSS.setSize(window.innerWidth, window.innerHeight);
rendererCSS.domElement.style.position = 'absolute';
document.body.appendChild(rendererCSS.domElement);
var rendererMain = new THREE.WebGLRenderer();
rendererMain.setSize(window.innerWidth, window.innerHeight);
rendererMain.setClearColor("white", 0);
rendererMain.domElement.style.position = 'absolute';
document.body.appendChild(rendererMain.domElement);
var scene = new THREE.Scene();
var sceneCSS = new THREE.Scene();
var planeWidth = 15;
var planeHeight = 15;
var planeMaterial = new THREE.MeshBasicMaterial({
blending: THREE.NoBlending,
opacity : 0.0,
transparent : true,
color : 0x000000,
side : THREE.DoubleSide
});
var planeGeometry = new THREE.PlaneGeometry(planeWidth, planeHeight);
var planeMesh = new THREE.Mesh(planeGeometry, planeMaterial);
scene.add(planeMesh);
var element = document.createElement('iframe')
var aspectRatio = planeHeight / planeWidth;
var elementWidth = 1024;
var elementHeight = elementWidth * aspectRatio;
element.src = 'moo.html';
element.style.width = elementWidth + "px";
element.style.height = elementHeight + "px";
var objectCSS = new THREE.CSS3DObject(element);
objectCSS.scale.x = planeWidth / elementWidth;
objectCSS.scale.y = planeHeight / elementHeight;
objectCSS.position = planeMesh.position;
objectCSS.rotation = planeMesh.rotation;
sceneCSS.add(objectCSS);
var material = new THREE.MeshBasicMaterial({color: 0xff0000});
var mesh = new THREE.Mesh(new THREE.SphereGeometry(5.0, 20.0, 20.0), material);
var mesh2 = new THREE.Mesh(new THREE.SphereGeometry(5.0, 20.0, 20.0), material);
mesh.position.set(5, 0, -1);
mesh2.position.set(-8, 0, -6);
scene.add(mesh); // in front
scene.add(mesh2); // behind
animate();
function animate() {
requestAnimationFrame(animate);
rendererMain.render(scene, camera);
rendererCSS.render(sceneCSS, camera);
}
</script>
</body>
moo.html:
<!DOCTYPE html>
<html>
<body style="background-color: purple">
<p align="center"><font color="lime" size="150">hello world</font> </p>
</body>
</html>
结果如下:
修订版58:http://i.imgur.com/tCszJ8X.jpg
修订版66:http://i.imgur.com/kfppVwF.jpg
我试图理解为什么,它可能非常简单。我无法在迁移中发现任何会以这种方式改变行为的内容。
提前致谢。
答案 0 :(得分:2)
如果您希望透明背景为WebGLRenderer
,则需要在alpha = true
构造函数中设置WebGLRenderer
。然后,您可以设置清晰的颜色。
var renderer = new THREE.WebGLRenderer( { alpha: true } );
renderer.setClearColor( 0x00ff00, 0.5 );
three.js r.66