javascript - 同步 Object3d 旋转(选项卡级别)

标签 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);
 })

此处的问题是第二个对象未与第一个对象正确同步。有人知道我做错了什么吗?

谢谢

最佳答案

在一个选项卡中,您请求当前(绝对)旋转。在另一种情况下,您可以在当前旋转的基础上加上这些值进行旋转。这将在您第一次设置非零旋转后立即中断。

你想要的是分配轮换,通过这样做

SecondObject.rotation.copy(target.rotation);

关于javascript - 同步 Object3d 旋转(选项卡级别),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54218311/

相关文章:

rotation - PDFsharp 更改原点

html - 如何在使用 css/js 旋转后定位/调整图像大小,以便图像不会定位在持有它的 div 之外或被裁剪掉

php - 无法将对象或字符串放入 javascript 数组

javascript - gulp 错误 : Cannot find module browserify

javascript - 为什么这个ajax表单没有重置?

javascript - Vuejs可拖动排序列表

javascript - 在运行时更改 Three.js Material 纹理会引发错误

javascript - Three.js 中的强光 Material 混合模式?

javascript - 使用 three.js 应用相机位置和旋转

javascript - THREE.js OrbitControls 不工作