青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

牽著老婆滿街逛

嚴以律己,寬以待人. 三思而后行.
GMail/GTalk: yanglinbo#google.com;
MSN/Email: tx7do#yahoo.com.cn;
QQ: 3 0 3 3 9 6 9 2 0 .

一種3D游戲碰撞檢測解決方案

轉載自:http://www.cnblogs.com/cproom/archive/2007/12/15/608732.html




        碰撞檢測在3D游戲中至關重要,好的碰撞檢測要求人物在場景中可以平滑移動,遇到一定高度內的臺階可以自動上去,而過高的臺階則把人擋住,遇到斜率較小的斜坡可以上去,斜率過大則把人擋住,在各種前進方向被擋住的情況下都要盡可能地讓人物沿合理的方向滑動而不是被迫停下。在滿足這些要求的同時還要做到足夠精確和穩定,防止人物在特殊情況下穿墻而掉出場景。

        碰撞檢測做得好了是應該的,不易被人注意到,因為這符合我們日常生活中的常識。做得差了卻很容易讓人發現,人物經常被卡住不能前進或者人物穿越了障礙。所以大部分人都覺得寫碰撞檢測代碼是件吃力不討好的事情,算法復雜、容易出bug、不容易出彩。下面還是回到正題,看看我們該如何解決這個難題。

        早期3D游戲的碰撞檢測多數基于格子或者BSP樹,基于格子的系統實現簡單但精度不夠,不屬于嚴格意義的3D碰撞檢測。基于BSP樹的碰撞檢測一度十分流行,算法基本已經成熟定型,但它的固有缺點卻使它不太適合現在的游戲。BSP樹需要很長的預處理時間不適合加載時計算,BSP劃分經常會產生原多邊形數三到四倍的多邊形,考慮到不用保存法線、顏色、uv等信息也要增加將近一倍的資源容量,在一個大的游戲中將模型資源的容量從200M增加到400M相信是大部分人都不愿接受的。目前對于任意復雜三角形集合(mesh)的碰撞檢測多數基于BVTreebounding volume tree,具體可以是aabb treeobb tree或者K-dop tree,這也是當今各種物理引擎和碰撞檢測引擎流行的做法。

        上面是碰撞檢測按數據結構不同的分類,按檢測方式又可以分為離散點的碰撞檢測和連續碰撞檢測(CCD continuous collision detection)。離散點的碰撞檢測是指定某一時刻T的兩個靜態碰撞體,看它們之間是否交迭,如果沒有交迭則返回它們最近點的距離,如果交迭則返回交迭深度,交迭方向等。連續碰撞檢測則是分別指定在T1T2兩個時刻兩個碰撞體的位置,看它們在由T1運動到T2時刻的過程中是否發生碰撞,如果碰撞則返回第一碰撞點的位置和法線。連續碰撞檢測是最為自然的碰撞檢測,可以大大方便碰撞響應邏輯的編寫,可以很容易避免物體發生交迭或者穿越。離散點的碰撞檢測則沒有那么友好,當檢測到碰撞時兩個物體已經發生了交迭,如果其中有三角形網格對象那么已經有許多三角形發生了交迭,如何將兩個交迭的對象分開并按合理的方式運動是一個挑戰。雖然連續碰撞檢測是最自然的方式,但它的實現非常復雜,運算開銷也很大,所以目前大部分成熟的物理引擎和碰撞檢測引擎還是采用了基于離散點的碰撞檢測,為了避免物體交迭過深或者彼此穿越,它們都要采用比較小的模擬步長。

        由于碰撞檢測引擎的復雜性和對效率的高要求,我們應該盡量使用目前成熟的完整引擎,而不是自己去開發。經過評估,我決定采用Opcode碰撞檢測引擎來做游戲中人物和場景的碰撞檢測。Opcode的主要功能是用aabb tree管理復雜三角形集合來和射線、球體,立方體,另一個三角形集合等進行離散點上的碰撞檢測,如果檢測到交迭則返回所有發生交迭的三角形。Opcode的特點是高度的內存使用優化和極好的效率,ODE物理引擎底層就采用它來做復雜三角形mesh的碰撞檢測,Opcode的作者也是NovodeXPhysX前身)物理引擎的核心開發人員,據說NovodeX采用了Opcode的一個更優化版本。由此可見Opcode的成熟與效率。

        確定了要使用的引擎,下面要討論的算法就和具體引擎無關了,適合于任何離散點的碰撞檢測引擎。我們用AABB包圍盒來代表場景中的人物,看看如何實現文章開頭所提出的效果。

         首先解釋一下檢測地面的方式,沿人物包圍盒的四條豎邊向下投四條射線,射線的終點略低于人物的腳底(也就是說射線的長度是有限的),如果與場景發生碰撞并且碰撞平面的斜率小于某一值則取得碰撞點的高度,否則視為這條射線沒有檢測到地面。將所有射線檢測到的地面高度最大值作為最后的地面高度,如果四條射線都沒有檢測到地面則認為人物懸空。

 

