三Js相机旋转问题

时间:2014-09-18 05:07:06

标签: javascript camera rotation three.js

我知道这是一个记录良好的问题,我已经进行了广泛的搜索,尝试了我找到的所有解决方案,但是,我无法完成最后一步。我有一个添加了相机的3D对象,我试图让第一人设置工作(相机的顺序设置为YXZ),当我尝试在x轴上旋转对象时,产生的运动是。 ..奇。 y旋转(即向左/向右看)工作正常。如果我在模拟开始时更改x旋转,向上和向下查看也可以正常工作,但是当我向左或向右看时,然后尝试向上/向下看,它会以最奇怪的角度旋转,从而使场景成为现实螺旋。这是一些代码:

                camera = new THREE.PerspectiveCamera( 75, window.innerWidth / window.innerHeight, 1, 1000 );             

                neck = new THREE.Object3D();
                neck.rotateOnAxis(new THREE.Vector3(1, 0, 0), degInRad(90));
                neck.up = new THREE.Vector3(0, 0, 1);
                neck.position.z = 10;
                neck.position.y = -5;
                neck.add(camera);
                scene.add(neck);

                if (leftPressed) {
                        neck.rotation.y += degInRad(1);  //look left
                } else if (rightPressed) {
                    neck.rotation.y -= degInRad(1);      //look right
                }
                if (upPressed) {
                    neck.rotation.x += degInRad(1);      //look up
                } else if (downPressed) {
                    neck.rotation.x -= degInRad(1);      //look down
                }

修改的 我已经阅读了关于这个问题的更多github问题,并了解了顺序轮换的问题。我猜或我的问题更尖锐的版本是:我如何更改lookAt()(或使用任何其他方法)以便更改x旋转不会影响y旋转?

1 个答案:

答案 0 :(得分:0)

如何为颈部创建另一个节点(Object3D)。这个想法是使用两个分开的坐标进行旋转。然后,您可以在y轴旋转新节点并在x轴旋转颈部。提示:不要忘记将颈部添加到新的Object3d节点。

.......
var neckNode = new THREE.Object3D();
neckNode.add(neck);
scene.add(neckNode);
.......
if (leftPressed) {
    neckNode.rotation.y += degInRad(1);  //look left
} else if (rightPressed) {
    neckNode.rotation.y -= degInRad(1);  //look right
}
if (upPressed) {
    neck.rotation.x += degInRad(1);      //look up
} else if (downPressed) {
    neck.rotation.x -= degInRad(1);      //look down
}

希望它有所帮助。