Почему сетка, созданная с помощью ThreeBSP.js, не работает должным образом с любым материалом, кроме MeshNormalMaterial?

Игра в кости выглядит как игра в кости, только если я использую MeshNormalMaterial во второй последней строке (result = resultBSP.toMesh(materialNormal);). С любым другим материалом это просто выглядит как куб без subtraction (точки) на нем. ThreeBSP Библиотека (ThreeCSG upgrade), которую я использую, находится здесь. Нет проблем с использованием MeshNormalMaterial, У него просто нет практически никаких возможностей для его изменения. (Он не принимает параметры, как другие материалы). Любые предложения будут очень признательны. Вот моя функция, которую я использую для создания игры в кости:

function buildDice(){

    var materialNormal = new THREE.MeshNormalMaterial();
    var diceCube = new THREE.Mesh( new THREE.BoxGeometry(100,100,100), materialNormal);

    diceCube.position.x = 0;
    diceCube.position.y = 50;
    diceCube.position.z = 0;

    diceCube.geometry.computeFaceNormals();
    diceCube.geometry.computeVertexNormals();

    var cubeBSP = new ThreeBSP(diceCube);

    var sphereGeometry = new THREE.SphereGeometry(75,16,8);
    var sphereMesh = new THREE.Mesh(sphereGeometry, materialNormal);

    sphereMesh.scale.x = 0.17;
    sphereMesh.scale.y = 0.17;
    sphereMesh.scale.z = 0.17;

    //coords of the spheres 
    var xPositions = [....]; // coordinates for xPositions of sphereMesh
    var yPositions = [....];
    var zPositions = [....];


    var diceDots    = new THREE.Geometry();

    for(var i = 0; i < xPositions.length; i++){

        sphereMesh.position.x   = xPositions[i];
        sphereMesh.position.y   = yPositions[i];
        sphereMesh.position.z   = zPositions[i];
        THREE.GeometryUtils.merge(diceDots, sphereMesh);
    }

    var dotsMesh = new THREE.Mesh(diceDots, materialNormal);
    dotsMesh.geometry.computeFaceNormals();
    dotsMesh.geometry.computeVertexNormals();

    var dotsBSP = new ThreeBSP(dotsMesh);
    var resultBSP = cubeBSP.subtract(dotsBSP);

    result = resultBSP.toMesh(materialNormal);
    scene.add(result);

}

1 ответ

Решение

Он работает с другими материалами, например, с THREE.MeshPhongMaterial, Это jsfiddle, используя ваш buildDice()-функция может вам помочь: http://jsfiddle.net/L0rdzbej/152/

Вы должны обновить матрицу сетки перед объединением геометрии, и лучше всего не использовать устаревшие функции для этого.

Three.js R73

Другие вопросы по тегам