Autodesk Forge Viewer 中的三个 JS 限制变换控制运动

Posted

技术标签:

【中文标题】Autodesk Forge Viewer 中的三个 JS 限制变换控制运动【英文标题】:ThreeJS Limit TransformControl movement in Autodesk Forge Viewer 【发布时间】:2021-08-02 12:44:58 【问题描述】:

我有一个来自 ThreeJS 的 TransformControl 附加到 Forge 查看器场景中的自定义网格。我使用自定义网格的位置来修改自定义立方体的大小。如果控件的移动导致立方体的大小缩小到最小大小以下,我想停止 TransformControl 的移动。

流程是:

1 - 用户拖动控件

2 - 获取附加网格的位置并确定尺寸变化量。

3 - 如果数量导致尺寸低于最小值,请将尺寸设置为最小值,将控件和附加网格的位置设置为会导致尺寸最小的位置,并且无法进一步拖动控件。用户可以一直按住Control,如果用户将Control拖到不会导致尺寸最小的位置,那么Control可以再次移动,尺寸会发生变化。

【问题讨论】:

【参考方案1】:

不幸的是,在 Forge Viewer (R71) 使用的 three.js 版本中,TransformControls 类似乎没有提供任何方式来挂钩翻译更新:https://github.com/mrdoob/three.js/blob/r71/examples/js/controls/TransformControls.js#L812-L853。如果你想根据一些自定义条件控制逻辑,你可能不得不以某种方式破解它,例如,通过覆盖 onPointerMove 方法,如果 offset 向量的长度低于它,则提前离开它一定的门槛。

【讨论】:

谢谢。我就是这样做的,而且效果很好。

以上是关于Autodesk Forge Viewer 中的三个 JS 限制变换控制运动的主要内容,如果未能解决你的问题,请参考以下文章

Autodesk Forge Viewer 适合查看纵向/横向

Autodesk Forge Viewer 中的三个 JS 限制变换控制运动

将模型从 Autodesk Viewer 加载到 Forge Viewer

如何将 Autodesk 模型衍生 API 元数据中的 objectids 与 Forge Viewer 模型 dbids 匹配?

在 Autodesk Forge Viewer 中对齐坐标系

如何在 Typescript 中更改 Autodesk Forge Viewer 标记扩展中的编辑模式?