three.Js使用TransformControls报错

发布于 2022-09-04 14:32:05 字数 1032 浏览 20 评论 0

官网中TransformControls的例子时通过键盘W,E,R这些按键去注册不同的动作来对长中的物体操作。
我想要在页面上放置两个按钮,拖动和旋转,按钮点击事件再注册控制器的动作,同时将控制器添加到场景中。
图片描述
但是总是报错:Uncaught TypeError: Cannot read property 'updateMatrixWorld' of null

当我点击物体时,上方按钮出现,选择动作,然后控制物体移动或时旋转

function tuodong(){
    tfcontrols.setMode( "translate" );
    tfcontrols.attach( SELECTED );
    scene.add( tfcontrols );
}

function xuanzhuan(){
    tfcontrols.setMode("rotate");
    tfcontrols.attach(SELECTED);
    scene.add( tfcontrols );
}

上面就是拖动和旋转物体时控制器的动作 SELECTED 就是一个物体
页面还有onDocumentMouseDown 鼠标点击事件,如果在鼠标点击事件中这样写:

    if ( intersects.length > 0 ) {
        controls.enabled = false;
        SELECTED= objects[item]
        tfcontrols.attach( SELECTED );
        scene.add( tfcontrols );
        //改变鼠标的样式
        container.style.cursor = 'move';
    }

这样就不会报错,但是只能拖动物体的位置 求赐教~~

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

瀞厅☆埖开 2022-09-11 14:32:05

找到问题~ 鼠标弹起时间中将SELECTED=null 所以报错了

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文