- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我有一个由6个曲面定义的3d封闭体积,每个曲面都有4个顶点。
因此,我想检查给定点是在体积内还是在体积外。我想到的解决方案是:
But I don't know how to check this feature of locating if it is on the surface
or not. Can someone please suggest how can I do it.
P.S. One way of doing this was extending ray casting to 3d but that involves
comparison of slopes to check the orientation. So how can I check orientation
of 3 points in 3d space. I have 4 vertices which make up that face, I know the
point under consideration. How can I check if this point lies clockwise or
counter clockwise to the surface.
最佳答案
要考虑您的问题,我们首先必须考虑内部或外部的含义。在具有四个实体的曲面的情况下,每个曲面都将空间精确地划分为两个侧面,通常,四个曲面将空间划分为9个区域,其中只有一个是有界的,从而界定了四面体(但是如果我们仔细选择曲面,我们可以甚至没有边界区域-例如,使其中两个平行)。因此,通常必须确定飞机的哪一侧标记内部或外部(嗯,也没关系,因为在外部与不在内部相同)。
面对更多的面孔,问题会变得复杂(并进一步复杂化),因为您可能有几个也定义了实体的有界区域,因此您需要更多的信息来仅用平面对其进行界定。如果该区域产生非凸形区域,则问题甚至更加复杂,因为您的点可能在区域的某些部分中,与某些平面的一侧匹配,而对于另一些平面则在错误的一侧,并且继续位于实体内部。只是看到这样的定界多边形
以及制作边界区域的可能性
您需要做的第一件事是充分定义实体,用边划定面,并在某种程度上建立界定一个面的边和顶点,以及面如何相互连接以形成您的实体。
遇到这种情况后,您将拥有一组脸部,并且每个脸部的 vector 都指向外部(以连续的方式进行,因此您不会以正常的脸部朝上,而下一个脸部朝下而结束)。接下来需要做的是将实体分成凸形实体。可以证明,对于由平面构成的3d实体,可以将其细分为有限的凸实体集。
我将尝试说明2D中的相同问题,但本质上在3D中是相同的:
首先,我们有初始的poligon,让我们假设它是凸的(为此,这是一个重要的属性,我将在后面提到):
假设它是一个3D小行星,而您正在有人在其表面行走。如果您开始走路,您将穿过黄色的所有线条。这些是法线,因此您需要从每个面中知道哪些面是可到达的,并像我所做的那样构造这些面的法线图。当您在小行星上行走时,您会标记法线以知道小行星内部的位置,并对其进行界定。现在,我们有了小行星与所有法线的 map 。让我们在我们下方绘制一个半空间(在我们下方的表面的一侧)。在几何中,这可以用一个平面表示(一个平面具有其所有点都正交于 vector 的属性,因此X*V=0
其中*
表示点乘积。如果我们将多边形的中心点和法线 vector 作为图形中的黄色 vector ,则将得到(X - P)*N = 0
,其中X
是平面中点的位置,P
是我们的位置(面的中心),并且N
是垂直于平面的 vector ,指向上方(指向小行星的外部)
好的,此等式具有的性质是,如果用空间中的任何位置替换X
,则平面下方的所有点X
都具有值(X - P)*N < 0
,而所有天空值均具有> 0
。
如果对四个法线执行相同的操作,则可以达到以下目的:
...
处理
并且只有当四个平面给出X
时,才会将问题点(X - X_face)*(N_face) < 0
埋入小行星,现在X_face
是脸的中心,而N_face
是指向我们小行星向外的法线。如果满足以下四个条件,则该点将位于小行星内,仅位于内。
但是,如果小行星不是凸面会发生什么呢?
如果您绘制法线,这将无济于事……因为小行星内部存在点且某些测试未通过(请记住,该点必须位于所有曲面之下,但并非必须如此(如下所示) :
问题在于多边形(或多面体)不是凸的,我们不能在那里应用算法。因此,首先我们必须解决使其凸出的问题。
如果您在穿越边缘时开始跟随小行星的所有表面(保持法线),则将到达另一个增加或减少坡度的平面,因此,如果增加坡度,则将标记该边缘(在我们的顶点多边形)(异常标记为红色),如果其减少,则将其标记为正常(标记为绿色):
当所有边缘都正常时,没问题,因为我们的小行星将是凸形的,但是当它们中的任何一个异常时,我们都必须在该平面上继续(在所有平面上挖掘小行星),直到到达另一个表面(延长飞机以划分我们的政策),如下所示:
由于我们的边数量有限,并且只有其中一些被标记为异常,因此此过程一定要完成(请记住,您可以让另一面尝试查找多面体(多边形)的面(面)具有顶点向上和顶点向下(就我们之前解释的意义而言))
因此,您已将多面体分为有限的一组凸多面体,可以应用第一种算法。
关于c++ - 指向3d封闭体积内,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38214038/
从the documentation, 13.5.5: When the last parameter of a method is a closure, you can place the clos
Bjarne Stroustrup 写道: “友元类必须事先在封闭范围内声明或在非类范围内定义,立即封闭声明它为友元的类” 语句的第一部分不是多余的,因为“立即包含类的非类范围”包括“先前在封闭范围中
我有一个网格(如下例),其中包含外墙(标记为 W)、环境 block (E)、开放空间 (o) 和事件点 (A)。目前,此网格存储在 [,] 中,其中包含与给定点关联的所有数据。我试图确定是否包含一个
我正在尝试使用 this blogpost's approach to higher-kinded data without dangling Identity functors for the tr
在下面的代码中: package main import ( "fmt" "time" ) func asChan(vs ...int) <-chan int { c := m
我在传递和评估闭包列表时遇到困难。经过大量简化,该程序显示出与我正在尝试编写的程序相同的错误: use std::vec::flat_map; #[main] fn main() { let li
我正在努力成为一名好公民,并尽可能远离全局范围。有没有办法访问不在全局范围内的 setTimeout 变量? 因此,在此示例中,某人将如何取消“计时器”? myObject.timedAction =
考虑这个例子: def A(): b = 1 def B(): # I can access 'b' from here. print(b)
val listPlans: List = newPlans.mapTry { it.data.map { Plan(it.id, it.nam
我目前正在尝试使用SinonJS对我的 angular.service 进行单元测试,但是遇到了一个问题,希望有人可以阐明为什么会发生这种情况。我已经重构了当前的项目以说明当前的问题。 我还提供了DE
我正在使用 Go channel ,我想知道关闭 channel 和将其设置为 nil 之间有什么区别? 编辑: 在此example ,我想通过关闭 channel 或设置为零来断开发送者和接收者的连
我的应用程序有一个奇怪的行为,我不知道它来自哪里。我已经为 TextView 内容实现了 NSScanner,效果非常好。扫描器与文本存储结合使用,通过 TextView 委托(delegate)方法
我不知道如何让 MyBatis 生成封闭的 or 语句: WHERE x.token = ? AND ( (x.scene = 'A' OR x.scene = 'B')) 这是一个令人惊讶的简单
我不希望这是一个摄像头检测程序。这是一个程序,可以检测应用程序屏幕上颜色的传递。 我想要做的是检测大于 5x5 像素的黑色何时穿过屏幕上定义的空间区域。我想过用一个大区域来拉伸(stretch)整个宽
我一直在使用 RDFLib 来解析数据并将其插入到三元组中。我遇到的一个常见问题是,从关联数据存储库解析时,没有尖括号括起 URL。 要上传数据,我必须手动添加 并使用 URIRef重新创建 URL。
我已经阅读了很多有关此问题的帖子,但我仍然不确定我是否完全理解这些定义。 以下是我认为不同术语的示例。我是否走在正确的轨道上,或者我仍然不理解这些概念。谢谢 Array - unbound and o
我为我的 Android 应用设置了 GooglePlay 内部和封闭式 Alpha 测试设置。 它非常适合允许测试人员加入计划并安装应用程序,但是当我从测试人员电子邮件列表中删除测试人员时,他们仍然
我是一名优秀的程序员,十分优秀!