javascript - 如何使用旋转找出旋转梯形的边界框

标签 javascript math three.js

我正在尝试将两个矩形对象连接在一起,这两个对象都切掉了一个 Angular 。在该操作之后,它们实际上是梯形。

一个对象被旋转了一定的度数,这取决于用户提供的输入。我设法计算出第二个对象需要具有的 Angular ,以便它与主对象的侧面切割对齐。

现在的问题是对象之间仍然存在间隙。我认为最好计算边界框,这样我就知道我需要在 x、y 或 z 方向调整多少位置。

虽然我不知道如何计算这个梯形的边界框。我搜索了 Internet/stack overflow,但没有找到适合我需要的东西。

我掌握的信息是梯形的尺寸和旋转 Angular 。

这是一张图,希望能使我的情况更加清楚:

Drawing of the rotated trapezoid

最佳答案

只是关于如何使用 THREE.Box3() 的概念:

var scene = new THREE.Scene();
var camera = new THREE.PerspectiveCamera(60, window.innerWidth / window.innerHeight, 1, 1000);
camera.position.set(5, 8, 13);
var renderer = new THREE.WebGLRenderer({
  antialias: true
});
renderer.setSize(window.innerWidth, window.innerHeight);
document.body.appendChild(renderer.domElement);

var controls = new THREE.OrbitControls(camera, renderer.domElement);

scene.add(new THREE.GridHelper(10, 10, 0x404040, 0x202020));

//trapezoid
var tPoints = [
  new THREE.Vector2(0, 1),
  new THREE.Vector2(1, 0),
  new THREE.Vector2(5, 0),
  new THREE.Vector2(5, 1)
];

var tGeom = new THREE.ExtrudeGeometry(new THREE.Shape(tPoints), {
  depth: 1,
  bevelEnabled: false
});
tGeom.center();
var tMat = new THREE.MeshBasicMaterial({
  color: "aqua",
  wireframe: true
});
var trapezoid = new THREE.Mesh(tGeom, tMat);
trapezoid.position.set(0, 2.5, 0);
scene.add(trapezoid);

var box3 = new THREE.Box3();
var box3Helper = new THREE.Box3Helper(box3);
scene.add(box3Helper);

renderer.setAnimationLoop(() => {
  trapezoid.rotation.z += 0.01;
  box3.setFromObject(trapezoid);
  renderer.render(scene, camera)
});
body {
  overflow: hidden;
  margin: 0;
}
<script src="https://threejs.org/build/three.min.js"></script>
<script src="https://threejs.org/examples/js/controls/OrbitControls.js"></script>

关于javascript - 如何使用旋转找出旋转梯形的边界框,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58112808/

相关文章:

javascript - JS async/await - 为什么 await 需要异步?

android - 如何从图像计算高度而又不与光源距离

javascript - THREE.js 编辑器 : How to access main script in an example

c# - c#中的奇怪减法

javascript - THREE.js 动态添加点到 Points 几何不渲染

three.js - 如何动态更改 GLTF 模型的纹理?

javascript - 具有 onclick 动画的多个按钮 - 某些按钮未完成 setTimeout

javascript - document.createElement ('img' ) v/s new Image()?哪一个要附加到 DOM?

javascript - 从 Azure DevOps 获取已通过 JavaScript 合并到分支中的所有工作项

c - 计算 PWM 的频率