作者:xtxy的专栏

在网上搜索了一些资料,最后采用了obb的碰撞检测,方法如下:

1 在3ds max中,将biped骨骼的大小设置恰当,在使用方框显示骨骼的时候能比较准确的包围住角色,如下图:

222642rgzgxknvndefvjxg.jpg

然后选中所有的骨骼,使用maxscript脚本导出来。脚本其实比较简单,代码如下:

---------------------------------------------------------------------------------

-- file function
fn existFile fname = (getfiles fname).count != 0

-- main
fileName = F://Work//MyProjects//3DGame//3dsmax_data//fight_action_data.txt
if existFile fileName then deleteFile fileName
createFile fileName
fp = openFile fileName mode:at

for sel in selection do
(
-- get bounding box
bb = nodeLocalBoundingBox sel
-- print bb
-- print sel.transform
-- print -------------
position = (bb[2] + bb[1]) / 2
size = bb[2] - bb[1]

len = sel.transform[1].x ^ 2 + sel.transform[1].y ^ 2 + sel.transform[1].z ^ 2
len = len ^ 0.5
x1 = sel.transform[1].x / len
y1 = sel.transform[1].y / len
z1 = sel.transform[1].z / len

extent1 = (size.x * x1 + size.y * y1 + size.z * z1) / 2


len = sel.transform[2].x ^ 2 + sel.transform[2].y ^ 2 + sel.transform[2].z ^ 2
len = len ^ 0.5
x2 = sel.transform[2].x / len
y2 = sel.transform[2].y / len
z2 = sel.transform[2].z / len

extent2 = (size.x * x2 + size.y * y2 + size.z * z2) / 2

len = sel.transform[3].x ^ 2 + sel.transform[3].y ^ 2 + sel.transform[3].z ^ 2
len = len ^ 0.5
x3 = sel.transform[3].x / len
y3 = sel.transform[3].y / len
z3 = sel.transform[3].z / len

extent3 = (size.x * x3 + size.y * y3 + size.z * z3) / 2

print sel.name to:fp

print((extent1 as string) + , + (extent2 as string) + , + (extent3 as string)) to:fp
print((position.x as string) + , + (position.z as string) + , + ((-position.y) as string)) to:fp
print((x1 as string) + , + (z1 as string) + , + ((-y1) as string)) to:fp
print((x2 as string) + , + (z2 as string) + , + ((-y2) as string)) to:fp
print((x3 as string) + , + (z3 as string) + , + ((-y3) as string)) to:fp
)

close fp

---------------------------------------------------------------------------------

生成的文件格式如下:

---------------------------------------------------------------------------------
Bip01
2.18656,2.18656,2.18656
0.583941,40.3044,-1.10637
0.555635,0.0,0.831426
0.831426,0.0,-0.555635
0.0,1.0,0.0
Bip01 Pelvis
6.1669,5.71345,5.46639
0.583941,40.3044,-1.10637
-1.21579e-006,1.0,6.67132e-007
0.481059,0.0,0.876688
0.876688,1.3868e-006,-0.481059
…………
…………
---------------------------------------------------------------------------------

其中每个盒子的第二行数据就是盒子的半个长度,宽度和高度,和第四行至第六行的变换矩阵是一一对应的
第三行就是盒子的中心点位置,是全局坐标
第四行至第六行就是盒子在三个面方向上的标准变换矩阵了。

数据有了之后,就可以用obb碰撞算法进行碰撞检测了。
obb算法可以参考:
http://hi.baidu.com/jorbin/blog/item/2e7c2df5c146f423bd310977.html
或者他引用的一个国外的网址:
http://www.gamasutra.com/view/feature/3383/simple_intersection_tests_for_games.php?page=5

最后贴一个我在ogre里面根据obb数据画出来的碰撞盒子的图片,主要作用是调试碰撞检测是否正确:

222642b3jj88eaml6fum4h.jpg


锐亚教育

锐亚教育,游戏开发论坛|游戏制作人|游戏策划|游戏开发|独立游戏|游戏产业|游戏研发|游戏运营| unity|unity3d|unity3d官网|unity3d 教程|金融帝国3|8k8k8k|mcafee8.5i|游戏蛮牛|蛮牛 unity|蛮牛