之前发的小游戏滚蛋躲方块中,用它来判断球体与立方体是否发生了碰撞.

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有向包围盒与球体碰撞的算法的更多相关文章

  1. 碰撞回避算法(一) Velocity Obstacle

    碰撞回避是机器人导航,游戏AI等领域的基础课题.几十年来,有很多算法被提出.注意这里主要指的是局部的碰撞回避算法.尽管和全局的路径规划算法(A*算法等)有千丝万缕的联系.可是还是有所不同的(局部的碰撞 ...

  2. 3D空间中射线与轴向包围盒AABB的交叉检测算法【转】

    引言 在上一节中,我讲述了如何实现射线与三角形的交叉检测算法.但是,我们应该知道,在游戏开发中,一个模型有很多的三角形构成,如果要对所有的物体,所有的三角形进行这种检测,就算现在的计算机运算能力,也是 ...

  3. 3D空间中射线与轴向包围盒AABB的交叉检测算法 【转】

    http://blog.csdn.net/i_dovelemon/article/details/38342739 引言 在上一节中,我讲述了如何实现射线与三角形的交叉检测算法. 但是,我们应该知道, ...

  4. 游戏碰撞OBB算法(java代码)

    业务需求      游戏2D型号有圆形和矩形,推断说白了就是碰撞检测 :      1.圆形跟圆形是否有相交      2.圆形跟矩形是否相交       3.矩形和矩形是否相交           ...

  5. 【Unity 3D】学习笔记三十七:物理引擎——碰撞与休眠

    碰撞与休眠 上一篇笔记说过,当给予游戏对象刚体这个组件以后,那么这个组件将存在碰撞的可能性.一旦刚体開始运动,那么系统方法便会监视刚体的碰撞状态.一般刚体的碰撞分为三种:进入碰撞,碰撞中,和碰撞结束. ...

  6. 数百个 HTML5 例子学习 HT 图形组件 – WebGL 3D 篇

    <数百个 HTML5 例子学习 HT 图形组件 – 拓扑图篇>一文让读者了解了 HT的 2D 拓扑图组件使用,本文将对 HT 的 3D 功能做个综合性的介绍,以便初学者可快速上手使用 HT ...

  7. 【翻译】西川善司的「实验做出的游戏图形」「GUILTY GEAR Xrd -SIGN-」中实现的「纯卡通动画的实时3D图形」的秘密,后篇

    http://www.4gamer.net/games/216/G021678/20140714079/     连载第2回的本回,  Arc System Works开发的格斗游戏「GUILTY G ...

  8. 利用Flare3D和Stage3D创建3D

    Flare3D 是一款功能强大的引擎,它使得 Flash 中的 3D 内容管理变得更为简便. 它的设计宗旨是提供一个完美的开发工作流程,以便你能够获得事半功倍的效果. 本教程侧重讨论在 Flash 中 ...

  9. 【Unity 3D 游戏开发】Unity3D 入门 - 工作区域介绍 与 入门示例

    一. 工作区域详解 1. Scence视图 (场景设计面板) scence视图简介 : 展示创建的游戏对象, 可以对所有的游戏对象进行 移动, 操作 和 放置; -- 示例 : 创建一个球体, 控制摄 ...

随机推荐

  1. 12:输出1到n位最大整数

    如果按照最简单的循环输出,会遇到边界问题,n非常大的话,int甚至long都不能满足需求,所以这里需要用数组或者是字符串来表示要输出的数字. 如果面试题给定了一个n位整数,那么就是大数问题,用字符串来 ...

  2. List元素为泛型时的注意事项

    最近的项目赶得非常紧,这节奏跟最近的天气一点也不搭调. 编码的过程,遇到一个关于List的小问题. 在调用List.add(E e)的时候范了一个小毛病,很自然地认为list中存储的是 E  对象的另 ...

  3. [转]kali中eth0网卡突然消失解决方案

    前言 不知道怎么kali的eth0网卡突然消失了.这可有点难受啊.在网上查找了一番找到了解决办法,特此记录. 问题   怎么办? 解决办法 首先使用ifconfig -a命令查看所有的网卡接口  发现 ...

  4. JAVA 9 新特性

     Oracle已将JAVA 9的开发提上日程.OpenJDK上已经出现了关于下一个主版本JAVA 9的改进建议(JEP).与以往不同,Oracle在这次谈及了一些真正的特性.而早期对于JDK9的声明仅 ...

  5. [leetcode tree]103. Binary Tree Zigzag Level Order Traversal

    Given a binary tree, return the zigzag level order traversal of its nodes' values. (ie, from left to ...

  6. PHP 笔记——面向对象编程知识点

    类是属性和方法的集合,是面向对象编程方式的核心和基础,通过类可以将零散的用于实现某项功能的代码进行有效管理. 类是由class关键字.类名和成员组成的,类名不区分大小写. 在类中定义常量使用关键字 c ...

  7. BZOJ2673 [Wf2011]Chips Challenge 费用流 zkw费用流 网络流

    https://darkbzoj.cf/problem/2673 有一个芯片,芯片上有N*N(1≤N≤40)个插槽,可以在里面装零件. 有些插槽不能装零件,有些插槽必须装零件,剩下的插槽随意. 要求装 ...

  8. PHP session用redis存储

    redis的官方github这么说: phpredis can be used to store PHP sessions. To do this, configure session.save_ha ...

  9. hdu 4858 水题

    题意:我们建造了一个大项目!这个项目有n个节点,用很多边连接起来,并且这个项目是连通的!两个节点间可能有多条边,不过一条边的两端必然是不同的节点.每个节点都有一个能量值.现在我们要编写一个项目管理软件 ...

  10. 【BZOJ-1194】潘多拉的盒子 拓扑排序 + DP

    1194: [HNOI2006]潘多拉的盒子 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 456  Solved: 215[Submit][Stat ...