3D有向包围盒与球体碰撞的算法
之前发的小游戏滚蛋躲方块中,用它来判断球体与立方体是否发生了碰撞.
http://www.cnblogs.com/WhyEngine/p/3350012.html
现在发布下该算法:
有向包围盒OBB,是有旋转变化的包围盒,由三种数据组成:
obbCenter表示包围盒的中心位置
obbAxes[3]表示包围盒XYZ三个坐标轴方向上的朝向,应该是正交的,否则意思着立方体有扭曲变形.并且应该是单位向量.
halfExtents表示包围盒三个方向上的长度.
该算法是多年前,已经不记得从什么地方找的了,自己又做了点修改.该代码其实可以更加简化一些,因为原代码中是可以计算球与包围盒的碰撞深度与碰撞的法线方向的.而这里只需要返回TRUE或FALSE即可.
算法的原理比较容易理解:判断球心到包围盒三个坐标轴的投影距离是否小于该轴的长度加上球的半径.如果三个轴都符合,则表示有碰撞.
该算法的基础是判断空间中一点是否在包围盒内部.
bool ObbSphereCollisionDetect(const Vector3& obbCenter,
const Vector3 obbAxes[],
const Vector3& halfExtents,
const Vector3& sphereCenter,
float sphereRadius)
{
Vector3 kDiff = sphereCenter - obbCenter; float fSide[] = { 1.0f, 1.0f, 1.0f };
float fS[] = { 0.0f, 0.0f, 0.0f };
float fD = 0.0f; if (D3DXVec3Dot(&kDiff, &obbAxes[]) < 0.0f)
{
fS[] = D3DXVec3Dot(&( sphereCenter - ( obbCenter - ( obbAxes[] * halfExtents.x ) ) ), &obbAxes[]); if (fS[] <= -sphereRadius)
return false; else if (fS[] < 0.0f)
fD += fS[] * fS[]; fS[] += sphereRadius;
}
else
{
fS[] = D3DXVec3Dot(&( ( obbCenter + ( obbAxes[] * halfExtents.x ) ) - sphereCenter ), &obbAxes[]); if (fS[] <= -sphereRadius)
return false; else if (fS[] < 0.0f)
fD += fS[] * fS[]; fS[] += sphereRadius;
fSide[] = -1.0f;
} if (D3DXVec3Dot(&kDiff, &obbAxes[]) < 0.0f)
{
fS[] = D3DXVec3Dot(&( sphereCenter - ( obbCenter - ( obbAxes[] * halfExtents.y ) ) ), &obbAxes[]); if (fS[] <= -sphereRadius)
return false; else if (fS[] < 0.0f)
fD += fS[] * fS[]; fS[] += sphereRadius;
}
else
{
fS[] = D3DXVec3Dot(&( ( obbCenter + ( obbAxes[] * halfExtents.y ) ) - sphereCenter ), &obbAxes[]); if (fS[] <= -sphereRadius)
return false; else if (fS[] < 0.0f)
fD += fS[] * fS[]; fS[] += sphereRadius;
fSide[] = -1.0f;
} if (D3DXVec3Dot(&kDiff, &obbAxes[]) < 0.0f)
{
fS[] = D3DXVec3Dot(&( sphereCenter - ( obbCenter - ( obbAxes[] * halfExtents.z ) ) ), &obbAxes[]); if (fS[] <= -sphereRadius)
return false; else if (fS[] < 0.0f)
fD += fS[] * fS[]; fS[] += sphereRadius;
}
else
{
fS[] = D3DXVec3Dot(&( ( obbCenter + ( obbAxes[] * halfExtents.z ) ) - sphereCenter ), &obbAxes[]); if (fS[] <= -sphereRadius)
return false; else if (fS[] < 0.0f)
fD += fS[] * fS[]; fS[] += sphereRadius;
fSide[] = -1.0f;
} return (fD <= ( sphereRadius * sphereRadius ));
}
3D有向包围盒与球体碰撞的算法的更多相关文章
- 碰撞回避算法(一) Velocity Obstacle
碰撞回避是机器人导航,游戏AI等领域的基础课题.几十年来,有很多算法被提出.注意这里主要指的是局部的碰撞回避算法.尽管和全局的路径规划算法(A*算法等)有千丝万缕的联系.可是还是有所不同的(局部的碰撞 ...
- 3D空间中射线与轴向包围盒AABB的交叉检测算法【转】
引言 在上一节中,我讲述了如何实现射线与三角形的交叉检测算法.但是,我们应该知道,在游戏开发中,一个模型有很多的三角形构成,如果要对所有的物体,所有的三角形进行这种检测,就算现在的计算机运算能力,也是 ...
- 3D空间中射线与轴向包围盒AABB的交叉检测算法 【转】
http://blog.csdn.net/i_dovelemon/article/details/38342739 引言 在上一节中,我讲述了如何实现射线与三角形的交叉检测算法. 但是,我们应该知道, ...
- 游戏碰撞OBB算法(java代码)
业务需求 游戏2D型号有圆形和矩形,推断说白了就是碰撞检测 : 1.圆形跟圆形是否有相交 2.圆形跟矩形是否相交 3.矩形和矩形是否相交 ...
- 【Unity 3D】学习笔记三十七:物理引擎——碰撞与休眠
碰撞与休眠 上一篇笔记说过,当给予游戏对象刚体这个组件以后,那么这个组件将存在碰撞的可能性.一旦刚体開始运动,那么系统方法便会监视刚体的碰撞状态.一般刚体的碰撞分为三种:进入碰撞,碰撞中,和碰撞结束. ...
- 数百个 HTML5 例子学习 HT 图形组件 – WebGL 3D 篇
<数百个 HTML5 例子学习 HT 图形组件 – 拓扑图篇>一文让读者了解了 HT的 2D 拓扑图组件使用,本文将对 HT 的 3D 功能做个综合性的介绍,以便初学者可快速上手使用 HT ...
- 【翻译】西川善司的「实验做出的游戏图形」「GUILTY GEAR Xrd -SIGN-」中实现的「纯卡通动画的实时3D图形」的秘密,后篇
http://www.4gamer.net/games/216/G021678/20140714079/ 连载第2回的本回, Arc System Works开发的格斗游戏「GUILTY G ...
- 利用Flare3D和Stage3D创建3D
Flare3D 是一款功能强大的引擎,它使得 Flash 中的 3D 内容管理变得更为简便. 它的设计宗旨是提供一个完美的开发工作流程,以便你能够获得事半功倍的效果. 本教程侧重讨论在 Flash 中 ...
- 【Unity 3D 游戏开发】Unity3D 入门 - 工作区域介绍 与 入门示例
一. 工作区域详解 1. Scence视图 (场景设计面板) scence视图简介 : 展示创建的游戏对象, 可以对所有的游戏对象进行 移动, 操作 和 放置; -- 示例 : 创建一个球体, 控制摄 ...
随机推荐
- Data时间格式化
//时间戳转时间 function timeStamp2String(time) { var datetime = new Date(); datetime.setTime(time); var ye ...
- hdoj2037 今年暑假不AC(贪心)
题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=2037 思路 想要看的节目尽可能的多,则首先要将节目按照结束时间从早到晚排序,因为一个节目越早结束,留给 ...
- Java反射机制的缺点
来自官方指南(Tutorial):http://docs.oracle.com/javase/tutorial/reflect/index.html 反射的用途 Uses of ReflectionR ...
- 用Python开始机器学习(3:数据拟合与广义线性回归)
机器学习中的预测问题通常分为2类:回归与分类. 简单的说回归就是预测数值,而分类是给数据打上标签归类. 本文讲述如何用Python进行基本的数据拟合,以及如何对拟合结果的误差进行分析. 本例中使用一个 ...
- windows下thrift的使用(python)
1.下载thrift,下载地址:http://archive.apache.org/dist/thrift/0.9.3/ 2.在编写python的thrift代码时,需要先安装thrift modul ...
- Power OJ 2605 SPFA+dp思想
题目链接[https://www.oj.swust.edu.cn/problem/show/2605] 题意:给出包含N(N <= 5000)个点M条边的有向图,然后求1 - N在满足距离小于T ...
- 为什么Android手机总是越用越慢?
根据第三方的调研数据显示,有77%的Android手机用户承认自己曾遭遇过手机变慢的影响,百度搜索“Android+卡慢”,也有超过460万条结果.在业内,Android手机一直有着“越用越慢”的口碑 ...
- [JOISC2014]歴史の研究/[BZOJ4241]历史研究
[JOISC2014]歴史の研究/[BZOJ4241]历史研究 题目大意: 一个长度为\(n(n\le10^5)\)的数列\(A(A_i\le10^9)\),定义一个元素对一个区间\([l,r]\)的 ...
- hdu 4540 dp
题意: 假设: 1.每一个时刻我们只能打一只地鼠,并且打完以后该时刻出现的所有地鼠都会立刻消失: 2.老鼠出现的位置在一条直线上,如果上一个时刻我们在x1位置打地鼠,下一个时刻我们在x2位置打地鼠,那 ...
- java集合之二(collection架构)
转载请注明出处:http://www.cnblogs.com/skywang12345/p/3308513.html 首先,我们对Collection进行说明.下面先看看Collection的一些框架 ...