THREE.js三角形是黑色的

时间:2013-10-29 16:52:49

标签: javascript colors three.js geometry

所以我使用了THREE.JS并创建了一个三角形。但即使我给它颜色:0xFF0000,它在屏幕上显示为黑色。

这是我的剧本:

var camera, scene, renderer;
var geometry, material, mesh;

init();
animate();

function init() {

    scene = new THREE.Scene();
    camera = new THREE.PerspectiveCamera(35, window.innerWidth / window.innerHeight, 1, 10000);
    camera.position.z = 500;
    scene.add(camera);

    var geometry = new THREE.Geometry(200,200,200);
    var v1 = new THREE.Vector3(200,0,0);   // Vector3 used to specify position
    var v2 = new THREE.Vector3(-100,0,0);
    var v3 = new THREE.Vector3(0,50,0);   // 2d = all vertices in the same plane.. z = 0

    // Push vertices represented by position vectors
    geometry.vertices.push(v1);
    geometry.vertices.push(v2);
    geometry.vertices.push(v3);

    // Push face, defined with vertices in counter clock-wise order
    geometry.faces.push(new THREE.Face3(0, 2, 1));

    // Create a material and combine with geometry to create our mesh
    var redMat = new THREE.MeshLambertMaterial({color: 0xFF0000});
    var triangle = new THREE.Mesh(geometry, redMat);
    scene.add(triangle);

    renderer = new THREE.CanvasRenderer();
    renderer.setSize(window.innerWidth, window.innerHeight);

    document.body.appendChild(renderer.domElement);

}

function animate() {

    requestAnimationFrame(animate);
    render();

}

function render() {

    renderer.render(scene, camera);

}

希望你能找到我犯的错误。我确信这只是一些非常愚蠢的事情。

3 个答案:

答案 0 :(得分:2)

派对迟到了......但对于所有追随我的人来说。 这里的问题是使用的材料类型

变化

new THREE.MeshLambertMaterial({color: 0xFF0000});


new THREE.MeshBasicMaterial({color: 0xFF0000});

它会显示红色

答案 1 :(得分:0)

即使我已经在这个问题上挣扎了一段时间。对我来说,解决方案是如果您正在使用Lambert材料,则为场景添加环境光。

只需添加:

var light = new THREE.AmbientLight(0xffffff);
scene.add(light);

答案 2 :(得分:0)

尝试在几何对象上添加computeFaceNormals调用

  

geometry.computeFaceNormals();

*来自 https://stackoverflow.com/a/49226898/2154075