我创建了一个由 THREE.JS 和 Physijs 制作的游戏。我制作了一个名为 addBlock2 的函数,它在场景中添加了一个三角金字塔。它设置了适当的顶点,但是当涉及到 triangulateShape 时,它会失败并出现以下错误:
Uncaught TypeError: Cannot read property 'x' of undefined
THREE.Shape.Utils.triangulateShape @ three.min.js:680
Game.addBlock2 @ game.js:210
Game.update @ game.js:271
(anonymous function) @ game.js:284
onAnimationFrame @ VM3973:49
(anonymous function) @ VM3973:18
game.js:210 是“triangulateShape”行。
这是代码:
Game.prototype.addBlock2 = function(x,y,z) {
var geometry = new THREE.Geometry();
geometry.vertices = [
THREE.Vector3(0,0,0),
THREE.Vector3(0,200,-100),
THREE.Vector3(100,200,100),
THREE.Vector3(-100,200,100)
]
var triangles = THREE.Shape.Utils.triangulateShape(geometry.vertices, []);
for (i in triangles){
geometry.faces[geometry.faces.length] = new THREE.Face3(triangles[i][0], triangles[i][1], triangles[i][2])
}
geometry.computeFaceNormals();
geometry.computeVertexNormals();
var material = Physijs.createMaterial(new THREE.MeshPhongMaterial({color: 0xFFFF00}),0.3,0.8);
try {
var mesh = new Physijs.ConvexMesh(geometry,material);
}
catch (e) {
console.log(e,geometry,material)
return
}
mesh.position.x = x || 0
mesh.position.y = y || 0
mesh.position.z = z || 0
mesh.__dirtyPosition = true
mesh.name = "block."+(x||0)+","+(y||0)+","+(z||0)
mesh.receiveShadow = true
this.scene.add(mesh);
this.blocks[this.blocks.length] = mesh
}