vD = 當前幀人物位移

p0 
= 人物包圍盒中心當前位置

bOnGroundP1; 
// 人物是否站在地面

bOnGroundP3; 
// 人物是否站在地面

bOnGround; 
// 人物是否站在地面

 

p1 
= p0 + vD

在p1位置檢測地面

if( 檢測到地面 )

{

     將包圍盒下放到地面得到位置p2

     bOnGroundP1 
= true;

}


else

{

     p2 
= p1;

     bOnGroundP1 
= false;

}





測試p2點的包圍盒是否與場景交迭

if( 交迭 )

{

     取得所有交迭三角形的法線,將它們相加后取平均值,得到法線normal

     將法線與向上的向量叉乘得到切線方向tangent

     
// 計算人物沿切線滑動后的位置,注意這里用p0做計算。

     
// 如果要使滑動更平滑可以把p0向法線方向推出一些

     
// p3 = p0 + normal * 0.1f + vD.Dot(tangent);

     p3 
= p0 + vD.Dot(tangent); 

 

     在p3位置檢測地面

     
if( 檢測到地面 )

     
{

         將包圍盒下放到地面得到位置p4

          bOnGroundP3 
= true;

     }


     Else

     
{

         p4 
= p3;

          bOnGroundP3 
= false;

     }


 

     測試p4點的包圍盒是否與場景交迭

     
if( 交迭 )

     
{

         測試p1點的包圍盒是否與場景交迭

         
if( 交迭 )

         
{

              
// 無法得到合理的移動位置,人物位置保持不變

              
// 等待下一幀玩家調整前進方向再做測試

              將p0作為人物的新位置

              bOnGround 
= true;

              
return;

         }


         
else

         
{

              將p1作為人物的新位置

              bOnGround 
= bOnGroundP1;

              
return;

         }


     }


     Else

     
{

         將p4作為人物的新位置

         bOnGround 
= bOnGroundP3;

          
return;

     }


}


else

{

     將p2作為人物的新位置

     bOnGround 
= bOnGroundP1;

     
return;

}

 

 

上面的算法基本達到了文章開頭所提到的效果,在某些復雜情況下人物移動還有些不流暢,但沒有發現人物有穿越障礙物的現象。在大部分情況下人物的新坐標都會由p2點返回,最壞情況是人物被卡住返回p0點。在P4 3.0G的機器上可以支持120個人物在最壞情況下保持30幀的游戲幀數。

