我希望有经验的人可以帮助如何从 xyz 数据准备形状文件。在这里可以看到一个为 Churyumov–Gerasimenko 彗星准备好的数据集的一个很好的例子,尽管没有提供前面创建形状文件的步骤。
我试图更好地理解如何将表面应用于给定的一组 XYZ 坐标。使用 R 包“rgl”直接使用笛卡尔坐标,但是环绕的形状似乎更困难。我找到了 R 包geometry
,它提供了QHULL函数的接口。我尝试使用它来计算 Delaunay 三角面,然后我可以在rgl
. 我无法弄清楚与该函数相关的一些选项,delaunayn
以可能控制计算这些方面的最大距离。我希望这里的某个人可能对从 xyz 数据改进表面构造有一些想法。
使用“Stanford bunnny”数据集的示例:
library(onion)
library(rgl)
library(geometry)
data(bunny)
#XYZ point plot
open3d()
points3d(bunny, col=8, size=0.1)
#rgl.snapshot("3d_bunny_points.png")
#Facets following Delaunay triangulation
tc.bunny <- delaunayn(bunny)
open3d()
tetramesh(tc.bunny, bunny, alpha=0.25, col=8)
#rgl.snapshot("3d_bunny_facets.png")
这个答案让我相信 Qhull 的 R 实现可能存在问题。另外,我现在尝试了各种设置(例如delaunayn(bunny, options="Qt")
),但效果不大。此处概述了 Qhull 选项
编辑:
这是球体的另一个(更简单)示例。即使在这里,面的计算也并不总是找到最近的相邻顶点(如果你旋转球,你会看到一些面穿过内部)。
library(rgl)
library(geometry)
set.seed(1)
n <- 10
rho <- 1
theta <- seq(0, 2*pi,, n) # azimuthal coordinate running from 0 to 2*pi
phi <- seq(0, pi,, n) # polar coordinate running from 0 to pi (colatitude)
grd <- expand.grid(theta=theta, phi=phi)
x <- rho * cos(grd$theta) * sin(grd$phi)
y <- rho * sin(grd$theta) * sin(grd$phi)
z <- rho * cos(grd$phi)
set.seed(1)
xyz <- cbind(x,y,z)
tbr = t(surf.tri(xyz, delaunayn(xyz)))
open3d()
rgl.triangles(xyz[tbr,1], xyz[tbr,2], xyz[tbr,3], col = 5, alpha=0.5)
rgl.snapshot("ball.png")