同步Object3d旋转(标签级)

时间:2019-01-16 13:39:08

标签: javascript three.js rotation

需要帮助,

我正在尝试将活动浏览器选项卡中加载的一个对象与第二个选项卡中加载的另一个对象的旋转同步。旋转时,加载到活动浏览器选项卡中的对象将向另一个发送消息。在第二个选项卡中,将侦听从第一个选项卡发送的消息,并使用旋转值相应地旋转对象。我的代码如下所示((我提到了this示例)

 let objectLoaded;
 let previousMousePosition = {x : 0,  y : 0 };
    function mouseDown(e) {
        isDragging = true;
    }

    function mouseUp() {
        isDragging = false;
        if (objectLoaded) {
            // publishing the rotation value to another tab using 'hermes' package.
            hermes.send('rotation', JSON.stringify({
                rotation: objectLoaded.rotation,
                quaternion: objectLoaded.getWorldQuaternion(),
                matrix: objectLoaded.matrixWorld
            })); 
        }
    }

    function mouseMove(e) {
        const deltaMove = { x : e.offsetX - previousMousePosition.x,y : e.offsetY - previousMousePosition.y };         
        if (isDragging && objectLoaded) {
            const deltaRotationQuaternion = new THREE.Quaternion().setFromEuler(new THREE.Euler(toRadians(deltaMove.y * 1), toRadians(deltaMove.x * 1), 0, 'XYZ'));
            objectLoaded.quaternion.multiplyQuaternions(deltaRotationQuaternion, objectLoaded.quaternion);
        }
        previousMousePosition = {x : e.offsetX,  y : e.offsetY };
    }

    function toRadians(angle) {
         return angle * (Math.PI / 180);
    }

侦听器代码,

  hermes.on('rotation', (rotationObj) => {
  // rotationObj structure: {rotation: { _x: 0, _y: 0: _z: 0}, quaternion: { _x: 0, _y: 0: _z: 0, _w: 0}}
      const target = JSON.parse(rotationObj);
      SecondObject.rotateX(target.rotation._x);
      SecondObject.rotateY(target.rotation._y);
      SecondObject.rotateZ(target.rotation._z);
 })

这里的问题是第二个对象与第一个对象无法正确同步。有人知道我在做什么错吗?

谢谢

1 个答案:

答案 0 :(得分:1)

在一个选项卡中,您请求当前(绝对)旋转。另一方面,您将 addition 中的值旋转到当前旋转。第一次设置非零旋转后,这种情况就会消失。

您要执行的操作是分配

address