Почему сетка, созданная с помощью 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