CN102509317A - 一种实时碰撞检测系统的实现方法 - Google Patents
一种实时碰撞检测系统的实现方法 Download PDFInfo
- Publication number
- CN102509317A CN102509317A CN2011102896710A CN201110289671A CN102509317A CN 102509317 A CN102509317 A CN 102509317A CN 2011102896710 A CN2011102896710 A CN 2011102896710A CN 201110289671 A CN201110289671 A CN 201110289671A CN 102509317 A CN102509317 A CN 102509317A
- Authority
- CN
- China
- Prior art keywords
- node
- collision
- model
- execution
- ray
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
Images
Landscapes
- Processing Or Creating Images (AREA)
- Image Generation (AREA)
Abstract
本发明提供了一种实时碰撞检测系统的实现方法,包括如下步骤:A、将场景分割成四叉树,制作场景中需要发生碰撞的物体的带逻辑等级的碰撞模型,生成碰撞模型的模型数据文件以及场景的四叉树及结点信息文件;B、读取所述四叉树及结点信息文件,创建管理模型的四叉树;读取模型数据文件,根据碰撞模型的数量读取碰撞模型中的三角形数据,创建保存三角形数据的数组,并生成碰撞模型的沿轴排列包围盒AABB,根据最长坐标轴对碰撞模型进行排序,然后建立AABB树;C、在客户端和服务器侧检测在射线检测距离内的射线与四叉树的碰撞,以及射线与四叉树叶结点、AABB树及三角形的碰撞,其中在客户端测试最近的碰撞点,在服务器侧判断是否碰撞。
Description
技术领域
本发明涉及计算机游戏及虚拟现实技术领域,尤其涉及一种实时碰撞检测系统的实现方法。
背景技术
碰撞检测技术用于判定一对或多对物体在给定时间域内的同一时刻是否占有相同区域。它是机器人运动规划、计算机仿真、虚拟现实、游戏等领域不可回避的问题之一。
在当今的大型3D场景游戏中,实时碰撞检测技术非常常见,它能够使游戏中各种效果的表现更加精准,玩家的体验更加真实,但是复杂场景的实时检测的效率有时还不能令人满意,影响到游戏的整体性能,影响游戏体验。而对于一些射击类的大型网络游戏,如果仅仅进行客户端的检测,服务端的碰撞结果就只能由客户端返回,但是这样就给了外挂可乘之机,虽然可能可以通过其他方式避免,但也会相对复杂。如果在服务端也进行碰撞检测,以现有的碰撞检测技术而言,服务端无法承受大数据量的碰撞检测,或者需要性能更高效的服务器,增加游戏的运营的支出。
基于格子的碰撞系统在早期比较常见,它实现简单,执行效率快,像早期的仙剑奇侠传和其他碰撞怪的角色扮演游戏(RPG),以及一些推箱子、打砖块、俄罗斯方块等游戏,都是基于这种类型的碰撞检测。基于格子的碰撞检测系统碰撞的精度不够,不属于严格意义上的碰撞检测。
基于二叉空间分割(BSP)树的碰撞检测比较适合复杂的封闭场景,场景根据一定的分配策略将空间划分为2部分,然后再对子结点进行递归划分,直到达到分配策略的要求。碰撞模型的图元数据都保存在叶子中。这种碰撞的分割策略很重要,技术已经很成熟,效率很高。但是基于BSP树的碰撞检测,BSP树的生成需要很长的预处理时间,不适合加载时计算;BSP划分经常会产生原多边形数三到四倍的多边形,考虑到不用保存法线、颜色、uv等信息也要增加将近一倍的资源容量,因此不适合处理大型场景的碰撞。在一个大的游戏中将模型资源的容量从200M增加到400M相信是大部分人都不愿接受的。
发明内容
本发明提供了一种实时碰撞检测系统的实现方法,能够实时高效的处理大型场景的碰撞。
本发明实施例提供的一种实时碰撞检测系统的实现方法包括如下步骤:
A、将场景分割成四叉树,制作场景中需要发生碰撞的物体的碰撞模型,生成碰撞模型的模型数据文件以及场景的四叉树及结点信息文件;
B、读取所述四叉树及结点信息文件,创建管理模型的四叉树;读取模型数据文件,根据碰撞模型的数量读取碰撞模型中的三角形数据,创建保存三角形数据的数组,并生成碰撞模型的沿轴排列包围盒AABB,根据最长坐标轴对碰撞模型进行排序,然后建立AABB树;
C、在客户端和服务器侧检测在射线检测距离内的射线与四叉树的碰撞,以及射线与四叉树叶结点、AABB树及三角形的碰撞,其中在客户端测试最近的碰撞点,在服务器侧判断是否碰撞。
较佳地,步骤A所述将场景分割成四叉树包括:
A1、判断场景中是否存在根节点,若是,执行步骤A2,否则结束本流程;
A2、判断场景中模型的AABB与当前节点的xz平面是否发生碰撞,若是执行步骤A3,否则结束本流程;
A3、判断当前节点是否为叶子节点且当前节点包含的模型数目小于N,若是执行步骤A5,否则执行步骤A4;
A4、判断当前节点是否为最深节点,若是,执行步骤A5,否则执行步骤A6;
A5、在当前节点中添加模型数据的索引,然后结束本流程;
A6、判断是否遍历完四叉树的四个子节点,若是,执行步骤A7,否则执行步骤A10;
A7、判断是否遍历完当前节点包含的模型数据,若是执行步骤A8,否则返回步骤A6;
A8、判断是否到达最上层结点,若是,结束本流程,否则执行步骤A9;
A9、返回上一层结点,并继续执行步骤A6;
A10、设置当前结点的子结点为当前结点,并继续执行步骤A2。
较佳地,所述碰撞模型为场景中物体的渲染模型的简化模型。
较佳地,步骤A所述绘制场景中需要发生碰撞的物体的碰撞模型包括:设置碰撞模型的逻辑等级;
所述检测射线与四叉树叶结点、AABB树及三角形的碰撞符合如下原则:射线仅与高于自身逻辑等级的碰撞模型对应的AABB发生碰撞。
较佳地,所述碰撞模型的逻辑等级分成低,中,高共三级。
较佳地,所述四叉树及结点信息文件的文件头部分包括文件标识、碰撞模型数量和四叉树结点数量;文件体中包括N组结点信息以及结点包含模型信息,N为四叉树中的结点总数;四叉树及结点信息文件还包括结点关系信息。
较佳地,所述四叉树及结点信息文件中的第i组结点信息的具体内容包括:第i个结点的X轴最小值、Z轴最小值、X轴最大值、Z轴最大值、该节点的深度以及结点标识,i为自然数,且1≤i≤N。
较佳地,所述四叉树及结点信息文件中的第i组结点包含模型信息包括:结点包含碰撞模型数量以及该结点包含的全部碰撞模型索引。
较佳地,所述四叉树及结点信息文件中的结点关系信息包括结点索引、孩子标志、孩子结点索引以及1至4个孩子结点。
较佳地,所述模型数据文件的文件头包括文件标识和三角形网格数量,文件体包括三角形信息和模型数据信息;所述三角形信息中包括多于1个三角形网格信息,每个三角形网格信息中包括该三角形网格中包含的三角形数量、三角形信息;模型数据信息中包括每一个碰撞模型的模型AABB、碰撞逻辑等级、三角形网格索引、三角形数量以及转换矩阵。
较佳地,步骤C所述在客户端测试最近的碰撞点包括:客户端测试所有与射线发生碰撞的模型的三角形数据,计算最近的碰撞点,并返回碰撞测试结果。
较佳地,步骤C所述在服务器侧判断是否碰撞包括:当服务器检测到射线与某一个三角形发生碰撞时,立即返回测试成功。
较佳地,步骤C所述检测在射线检测距离内的射线与四叉树的碰撞检测包括如下流程:
C1、判断根结点是否是叶子结点,若是,执行步骤C2,否则执行步骤C3;
C2、检测叶子结点中模型碰撞,然后结束本流程;
C3、判断射线是否与根结点AABB碰撞,若是执行步骤C4,否则结束本流程;
C4、判断该根结点是否存在未检验的子结点,若是执行步骤C7,否则执行步骤C5;
C5、判断该根结点是否有父结点,若是执行步骤C6,否则结束本流程;
C6、返回父节点,并转至步骤C4;
C7、判断子结点是否是叶子结点,若是执行步骤C8,否则执行步骤C10;
C8、判断该叶子结点是否存在模型数据,若是执行步骤C9,否则执行步骤C6;
C9、测试射线与叶子结点中模型的碰撞,然后返回步骤C5;
C10、测试射线与子结点的碰撞;
C11:若碰撞成功,执行步骤C12,若碰撞失败,返回步骤C4;
C12:判断该子节点是否是叶子结点,若是,返回步骤C4,否则以这个子节点为当前结点,然后返回步骤C4。
较佳地,步骤C所述检测在射线检测距离内的射线与四叉树叶结点和AABB及三角形的碰撞包括如下流程:
C13、判断当前场景是否存在碰撞模型,若是,执行步骤C14,否则结束本流程;
C14、判断射线测试等级是否大于模型的逻辑碰撞等级,若是,执行步骤C15,否则返回步骤C13;
C15、判断射线与模型AABB碰撞是否成功,若是,执行步骤C16,否则返回步骤C13;
C16、转换射线和起始点到模型本地坐标系;
C17、设置根结点;
C18、测试射线与当前结点模型的AABB的碰撞;
C19、若碰撞成功,执行步骤C20,否则转至步骤C23;
C20、判断当前结点是否是叶子结点,若是执行步骤C24,否则执行步骤C21;
C21、判断子节点是否遍历完毕,若是,执行步骤C23,否则执行步骤C22;
C22、访问子节点,并返回步骤C18;
C23、判断是否存在父节点,若是返回步骤C21,否则结束本流程;
C24、判断是否存在三角形集合,若是执行步骤C25,否则执行步骤C23;
C25、测试射线与三角形的碰撞;
C26、判断碰撞是否成功,若是执行步骤C27,否则返回步骤C24;
C27、判断本次碰撞是否比最近碰撞距离最近,若是,执行步骤C28,否则返回步骤C24;
C28、记录碰撞点,并返回步骤C24。
从以上技术方案可以看出,将场景分割成四叉树,并检测在射线检测距离内的射线与四叉树的碰撞检测以及射线与四叉树叶结点和AABB及三角形的碰撞,客户端和服务器分别执行不同的碰撞检测任务,其中服务端当检测到有碰撞时,系统立即返回碰撞成功,客户端检测,需要测试最近的碰撞点,这样可以极大减少服务器端的碰撞检测计算量,能够高效的处理大型场景的碰撞,满足服务端大批量高效的计算,同时又避免了外挂的可能。
附图说明
图1为本发明实施例提出的基于逻辑等级的实时碰撞检测方法流程示意图;
图2为本发明实施例提供的将场景分割成四叉树的详细流程图;
图3为四叉树及结点信息文件的结构示意图;
图4为模型数据文件的结构示意图;
图5为本发明实施例提供的射线与四叉树的碰撞检测流程图;
图6为本发明实施例提供的射线与四叉树叶结点和AABB树及三角形的碰撞检测流程。
具体实施方式
图1示出了本发明实施例提出的一种实时碰撞检测系统的实现方法流程,包括如下步骤:
步骤101:将场景分割成四叉树;
步骤102:制作场景中需要发生碰撞的物体的带逻辑等级的碰撞模型;
步骤103:生成场景的碰撞模型的模型数据文件以及场景的四叉树信息的四叉树信息文件;
步骤104:读取所述四叉树信息文件,创建管理模型的四叉树,读取模型数据文件,根据碰撞模型的数量读取碰撞模型中的三角形数据,创建保存三角形数据的数组,并生成碰撞模型的沿轴排列包围盒(AABB,Aligned AxisBounding Box),根据最长坐标轴对碰撞模型进行排序,然后建立AABB树;
步骤105:检测在射线检测距离内的射线与四叉树的碰撞,以及射线与四叉树叶结点、AABB树及三角形的碰撞。
AABB保存了三角形的集合,AABB的构建是通过三角形在模型中的相对位置进行划分,这样能够更快的检测与三角形数据的碰撞。
服务端进行射线检测时,当检测到有碰撞时,系统立即返回碰撞成功,因为服务端并不需要知道碰撞的具体位置,只需要判定是否发生碰撞。
客户端检测,需要测试最近的碰撞点,所以测试效率会相对降低。因为客户端需要根据测试的碰撞点,进行后续处理,例如碰撞效果的渲染等。
当测试等级大于碰撞模型本身的逻辑等级时,判定未发生碰撞,在满足一定真实性的情况下,提高了系统的执行效率。
为使本发明技术方案的特点及技术效果更加清楚,以下通过具体实施例对本发明技术方案进行进一步详细阐述。
步骤101所述将场景分割为四叉树具体包括:
将场景分割成四叉树,判断场景中模型的AABB的xz面与由场景分割成的四叉树的各个结点由上至下的碰撞情况,如果发生碰撞,将判断此结点子结点碰撞情况,直至满足条件(子节点模型数小于一定数量或到达最深结点)放入子结点,由此管理场景中的所有模型。
图2示出了本发明实施例提供的将场景分割成四叉树的详细流程,包括如下步骤:
步骤201:判断场景中是否存在根节点,若是,执行步骤202,否则结束本流程。
步骤202:判断场景中模型的AABB与当前节点的xz平面是否发生碰撞,若是执行步骤203,否则结束本流程。
步骤203:判断当前节点是否为叶子节点且当前节点包含的模型数目N,若是执行步骤205,否则执行步骤204。
N为根据分配策略预先设定的自然数,代表四叉树最小节点所能容纳的模型的上限。
步骤204:判断当前节点是否为最深节点,若是,执行步骤205,否则执行步骤206。
步骤205:在当前节点中添加模型数据的索引,然后结束本流程。
步骤206:判断是否遍历完四叉树的四个子节点,若是,执行步骤207,否则执行步骤210。
步骤207:判断是否遍历完当前节点包含的模型数据,若是执行步骤208,否则返回步骤206。
步骤208:判断是否到达最上层结点,若是,结束本流程,否则执行步骤209。
步骤209:返回上一层结点,并继续执行步骤206。
步骤210:设置当前结点的子结点为当前结点,并继续执行步骤202。
绘制场景中需要发生碰撞的物体的碰撞模型,碰撞模型需要与场景中物体的渲染模型基本吻合,但是相对于渲染模型进行极大的简化,以提高射线碰撞检测的速率。
同时,在静物模型编辑器中,在静物模型中添加碰撞模型的信息,根据静物直观的表象,这个直观的表象就是看起来静物的实际的低,中,高,但是确定这个模型到底属于什么等级,还需要再静物编辑器中设置模型的逻辑等级。碰撞模型的逻辑等级分成低,中,高共三级,射线检测时,也将包含逻辑等级信息,射线仅与高于自身逻辑等级的碰撞模型发生碰撞。例如,一个低等级的射线可以测试与中等级和高等级的模型的碰撞,中等级的射线可以测试与高等级模型的碰撞。
最后生成场景的包含碰撞模型的模型数据文件以及场景的四叉树信息文件,这样可以使程序在加载的过程不再重新计算生成一次四叉树,提高程序效率。生成的文件有2个,一个是四叉树及结点信息文件,另一个是所有碰撞模型的模型数据文件。
四叉树及结点信息文件的结构如图3所示,文件头部分包括文件标识(4字节)、碰撞模型数量(4字节)、四叉树结点数量(4字节)。文件体中还包括N组结点信息以及结点包含模型信息,N为四叉树中的结点总数。四叉树及结点信息文件还包括结点关系信息。
第i组(1≤i≤N)结点信息的具体内容包括:第i个结点的X轴最小值m_fMinX(4字节)、Z轴最小值m_fMinZ(4字节)、X轴最大值m_fMaxX(4字节)、Z轴最大值m_fMaxZ(4字节)、该节点的深度m_nDepth(4字节)、结点标识m_nID(4字节)。第i组结点包含模型信息包括:结点包含碰撞模型数量(4字节)、以及该结点包含的全部碰撞模型索引(4字节)。
结点关系信息包括:结点索引(4字节)、孩子标志(1字节)、孩子结点索引(4字节)以及1至4个孩子结点。
模型数据文件的结构如图4所示,其文件头包括文件标识(4字节)和三角形网格数量(4字节)。模型数据文件的文件体包括三角形信息和模型数据信息。三角形信息中包括多于1个的三角形网格信息,每个三角形网格信息中包括该三角形网格中包含的三角形数量(4字节)、三角形信息(36字节)。模型数据信息中包括每一个碰撞模型的模型AABB(24字节)、碰撞逻辑等级(4字节)、三角形网格索引(4字节)、三角形数量(4字节)以及转换矩阵(64字节)。
所述步骤104具体包括:
子步骤104-1:读取碰撞测试系统四叉树文件,读取模型数量和四叉树结点数量,将所有的结点读出保存在碰撞测试系统的数组中,以及每个结点中包含的模型的索引信息;
子步骤104-2:读取结点关系信息,根据关系信息重建四叉树。
子步骤104-3:读取模型数据文件,根据模型的数量,读取所有的模型中的三角形数据,创建保存模型三角形数据的数组,读取所有的模型信息。
子步骤104-4:生成模型的AABB树,AABB树保存了三角形的集合,AABB树的构建是通过三角形在模型中的相对位置进行划分,这样能够更快的检测与三角形数据的碰撞。
步骤105所述碰撞检测包括两部分内容,分别是:射线与四叉树的碰撞检测以及射线与四叉树叶结点和AABB及三角形的碰撞。
测试射线是否穿过四叉树结点,如果发生碰撞,继续测试子结点,当查找到碰撞成功的叶子结点,如果结点内有碰撞模型,再判断模型的逻辑等级是否通过,如果通过则检测与碰撞模型的AABB的碰撞。如果与模型的AABB发生碰撞,通过模型的转换矩阵的逆矩阵将射线的起始点和方向向量转换到模型的本地坐标系进行测试,因为碰撞模型的三角形数据都是本地坐标系下的数据。
射线与四叉树的碰撞检测流程详见图5所示,包括如下步骤:
步骤501:判断根结点是否是叶子结点,若是,执行步骤502,否则执行步骤503。
步骤502:检测叶子结点中模型碰撞,然后结束本流程。
步骤503:判断射线是否与根结点AABB碰撞,若是执行步骤504,否则结束本流程。
步骤504:判断该根结点是否存在未检验的子结点,若是执行步骤507,否则执行步骤505。存在未检验的子结点的情况可以是子结点不为空,且4个子结点没有遍历完;如果子结点为空或者已遍历完4个子结点,则不存在未检验的子结点。
步骤505:判断该根结点是否有父结点,若是执行步骤506,否则结束本流程。
步骤506:返回父节点,并转至步骤504继续检验子结点的操作。
步骤507:判断子结点是否是叶子结点,若是执行步骤508,否则执行步骤510。叶子结点是没有子结点的结点,即叶子节点的子节点都为空。
步骤508:判断该叶子结点是否存在模型数据,若是执行步骤509,如果不存在,执行步骤506。
步骤509:测试射线与叶子结点中模型的碰撞,然后返回步骤505。
步骤510:测试射线与子结点的碰撞。
步骤511:若碰撞成功,执行步骤512。如果碰撞失败,返回504,继续检验子结点
步骤512:判断该子节点是否是叶子结点,若是,返回步骤504,若否,执行步骤513。
步骤513:以这个子节点为当前结点,然后返回步骤504。
测试射线与模型AABB树的碰撞,测试射线与当前结点的AABB的碰撞,如果碰撞成功,测试子节点与射线的碰撞,以此递归,如果射线与叶子结点碰撞成功,然后检测与叶子结点中包含的三角形的碰撞。通过三角形与射线的碰撞计算碰撞点。再通过转换矩阵将碰撞点转换到世界坐标系。
图6示出了射线与四叉树叶结点和AABB树及三角形的碰撞检测流程,包括如下步骤:
步骤601:判断当前场景是否存在碰撞模型,若是,执行步骤602,否则结束本流程。
步骤602:判断射线测试等级是否大于模型的逻辑碰撞等级,若是,执行步骤603,否则返回步骤601。
步骤603:判断射线与模型AABB碰撞是否成功,若是,执行步骤604,否则返回步骤601。
步骤604:转换射线和起始点到模型本地坐标系。
步骤605:设置根结点。
步骤606:测试射线与当前结点模型的AABB的碰撞。
步骤607,若碰撞成功,执行步骤608,否则转至步骤611。
步骤608:判断当前结点是否是叶子结点,若是执行步骤612,否则执行步骤609。
步骤609:判断子节点是否遍历完毕,若是,执行步骤611,否则执行步骤610。
步骤610:访问子节点,并返回步骤606。
步骤611:判断是否存在父节点,若是返回步骤609,否则结束本流程。
步骤612:判断是否存在三角形集合,若是执行步骤613,否则执行步骤611。
步骤613:测试射线与三角形的碰撞。
步骤614:判断碰撞是否成功,若是执行步骤615,否则返回步骤612。
步骤615:判断本次碰撞是否比最近碰撞距离更近,若是,执行步骤616,否则返回步骤612。
步骤616:记录碰撞点,并返回步骤612。
客户端侧,碰撞测试需要返回碰撞的最近点,射线检测需要测试所有与射线发生碰撞的模型的三角形数据,计算最近的碰撞点,并返回碰撞测试结果。
服务器侧,碰撞测试仅仅需要测试是否发生碰撞,当检测到射线与某一个三角形发生碰撞时,立即返回测试成功,不再进行测试,以提高测试效率。
所述仅为本发明的较佳实施例而已,并不用以限制本发明,凡在本发明的精神和原则之内,所做的任何修改、等同替换、改进等,均应包含在本发明保护的范围之内。
Claims (14)
1.一种实时碰撞检测方法,其特征在于,包括如下步骤:
A、将场景分割成四叉树,制作场景中需要发生碰撞的物体的碰撞模型,生成碰撞模型的模型数据文件以及场景的四叉树及结点信息文件;
B、读取所述四叉树及结点信息文件,创建管理模型的四叉树;读取模型数据文件,根据碰撞模型的数量读取碰撞模型中的三角形数据,创建保存三角形数据的数组,并生成碰撞模型的沿轴排列包围盒AABB,根据最长坐标轴对碰撞模型进行排序,然后建立AABB树;
C、在客户端和服务器侧检测在射线检测距离内的射线与四叉树的碰撞,以及射线与四叉树叶结点、AABB树及三角形的碰撞,其中在客户端测试最近的碰撞点,在服务器侧判断是否碰撞。
2.根据权利要求1所述的方法,其特征在于,步骤A所述将场景分割成四叉树包括:
A1、判断场景中是否存在根节点,若是,执行步骤A2,否则结束本流程;
A2、判断场景中模型的AABB与当前节点的xz平面是否发生碰撞,若是执行步骤A3,否则结束本流程;
A3、判断当前节点是否为叶子节点且当前节点包含的模型数目小于N,若是执行步骤A5,否则执行步骤A4;
A4、判断当前节点是否为最深节点,若是,执行步骤A5,否则执行步骤A6;
A5、在当前节点中添加模型数据的索引,然后结束本流程;
A6、判断是否遍历完四叉树的四个子节点,若是,执行步骤A7,否则执行步骤A10;
A7、判断是否遍历完当前节点包含的模型数据,若是执行步骤A8,否则返回步骤A6;
A8、判断是否到达最上层结点,若是,结束本流程,否则执行步骤A9;
A9、返回上一层结点,并继续执行步骤A6;
A10、设置当前结点的子结点为当前结点,并继续执行步骤A2。
3.根据权利要求1所述的方法,其特征在于,所述碰撞模型为场景中物体的渲染模型的简化模型。
4.根据权利要求1所述的方法,其特征在于,步骤A所述绘制场景中需要发生碰撞的物体的碰撞模型包括:设置碰撞模型的逻辑等级;
所述检测射线与四叉树叶结点、AABB树及三角形的碰撞符合如下原则:射线仅与高于自身逻辑等级的碰撞模型对应的AABB发生碰撞。
5.根据权利要求4所述的方法,其特征在于,所述碰撞模型的逻辑等级分成低,中,高共三级。
6.根据权利要求4所述的方法,其特征在于,所述四叉树及结点信息文件的文件头部分包括文件标识、碰撞模型数量和四叉树结点数量;文件体中包括N组结点信息以及结点包含模型信息,N为四叉树中的结点总数;四叉树及结点信息文件还包括结点关系信息。
7.根据权利要求6所述的方法,其特征在于,所述四叉树及结点信息文件中的第i组结点信息的具体内容包括:第i个结点的X轴最小值、Z轴最小值、X轴最大值、Z轴最大值、该节点的深度以及结点标识,i为自然数,且1≤i≤N。
8.根据权利要求6所述的方法,其特征在于,所述四叉树及结点信息文件中的第i组结点包含模型信息包括:结点包含碰撞模型数量以及该结点包含的全部碰撞模型索引。
9.根据权利要求6所述的方法,其特征在于,所述四叉树及结点信息文件中的结点关系信息包括结点索引、孩子标志、孩子结点索引以及1至4个孩子结点。
10.根据权利要求6至9任一项所述的方法,其特征在于,所述模型数据文件的文件头包括文件标识和三角形网格数量,文件体包括三角形信息和模型数据信息;所述三角形信息中包括多于1个三角形网格信息,每个三角形网格信息中包括该三角形网格中包含的三角形数量、三角形信息;模型数据信息中包括每一个碰撞模型的模型AABB、碰撞逻辑等级、三角形网格索引、三角形数量以及转换矩阵。
11.根据权利要求10所述的方法,其特征在于,步骤C所述在客户端测试最近的碰撞点包括:客户端测试所有与射线发生碰撞的模型的三角形数据,计算最近的碰撞点,并返回碰撞测试结果。
12.根据权利要求10所述的方法,其特征在于,步骤C所述在服务器侧判断是否碰撞包括:当服务器检测到射线与某一个三角形发生碰撞时,立即返回测试成功。
13.根据权利要求10所述的方法,其特征在于,步骤C所述检测在射线检测距离内的射线与四叉树的碰撞检测包括如下流程:
C1、判断根结点是否是叶子结点,若是,执行步骤C2,否则执行步骤C3;
C2、检测叶子结点中模型碰撞,然后结束本流程;
C3、判断射线是否与根结点AABB碰撞,若是执行步骤C4,否则结束本流程;
C4、判断该根结点是否存在未检验的子结点,若是执行步骤C7,否则执行步骤C5;
C5、判断该根结点是否有父结点,若是执行步骤C6,否则结束本流程;
C6、返回父节点,并转至步骤C4;
C7、判断子结点是否是叶子结点,若是执行步骤C8,否则执行步骤C10;
C8、判断该叶子结点是否存在模型数据,若是执行步骤C9,否则执行步骤C6;
C9、测试射线与叶子结点中模型的碰撞,然后返回步骤C5;
C10、测试射线与子结点的碰撞;
C11:若碰撞成功,执行步骤C12,若碰撞失败,返回步骤C4;
C12:判断该子节点是否是叶子结点,若是,返回步骤C4,否则以这个子节点为当前结点,然后返回步骤C4。
14.根据权利要求10所述的方法,其特征在于,步骤C所述检测在射线检测距离内的射线与四叉树叶结点和AABB及三角形的碰撞包括如下流程:
C13、判断当前场景是否存在碰撞模型,若是,执行步骤C14,否则结束本流程;
C14、判断射线测试等级是否大于模型的逻辑碰撞等级,若是,执行步骤C15,否则返回步骤C13;
C15、判断射线与模型AABB碰撞是否成功,若是,执行步骤C16,否则返回步骤C13;
C16、转换射线和起始点到模型本地坐标系;
C17、设置根结点;
C18、测试射线与当前结点模型的AABB的碰撞;
C19、若碰撞成功,执行步骤C20,否则转至步骤C23;
C20、判断当前结点是否是叶子结点,若是执行步骤C24,否则执行步骤C21;
C21、判断子节点是否遍历完毕,若是,执行步骤C23,否则执行步骤C22;
C22、访问子节点,并返回步骤C18;
C23、判断是否存在父节点,若是返回步骤C21,否则结束本流程;
C24、判断是否存在三角形集合,若是执行步骤C25,否则执行步骤C23;
C25、测试射线与三角形的碰撞;
C26、判断碰撞是否成功,若是执行步骤C27,否则返回步骤C24;
C27、判断本次碰撞是否比最近碰撞距离更近,若是,执行步骤C28,否则返回步骤C24;
C28、记录碰撞点,并返回步骤C24。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN 201110289671 CN102509317B (zh) | 2011-09-27 | 2011-09-27 | 一种实时碰撞检测系统的实现方法 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN 201110289671 CN102509317B (zh) | 2011-09-27 | 2011-09-27 | 一种实时碰撞检测系统的实现方法 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN102509317A true CN102509317A (zh) | 2012-06-20 |
CN102509317B CN102509317B (zh) | 2013-12-25 |
Family
ID=46221395
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN 201110289671 Active CN102509317B (zh) | 2011-09-27 | 2011-09-27 | 一种实时碰撞检测系统的实现方法 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN102509317B (zh) |
Cited By (17)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN104699946A (zh) * | 2014-12-30 | 2015-06-10 | 北京像素软件科技股份有限公司 | 一种游戏场景的管理方法及装置 |
CN104766371A (zh) * | 2015-04-13 | 2015-07-08 | 南京工程学院 | 一种大规模场景中物体碰撞检测方法 |
CN104850726A (zh) * | 2014-02-13 | 2015-08-19 | 博雅网络游戏开发(深圳)有限公司 | 基于碰撞游戏的异常数据检测方法和系统 |
CN105404511A (zh) * | 2015-11-19 | 2016-03-16 | 福建天晴数码有限公司 | 基于理想几何的物理碰撞预测方法和装置 |
CN105488851A (zh) * | 2015-11-30 | 2016-04-13 | 腾讯科技(深圳)有限公司 | 实时虚拟场景中碰撞体之间碰撞探测的方法和装置 |
CN105786833A (zh) * | 2014-12-22 | 2016-07-20 | 阿里巴巴集团控股有限公司 | 一种网页元素碰撞判断方法及装置 |
CN106182087A (zh) * | 2015-05-04 | 2016-12-07 | 中国科学院沈阳自动化研究所 | 基于六维力传感器的碰撞位置感知方法 |
CN106600684A (zh) * | 2016-11-29 | 2017-04-26 | 浙江科澜信息技术有限公司 | 一种倾斜模型组织构建方法 |
CN106625662A (zh) * | 2016-12-09 | 2017-05-10 | 南京理工大学 | 一种基于虚拟现实带电作业机械臂防碰撞保护方法 |
CN107609222A (zh) * | 2017-08-16 | 2018-01-19 | 北京控制工程研究所 | 一种空间机器人末端接触碰撞力计算方法 |
CN108898676A (zh) * | 2018-06-19 | 2018-11-27 | 青岛理工大学 | 一种虚实物体之间碰撞及遮挡检测方法及系统 |
CN108970113A (zh) * | 2018-07-26 | 2018-12-11 | 广州多益网络股份有限公司 | 一种碰撞检测方法、装置、设备及介质 |
CN110262729A (zh) * | 2019-05-20 | 2019-09-20 | 联想(上海)信息技术有限公司 | 一种对象处理方法和设备 |
CN110496390A (zh) * | 2019-07-23 | 2019-11-26 | 网易(杭州)网络有限公司 | 信息处理方法、装置及存储介质 |
CN111870952A (zh) * | 2020-07-24 | 2020-11-03 | 上海米哈游天命科技有限公司 | 一种高度图生成方法、装置、设备及存储介质 |
CN112825199A (zh) * | 2019-11-20 | 2021-05-21 | 北京博超时代软件有限公司 | 碰撞检测方法、装置、设备及存储介质 |
CN115964183A (zh) * | 2023-03-16 | 2023-04-14 | 中船重工奥蓝托无锡软件技术有限公司 | 基于分布式计算的目标碰撞检测方法 |
Citations (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2005310021A (ja) * | 2004-04-26 | 2005-11-04 | Japan Science & Technology Agency | 衝突検出方法及び衝突検出システム |
CN101071515A (zh) * | 2007-06-25 | 2007-11-14 | 北京金山软件有限公司 | 一种在服务器端实现三维游戏碰撞检测的方法 |
CN101093586A (zh) * | 2007-07-12 | 2007-12-26 | 上海交通大学 | 面向复杂场景实时交互操作的并行碰撞检测方法 |
US20080158225A1 (en) * | 2006-12-28 | 2008-07-03 | Sathe Rahul P | Collision detection of concave bodies using art gallery problem and cube maps |
CN101593366A (zh) * | 2009-06-24 | 2009-12-02 | 北京航空航天大学 | 一种基于平衡二叉树的大规模虚拟场景碰撞检测方法 |
CN101593367A (zh) * | 2009-06-25 | 2009-12-02 | 北京航空航天大学 | 一种基于四叉包围盒树的柔性织物自碰撞检测方法 |
US7883412B2 (en) * | 2002-12-04 | 2011-02-08 | Waterleaf Limited | Collusion detection and control |
-
2011
- 2011-09-27 CN CN 201110289671 patent/CN102509317B/zh active Active
Patent Citations (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7883412B2 (en) * | 2002-12-04 | 2011-02-08 | Waterleaf Limited | Collusion detection and control |
JP2005310021A (ja) * | 2004-04-26 | 2005-11-04 | Japan Science & Technology Agency | 衝突検出方法及び衝突検出システム |
US20080158225A1 (en) * | 2006-12-28 | 2008-07-03 | Sathe Rahul P | Collision detection of concave bodies using art gallery problem and cube maps |
CN101071515A (zh) * | 2007-06-25 | 2007-11-14 | 北京金山软件有限公司 | 一种在服务器端实现三维游戏碰撞检测的方法 |
CN101093586A (zh) * | 2007-07-12 | 2007-12-26 | 上海交通大学 | 面向复杂场景实时交互操作的并行碰撞检测方法 |
CN101593366A (zh) * | 2009-06-24 | 2009-12-02 | 北京航空航天大学 | 一种基于平衡二叉树的大规模虚拟场景碰撞检测方法 |
CN101593367A (zh) * | 2009-06-25 | 2009-12-02 | 北京航空航天大学 | 一种基于四叉包围盒树的柔性织物自碰撞检测方法 |
Non-Patent Citations (3)
Title |
---|
冯良波: "虚拟现实中三维场景构建的优化研究", 《中国优秀硕士学位论文全文数据库》 * |
李山 等: "一种基于八叉树与流水线技术的快速碰撞检测算法", 《计算机与现代化》 * |
梁小红: "虚拟环境中可变形体碰撞检测算法研究", 《中国优秀硕士学位论文全文数据库》 * |
Cited By (29)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN104850726B (zh) * | 2014-02-13 | 2018-08-24 | 博雅网络游戏开发(深圳)有限公司 | 基于碰撞游戏的异常数据检测方法和系统 |
CN104850726A (zh) * | 2014-02-13 | 2015-08-19 | 博雅网络游戏开发(深圳)有限公司 | 基于碰撞游戏的异常数据检测方法和系统 |
CN105786833B (zh) * | 2014-12-22 | 2019-06-18 | 阿里巴巴集团控股有限公司 | 一种网页元素碰撞判断方法及装置 |
CN105786833A (zh) * | 2014-12-22 | 2016-07-20 | 阿里巴巴集团控股有限公司 | 一种网页元素碰撞判断方法及装置 |
CN104699946A (zh) * | 2014-12-30 | 2015-06-10 | 北京像素软件科技股份有限公司 | 一种游戏场景的管理方法及装置 |
CN104699946B (zh) * | 2014-12-30 | 2018-10-30 | 北京像素软件科技股份有限公司 | 一种游戏场景的管理方法及装置 |
CN104766371A (zh) * | 2015-04-13 | 2015-07-08 | 南京工程学院 | 一种大规模场景中物体碰撞检测方法 |
CN106182087A (zh) * | 2015-05-04 | 2016-12-07 | 中国科学院沈阳自动化研究所 | 基于六维力传感器的碰撞位置感知方法 |
CN106182087B (zh) * | 2015-05-04 | 2018-05-15 | 中国科学院沈阳自动化研究所 | 基于六维力传感器的碰撞位置感知方法 |
CN105404511A (zh) * | 2015-11-19 | 2016-03-16 | 福建天晴数码有限公司 | 基于理想几何的物理碰撞预测方法和装置 |
CN105404511B (zh) * | 2015-11-19 | 2019-03-12 | 福建天晴数码有限公司 | 基于理想几何的物理碰撞预测方法和装置 |
CN105488851A (zh) * | 2015-11-30 | 2016-04-13 | 腾讯科技(深圳)有限公司 | 实时虚拟场景中碰撞体之间碰撞探测的方法和装置 |
US10235764B2 (en) | 2015-11-30 | 2019-03-19 | Tencent Technology (Shenzhen) Company Limited | Method, terminal, and storage medium for detecting collision between colliders in real-time virtual scene |
CN106600684A (zh) * | 2016-11-29 | 2017-04-26 | 浙江科澜信息技术有限公司 | 一种倾斜模型组织构建方法 |
CN106625662A (zh) * | 2016-12-09 | 2017-05-10 | 南京理工大学 | 一种基于虚拟现实带电作业机械臂防碰撞保护方法 |
CN107609222A (zh) * | 2017-08-16 | 2018-01-19 | 北京控制工程研究所 | 一种空间机器人末端接触碰撞力计算方法 |
CN108898676A (zh) * | 2018-06-19 | 2018-11-27 | 青岛理工大学 | 一种虚实物体之间碰撞及遮挡检测方法及系统 |
CN108898676B (zh) * | 2018-06-19 | 2022-05-13 | 青岛理工大学 | 一种虚实物体之间碰撞及遮挡检测方法及系统 |
CN108970113A (zh) * | 2018-07-26 | 2018-12-11 | 广州多益网络股份有限公司 | 一种碰撞检测方法、装置、设备及介质 |
CN108970113B (zh) * | 2018-07-26 | 2021-07-23 | 广州多益网络股份有限公司 | 一种碰撞检测方法、装置、设备及介质 |
CN110262729B (zh) * | 2019-05-20 | 2021-11-16 | 联想(上海)信息技术有限公司 | 一种对象处理方法和设备 |
CN110262729A (zh) * | 2019-05-20 | 2019-09-20 | 联想(上海)信息技术有限公司 | 一种对象处理方法和设备 |
CN110496390A (zh) * | 2019-07-23 | 2019-11-26 | 网易(杭州)网络有限公司 | 信息处理方法、装置及存储介质 |
US11998839B2 (en) | 2019-07-23 | 2024-06-04 | Netease (Hangzhou) Network Co., Ltd. | Information processing method, apparatus and computer storage medium |
CN112825199A (zh) * | 2019-11-20 | 2021-05-21 | 北京博超时代软件有限公司 | 碰撞检测方法、装置、设备及存储介质 |
CN112825199B (zh) * | 2019-11-20 | 2023-09-19 | 北京博超时代软件有限公司 | 碰撞检测方法、装置、设备及存储介质 |
CN111870952A (zh) * | 2020-07-24 | 2020-11-03 | 上海米哈游天命科技有限公司 | 一种高度图生成方法、装置、设备及存储介质 |
CN111870952B (zh) * | 2020-07-24 | 2024-01-23 | 上海米哈游天命科技有限公司 | 一种高度图生成方法、装置、设备及存储介质 |
CN115964183A (zh) * | 2023-03-16 | 2023-04-14 | 中船重工奥蓝托无锡软件技术有限公司 | 基于分布式计算的目标碰撞检测方法 |
Also Published As
Publication number | Publication date |
---|---|
CN102509317B (zh) | 2013-12-25 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN102509317B (zh) | 一种实时碰撞检测系统的实现方法 | |
CN110738721B (zh) | 基于视频几何分析的三维场景渲染加速方法及系统 | |
Garanzha et al. | Fast ray sorting and breadth‐first packet traversal for GPU ray tracing | |
KR102712155B1 (ko) | 가속 구조를 생성하는 방법 및 장치 | |
CN102147928B (zh) | 一种基于粒子系统的火焰模拟加速改进算法 | |
CN106446351A (zh) | 一种面向实时绘制的大规模场景组织与调度技术及仿真系统 | |
US11704868B2 (en) | Spatial partitioning for graphics rendering | |
CN110309458B (zh) | 基于WebGL的BIM模型显示及渲染方法 | |
CN105389850A (zh) | 一种大规模三维场景的新型可见性生成方法 | |
CN102663801A (zh) | 一种提高三维模型渲染性能的方法 | |
CN103593817A (zh) | 用于使用并行管道的图形处理的方法和设备 | |
CN104054112A (zh) | 描绘数据生成装置以及图像描绘装置 | |
CN101826215A (zh) | 实时二级光线跟踪的并行渲染方法 | |
CN109745704A (zh) | 一种体素地形的管理方法 | |
CN109859562A (zh) | 数据生成方法、装置、服务器及存储介质 | |
US10824775B2 (en) | Simulation method and device for determining collision between objects | |
CN112755534B (zh) | 一种数据处理方法、装置和存储介质 | |
CN101770655B (zh) | 一种大规模虚拟动态场景简化方法 | |
CN102855661A (zh) | 基于空间相似性的大规模森林场景快速生成方法 | |
JP6948226B2 (ja) | 加速構造を生成する方法及びその装置 | |
Guntury et al. | Raytracing dynamic scenes on the GPU using grids | |
CN113470172B (zh) | 一种OBJ三维模型转换3DTiles方法 | |
CN103700137A (zh) | 一种时空相关的层次遮挡剔除方法 | |
US20120100912A1 (en) | Method of reusing physics simulation results and game service apparatus using the same | |
CN114398253A (zh) | 自动驾驶实车测试场景生成方法和系统 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
C06 | Publication | ||
PB01 | Publication | ||
C10 | Entry into substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
C14 | Grant of patent or utility model | ||
GR01 | Patent grant |