- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我使用 XCode 关卡编辑器设置了一个非常简单的场景。
如您所见,其中一个 1x5 长方体已旋转 90º。这是通过在节点检查器中将 Euler Angles 属性的 y 属性设置为 90 来实现的。
但请注意,边界框不考虑长方体的旋转。当我遍历场景中的 SCNNode 时也是如此。两个长方体具有相同的边界体积
for wall:SCNNode in walls.childNodes {
var v1 = SCNVector3Zero
var v2 = SCNVector3Zero
wall.getBoundingBoxMin(&v1, max:&v2)
print(v1, v2)
}
// Prints
// SCNVector3(x: -0.5, y: 0.0, z: -2.5) SCNVector3(x: 0.5, y: 0.5, z: 2.5)
// SCNVector3(x: -0.5, y: 0.0, z: -2.5) SCNVector3(x: 0.5, y: 0.5, z: 2.5)
因此边界体积似乎是使用子节点自己的坐标系计算的,而不是节点父节点(或场景)的坐标系。这让我想知道;如何计算场景中的 SCNNodes 包围体?
查看 SCNNode 的文档,似乎所有信息都在那里。我可以阅读 eulerAngles
,它可以让我正确地绕 y 轴旋转。我可以读取 transform
属性。
我以为我可以将向量乘以节点变换矩阵,但变换矩阵 (4x4) 和边界框向量 (1x3) 似乎不兼容。 SceneKit 似乎也没有提供任何将变换矩阵应用于向量的方法。但是,我不太擅长几何,所以我可能会遗漏一些明显的东西。
最佳答案
一些想法:
在 Interface Builder 中,如您的屏幕截图所示,有一个 Editing space 属性,您可以将其设置为 World(而不是 Local)
在代码中,您可以使用临时节点来计算边界框。确保只有一个子节点(您要计算其边界框的节点),在该子节点上应用任何变换,然后他们向父节点询问其边界框。来自文档:
The bounding volume of a node containing child nodes is the minimal volume that encloses the bounding volumes of the node’s children.
-convertPosition:toNode:
之类的工具来计算另一个坐标系中的边界框关于swift - 通过旋转获取 SCNNode 的边界体积,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34831701/
我正在尝试让这段代码计算盒子的表面积和体积。它编译但不输出正确的数据。我认为问题可能出在 void Box::零件内,但碰壁了。或者它可能是 Height = Height 但我无法以任何其他方式让它
我需要一个使用 kinect 计算 body 体积(以立方米为单位)的算法。我知道我可以提取云和深度框架(通过使用骨架 NUI 的一些方法隔离 body )但我不知道如何从这个矩阵计算体积值。导出卷
我是 d3 的新手,并试图根据节点之间的连接数使链接的宽度动态化。比方说,我们有: "links": [ { "source": a, "target": b},
我要渲染 3D 数据,它是一个一维数组。此数据在将进行可视化的同一程序中预先计算。数据表示统一的 3D 网格。网格的每个单元格都由一个 vector 组成。 GridSize = dx * dy *
我尝试在 jupyter notebook 中使用 mayavi 渲染体积来测试下面的示例 from mayavi import mlab mlab.init_notebook() x, y, z =
我尝试了几种不同的方法。我需要使用继承来扩展这些类。每次我运行该程序时,它都会输出 0.0 的体积和面积。半径显示正确。输出在底部。 public class Base_HW04Q1 { pu
我参与了一个项目,我需要根据体积的一系列图像渲染 3D 体积。这些图像是通过多种技术创建的,因此它们是所讨论对象的垂直切片。 数据集类似于this question , 但提问者正在寻找 Matlab
已关闭。此问题旨在寻求有关书籍、工具、软件库等的建议。不符合Stack Overflow guidelines准则。它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,
我想知道是否有任何基于 numpy 的工具可以: 给定一个二值输入的 3D numpy 图像,找到它的凸包; 并返回索引列表或此 3D 凸包内的体素(3D 像素)的类似物。 一种可能是使用skimag
我要使用 Matlab 从灰度图像集创建一个 3D 体积。一组包含二维灰度图像的连续量化切片。我仍然认为自己是 Matlab 的菜鸟,但这是我目前的想法: 为 3D 体积创建一个空白空间。 在每张图片
我有一个 3D 体积和一个 2D 图像以及两者之间的近似映射(没有倾斜的仿射变换,已知缩放,旋转和平移近似已知并且需要拟合)。因为这个映射有错误,我想进一步将 2D 图像注册到 3D 体积。我以前没有
更新: 我创建了一个文档齐全的 ipython 笔记本。如果您只想要代码,请查看第一个答案。 问题 我有一个 40x40x40 体积的灰度值。这需要旋转/移动/剪切。 这是一组有用的齐次变换:http
看似简单的问题,没有图像处理/处理经验的人其实没那么容易。 我不只是想将 2D 阵列堆叠在一起,而是通过合并多个由空白分隔的二进制 2D 切片来创建 3D 体积。 例子: 用零定义一个 3D 矩阵:
我非常沮丧,因为几个小时后,我似乎无法在 python 中进行看似简单的 3D 插值。在 Matlab 中,我所要做的就是 Vi = interp3(x,y,z,V,xi,yi,zi) 使用 scip
我是一名优秀的程序员,十分优秀!