- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我做了一些研究,但找不到最有效的答案,盒对撞机 2D 还是圆形对撞机 2D?
有this question很快就得到了一个很好的答案,其中说最快的是球体对撞机,其次是胶囊对撞机,然后是盒子对撞机,但我想知道 2D 对撞机。
2500 Colliders
Capsule 453-481ms
Box 490-520ms
Sphere 190-233ms
最佳答案
可以在严格的数学基础上比较不同 2D 对撞机之间的性能差异;通过确定确定点 (P) 是否在特定形状内所需的步骤,可以掌握其成本的相对概念:
圆形碰撞器:非常简单的计算;只需将圆心和 P 之间的距离与圆的半径进行比较。如果距离 < 半径,则该点在圆内。 (如果我们假设它们正在比较距离 2 < 半径 2,则计算起来更便宜,因为这避免了一些代价高昂的平方根运算。)
盒子碰撞器:也相当简单,只需一点线性代数; as per this solution ,您需要计算并比较矩形顶点和点 P 之间的 2 对点积。(这背后的理论是 P 应该与矩形的所有顶点在内部形成锐角 - 如果不是,那就是外面。)这不是很昂贵,因为计算点积只是一点乘法和加法。然而,相对于圆形碰撞器,它仍然需要更多的步骤并且会更慢。
多边形对撞机 :确定一个点是否在多边形内是事情会变得非常慢的地方。因为Unity的多边形碰撞器可以是凹面的,一个简化的方法比如determining which side of each edge P lies on不会工作。
潜在凹多边形的一种方法是 perform a raycast that passes from outside of the polygon to P ,并计算它穿过的边数 - 如果它是奇数,则 P 在多边形内。 (我以前在 3D 中实现过一次,但我不确定是否有更快的方法。)还有其他方法,但它们都比前两个碰撞检测慢;它们都需要将 P 与多边形的每个边或顶点进行比较,并且需要多步乘法、加法,有时甚至是除法(慢!),以便确定 P 是否在多边形内。
边缘对撞机 :使用这个碰撞器,基于点的碰撞类比并不真正起作用。想象它的最简单方法是在它的每对顶点之间转换一条射线,以检查它们是否与任何碰撞器形状相交。这与其他对撞机有点像苹果对橘子的比较,因为对撞机的顶点没有形成封闭的形状 - 对撞机没有“内部”。因此,此对撞机的用例将受到限制(并且似乎不适用于您在这里想要的)。有趣的是,this collider performs better than a polygon collider和 trades blows with the box collider ,但同样,这些只是特定用例(如静态地形/障碍物)中的有效比较。
希望这会有所帮助 - 我没有在大多数方法背后包含任何实现细节或数学理论,但是如果您想进一步阅读它们,我会尽可能包含链接。正如我在评论中所指出的,使用最适合您正在使用的对象的对撞机 - 毕竟,圆形对撞机可能比盒子对撞机便宜,但它在物理交互中的表现也非常不同。
如果您将模拟扩展到这些单独的交互不再相关并且严格来说碰撞检测很重要的程度,那么您可能希望切换到更高效的碰撞器。当然,您最了解自己的项目,这取决于您。
关于unity3d - Circle Collider 2D 或 Box Collider 2D,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42011693/
我把圆圈旋转了180度,我怎样才能让内圈粘在上面(不旋转它) 最佳答案 试试这个代码。我创建了我的 HTML 代码。您的类(class)只需更改即可。 CSS: .outer-circle{
我正在制作一个圆圈到圆圈的碰撞检测程序。我可以让球四处移动,但是当检测到碰撞时,球重叠得很远。有什么建议么?提前致谢! import javax.swing.*; import java.awt.*;
这是圆类: public class Circle { private double radius; private double x; private double y; }
我正在制作一个 HTML Canvas 演示,以了解有关圆到圆碰撞检测和响应的更多信息。我相信检测代码是正确的,但响应数学并不完全正确。 该演示是使用 TypeScript 实现的,它是 JavaSc
所以我想在 CSS 中找出一个反圆/切出的圆。目前我找到 this answer 由 ScottS . 他的代码非常适合我,现在我正在寻找相同的效果,但在 的另一边元素。因此,我需要在右侧切出而不是
我目前正尝试在 C++ 中创建一个 Circle 类,但是当我编译时,我收到一条错误消息,提示“重载的‘Circle’调用不明确。我是 C++ 的新手,不确定这意味着什么。我一直在使用在这里可以找到一
在我的 wip 游戏中,我必须实现 Circle-Circle 碰撞。为了实现这一点,我只需计算它们的中心 (x1-x2)² + (y1-y2)² 之间的平方距离。如果它小于它们的平方半径 (r1+r
我必须画一个倒数计时器圆圈,我正在使用 this open source图书馆。要求是圆圈充满绿色并在 x 秒内消失。我已经给回圆圈绿色并在其上画了一个白色圆圈,绿色圆圈看起来正在消失。 self.c
我有一个 UIView,我将其背景设为圆形: self.colourView.layer.cornerRadius = 350 self.colourView.clipsToBounds = tr
引用: http://tympanus.net/Development/IconHoverEffects/#set-7 当您滑过上面链接中的任何圆圈图标时,它会以曲线形式淡化(我相信这是弹出的圆圈后面
我想创建一个形状,我将其描述为“反圆”: 图片有点不准确,因为黑线应该沿着 div 元素的外边界继续。 这是我目前拥有的演示:http://jsfiddle.net/n9fTF/ 没有图像的 CSS
我可以将文本添加到我的草图中,但如果我可以将文本直接附加到圆圈上,我会希望它。这意味着如果一个圆圈被另一个圆圈覆盖,文本也会被覆盖。在更高的层面上不是,我发现 d3 模型很难以某种方式构造对象,使它们
我正在展示用 Python 的 Turtle 模块绘制的孙子图案,他要求看同心圆。我认为使用 turtle 的 circle() 会更快画他们而不是编写自己的代码来生成圆。哈!我被困住了。我看到所产生
我正在创建一个使用 map 的网络应用程序。在 map 上我正在创建圆圈并希望在 div 中显示半径。通过覆盖完成事件完成半径后,我能够显示半径。但我想在创建圆时显示 div 中的半径,以允许用户以自
编辑:我可以用半径除以 Angular 吗? 问题:为了学习 HTML5 Canvas 中的碰撞艺术,我目前正在尝试让整圆与分段圆(在本例中为半圆)发生碰撞。 我尝试过的:我的第一个想法是一个简单的圆
我发现了其他标题相似的话题,但在这些话题中找不到适合我的解决方案。 我试图通过将相等的宽度/高度与 border-radius:50% 相结合来生成完美圆形的输入标签,但边缘出现像素化。我已经为宽度/
我使用 Google Maps V3 API 创建了一个圆,还尝试制作了一个具有相同半径的标记圆。 问题:我创建的是倾斜的,而谷歌地图创建的是一个漂亮的圆圈。出了什么问题? Google map V3
这是我一直在处理的图像 目标是检测大圆圈内的小圆圈。 目前我所做的是将图像转换为灰度并应用阈值(cv2.THRESH_OTSU),从而产生此图像 在此之后,我使用我在stackoverflow上找到的
我正在尝试绘制一张图片,并且绘制了一个矩形,然后我想绘制一个弧形元素,但是这个元素必须是精确的,并且它只是矩形之外的圆的一部分形状。因此,我尝试使用 Arc patch 来创建相同的东西,但形状不匹配
我必须检测 javaFX 程序中两个“球”何时发生碰撞。每次单击按钮时,都会将一个新球添加到 Pane 中。我知道 getChildren() 返回一个可观察列表,其中包含每个球的节点,当我打印带有两
我是一名优秀的程序员,十分优秀!