Autodesk Forge Viewer 中的三个 JS Limit Transform Control 运动
ThreeJS Limit TransformControl movement in Autodesk Forge Viewer
我有一个来自 ThreeJS 的 TransformControl 附加到 Forge Viewer 场景中的自定义网格。我使用自定义网格的位置来修改自定义立方体的大小。如果 Control 的移动导致立方体的大小缩小到最小大小以下,我想停止 TransformControl 的移动。
流量为:
1 - 用户拖动控件
2 - 获取附加网格的位置并确定尺寸变化量。
3 - 如果数量导致尺寸低于最小值,将尺寸设置为最小值,将控件和附加网格的位置设置为会导致尺寸最小的位置,并且无法拖动控件进一步。用户可以一直按住控件,如果用户将控件拖动到不会导致尺寸最小的位置,则控件可以再次移动,尺寸发生变化。
不幸的是,在 Forge Viewer (R71) 使用的 three.js 版本中,TransformControls
class 似乎没有提供任何方式来连接到翻译更新: https://github.com/mrdoob/three.js/blob/r71/examples/js/controls/TransformControls.js#L812-L853。如果你想根据一些自定义条件来控制逻辑,你可能不得不以某种方式破解它,例如,通过覆盖 onPointerMove
方法,如果 [=12= 的长度]向量低于特定阈值。
我有一个来自 ThreeJS 的 TransformControl 附加到 Forge Viewer 场景中的自定义网格。我使用自定义网格的位置来修改自定义立方体的大小。如果 Control 的移动导致立方体的大小缩小到最小大小以下,我想停止 TransformControl 的移动。
流量为:
1 - 用户拖动控件
2 - 获取附加网格的位置并确定尺寸变化量。
3 - 如果数量导致尺寸低于最小值,将尺寸设置为最小值,将控件和附加网格的位置设置为会导致尺寸最小的位置,并且无法拖动控件进一步。用户可以一直按住控件,如果用户将控件拖动到不会导致尺寸最小的位置,则控件可以再次移动,尺寸发生变化。
不幸的是,在 Forge Viewer (R71) 使用的 three.js 版本中,TransformControls
class 似乎没有提供任何方式来连接到翻译更新: https://github.com/mrdoob/three.js/blob/r71/examples/js/controls/TransformControls.js#L812-L853。如果你想根据一些自定义条件来控制逻辑,你可能不得不以某种方式破解它,例如,通过覆盖 onPointerMove
方法,如果 [=12= 的长度]向量低于特定阈值。