posted on 2007-12-29 12:08 楊粼波 閱讀(926) 評論(0)  編輯 收藏 引用

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            中文高清一区| 亚洲精品男同| 亚洲破处大片| 亚洲一区激情| 亚洲二区精品| 久久国产直播| 国产精品福利在线| 在线看日韩av| 久久久99国产精品免费| 日韩一级大片| 欧美精品一区二区三区高清aⅴ| 国内外成人免费激情在线视频网站| 一区二区国产精品| 欧美激情精品久久久久久变态| 亚洲制服欧美中文字幕中文字幕| 欧美日韩aaaaa| 亚洲美女淫视频| 免费一级欧美片在线播放| 亚洲欧美日韩中文视频| 欧美日韩视频在线第一区| 亚洲精品中文字幕女同| 亚洲特级毛片| 国产精品超碰97尤物18| 国产精品99久久99久久久二8 | 久久婷婷国产综合国色天香| 亚洲一区二区不卡免费| 国产精品theporn| 久久久精品国产一区二区三区| 欧美岛国在线观看| 亚洲精品国产精品乱码不99按摩| 欧美 日韩 国产 一区| 久久久久一区二区| 在线播放中文字幕一区| 欧美凹凸一区二区三区视频| 欧美日韩综合精品| 欧美一区二区高清| 欧美一区二区三区免费观看视频| 国产在线精品一区二区夜色| 亚洲精品在线二区| 国产精品色网| 久久久夜夜夜| 欧美黄色片免费观看| 中文高清一区| 免费视频最近日韩| 亚洲一区二区成人| 午夜精品免费| 国产日韩欧美一区二区三区在线观看 | 夜夜嗨av一区二区三区四区| 久久国产主播精品| 永久555www成人免费| 亚洲少妇在线| 国模大胆一区二区三区| 夜夜嗨av一区二区三区四区 | 久久经典综合| 香蕉久久a毛片| 久久综合狠狠综合久久激情| 日韩一级黄色大片| 亚洲欧美视频在线观看| 亚洲性线免费观看视频成熟| 欧美精品日韩| 久久国产乱子精品免费女| 国产精品卡一卡二| 欧美a级片一区| 在线不卡亚洲| 久久伊人精品天天| 性做久久久久久| 国产精品国产三级国产普通话99| 夜夜嗨一区二区三区| 亚洲视频www| 欧美性猛交xxxx免费看久久久| 亚洲美女av在线播放| 一区二区三区欧美| 欧美色图五月天| 亚洲一区www| 久久精品国产一区二区三区免费看| 国产精品永久在线| 日韩一二三区视频| 午夜精品三级视频福利| 欧美成在线视频| 日韩视频中文字幕| 午夜欧美大片免费观看| 国产综合色一区二区三区| 久久久www成人免费无遮挡大片| 亚洲在线观看视频| 国产情侣一区| 中文日韩在线| 久久精品国产免费看久久精品| 91久久久亚洲精品| 欧美成人午夜77777| 99这里只有精品| 欧美一区亚洲二区| 亚洲国产精彩中文乱码av在线播放 | 黄色成人av| 亚洲一区久久久| 久久久五月天| 亚洲美女在线观看| 国产日韩欧美精品综合| 免费在线观看一区二区| 在线亚洲精品福利网址导航| 久久久久www| 一本色道久久综合亚洲精品高清| 国产精品日韩在线| 免费人成精品欧美精品| 亚洲午夜精品| 亚洲二区免费| 久久久精品国产免大香伊| 亚洲精品美女91| 国产一区二区三区四区在线观看 | 先锋影音一区二区三区| 欧美激情中文字幕乱码免费| 亚洲尤物在线| 欧美在线关看| 欧美三区在线观看| 欧美在线观看网址综合| 亚洲精品免费电影| 免费日韩av| 久久成人精品视频| 国模 一区 二区 三区| 欧美偷拍一区二区| 欧美成人精品| 卡一卡二国产精品| 久久aⅴ国产紧身牛仔裤| 一区二区三区www| 久久成人av少妇免费| 在线视频日韩精品| 亚洲经典在线| 欧美三级电影一区| 美女国产一区| 99精品欧美一区| 亚洲第一精品影视| 久久综合五月天婷婷伊人| 最新成人av网站| 一区二区视频免费在线观看| 欧美美女视频| 欧美国产日韩精品| 牛人盗摄一区二区三区视频| 久久一二三四| 久久久在线视频| 久久免费午夜影院| 久久久伊人欧美| 久热国产精品| 免费在线观看成人av| 欧美国产日韩xxxxx| 欧美第一黄色网| 欧美日韩国产电影| 欧美日韩精品免费观看视一区二区 | 国产精品vvv| 国产精品激情电影| 国产精品伦一区| 国产精品三区www17con| 国产亚洲精品久久久久婷婷瑜伽| 国产日韩成人精品| 国模大胆一区二区三区| 一区二区亚洲| 亚洲伦理中文字幕| 亚洲视频在线观看| 亚洲免费网站| 日韩视频第一页| 中文日韩在线| 欧美一区二区三区免费视| 久久精品青青大伊人av| 免费毛片一区二区三区久久久| 欧美激情亚洲国产| 亚洲精品社区| 销魂美女一区二区三区视频在线| 久久不射2019中文字幕| 牛牛影视久久网| 国产精品国产三级国产普通话蜜臀| 国产色视频一区| 亚洲黄页视频免费观看| 在线一区二区视频| 久久国产欧美精品| 亚洲国产一二三| 欧美成人激情视频| 亚洲靠逼com| 欧美一区二区三区另类| 欧美大胆人体视频| 国产精品综合av一区二区国产馆| 在线观看亚洲| 亚洲一区二区三区视频| 麻豆成人在线| 一区二区三区色| 久久综合五月| 国产欧美日韩亚州综合| 日韩视频永久免费| 久久九九精品| 最新国产精品拍自在线播放| 国产精品亚洲综合一区在线观看| 久久天天躁狠狠躁夜夜av| 欧美日韩午夜精品| 国语自产在线不卡| 亚洲在线观看| 亚洲国产精品免费| 欧美一级视频精品观看| 欧美三区不卡| 亚洲经典自拍| 蜜臀久久久99精品久久久久久 | 久久久久九九视频| 一本色道久久综合亚洲精品不| 久久综合色播五月|