gpt4 book ai didi

javascript - Three.js r68 - 无法使用 OBJMTLLoader 获取几何形状的质心

转载 作者:塔克拉玛干 更新时间:2023-11-02 22:46:52 25 4
gpt4 key购买 nike

我使用 Three.js 的旧版本已经有一段时间了,所以我决定升级到最新版本 (r68)。我知道我会遇到一些问题,但我没想到会删除 geometry.computeCentroids() 和 .centroid 属性。

我正在使用 OBJMTLLoader 库加载模型。这个问题是因为它不再有 .computeCentroids() 方法,我无法获得它们。我尝试使用其他方法计算它们,但无济于事:

我也尝试过使用 .localToWorld(point) 方法,但它们也不起作用。它总是返回 (0,0,0)。

现在,当我点击一个网格时,我正在计算(或尝试计算)它的质心:

 if (mesh.centroid === undefined) {
mesh.centroid = new THREE.Vector3();
mesh.centroid = mesh.geometry.center();
console.log(mesh.centroid); }

每当我向场景(具有子网格)添加新对象时,我也会使用它:

//desperate try to find different values for centroids
object.updateMatrix();
scene.updateMatrix();
object.updateMatrixWorld();
scene.updateMatrixWorld();

更奇怪的是,我尝试计算的质心并不一致。它总是在 console.log() 中显示相同的向量,无论我以何种顺序单击网格。

THREE.Vector3 {x: 158.89799999999997, y: -4.115949999999998, z: 67.75310000000002, constructor: function, set: function…}
THREE.Vector3 {x: 0.000005004882780212938, y: 0.16375010757446518, z: 0.0000024658203301441972, constructor: function, set: function…}
THREE.Vector3 {x: -1.7053025658242404e-13, y: -0.0818749484539012, z: 1.1368683772161603e-13, constructor: function, set: function…}

我想知道是否有人对此有类似的问题。我没有尝试过之前的 three.js 版本,因为我真的想升级到最新版本并保持一致。

提前谢谢你。

编辑:忘记提及一个重要细节。我想要世界坐标中的质心。

使用 mrdoob 的方法后,我能够得到质心。我总是为每个网格获得相同的值,因为即使我在每个网格上使用 .calculateBoundingBoxes(),这些边界指的是主要父对象。每个几何体都分配了对象的所有顶点,我假设边界框是根据这些顶点计算的,这就是我为每个几何体获得相同值的原因。

最佳答案

如果你想计算整个几何体的质心,这是你需要的代码:

geometry.computeBoundingBox();

var centroid = new THREE.Vector3();
centroid.addVectors( geometry.boundingBox.min, geometry.boundingBox.max );
centroid.multiplyScalar( - 0.5 );

centroid.applyMatrix4( mesh.matrixWorld );

关于javascript - Three.js r68 - 无法使用 OBJMTLLoader 获取几何形状的质心,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25267003/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com