• <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>

            天行健 君子當(dāng)自強(qiáng)而不息

            幾何檢測(cè)(3)

             

            AABB與平面的相交性檢測(cè)

            考慮3D中由極值點(diǎn)pminpmax定義的AABB和以標(biāo)準(zhǔn)方式定義的平面:p . n = d,其中n為單位向量,平面與AABB必須處于相同的坐標(biāo)系中。

            一種簡(jiǎn)單的靜態(tài)測(cè)試方法是,計(jì)算矩形邊界框頂點(diǎn)和n的點(diǎn)積,通過(guò)比較點(diǎn)積和d,來(lái)檢測(cè)邊界框的頂點(diǎn)是否完全在平面的一邊,或是在另外一邊。如果所有點(diǎn)積都大于d,那么整個(gè)邊界框就在平面的正面所指的一側(cè);如果所有的點(diǎn)積都小于d,那么整個(gè)邊界框就在平面的反面所指的一側(cè)。

            實(shí)際上,不需要檢測(cè)全部的8個(gè)頂點(diǎn),可以用和變換AABB類(lèi)似的技巧,例如,如果nx > 0,點(diǎn)積最小的頂點(diǎn)是x = xmin,點(diǎn)積最大的頂點(diǎn)是x= xmax。如果nx < 0,則得出的是相反的結(jié)論。對(duì)nynz也有同樣的結(jié)論。我們計(jì)算最小和最大點(diǎn)積的值,如果最小點(diǎn)積大于d或最大點(diǎn)積小于d,說(shuō)明它們不相交;否則,兩個(gè)點(diǎn)在平面的兩邊,說(shuō)明邊界框與平面相交。

            接下來(lái)進(jìn)行動(dòng)態(tài)測(cè)試,我們假設(shè)平面是靜止的(以一個(gè)移動(dòng)物體為參考來(lái)考慮它們的相交性檢測(cè)會(huì)比較簡(jiǎn)單)。邊界框的位移由單位向量d和長(zhǎng)度L定義,和前面一樣,先求得點(diǎn)積最大和最小的頂點(diǎn),并在t=0時(shí)作一次相交性檢測(cè),如果邊界框和平面最初沒(méi)有相交,那么一定是離平面最近的頂點(diǎn)先接觸平面,它可能就是前一步檢測(cè)出的兩個(gè)頂點(diǎn)之一。如果只對(duì)與平面的"正面"碰撞感興趣,那么總是使用點(diǎn)積最小的頂點(diǎn)。一旦檢測(cè)出先接觸到平面的頂點(diǎn),就可以利用射線(xiàn)與平面的相交性測(cè)試來(lái)解決問(wèn)題。

            cAABB3類(lèi)實(shí)現(xiàn)了AABB與平面的靜態(tài)、動(dòng)態(tài)相交性檢測(cè)。

             

            三個(gè)平面間的相交性檢測(cè)

            在3D中,三個(gè)平面相交于一點(diǎn),如圖13.7所示:

            假設(shè)三個(gè)平面的隱式方程為:

            p . n1 = d1

            p . n2 = d2

            p . n3 = d3

            雖然平面的法向量通常被限制為單位向量,但此時(shí)這種限制是沒(méi)有必要的。上面的等式組成了一個(gè)有三個(gè)方程和三個(gè)未知數(shù)(交點(diǎn)的x、y、z坐標(biāo))的線(xiàn)性方程組。解這個(gè)方程組能得到如公式13.7所示的結(jié)果:

            如果任意一對(duì)平面平行,那么交點(diǎn)要么不存在,要么不唯一,在這種情況下,公式13.7的分母都為0。

             

            射線(xiàn)和圓/球的相交性檢測(cè)

            這里將討論2D中射線(xiàn)和圓的相交性檢測(cè),檢測(cè)的方法也適用于3D中射線(xiàn)和球之間的相交性檢測(cè),這是因?yàn)榭梢栽诎渚€(xiàn)和球心的平面中進(jìn)行檢測(cè),從而將3D問(wèn)題轉(zhuǎn)化為2D問(wèn)題。(如果射線(xiàn)包含在穿過(guò)球心的直線(xiàn)上,那么這個(gè)平面就不是唯一的。但這并不是問(wèn)題,在這種情況下我們能使用任意包含射線(xiàn)和球心的平面來(lái)進(jìn)行計(jì)算。)

            構(gòu)圖方法見(jiàn)13.8 :

            用圓心c和半徑r來(lái)定義球,射線(xiàn)的定義為:p(t) = p0 + td

            這里,d為單位向量,t從0變化到L,L為射線(xiàn)長(zhǎng)度。所要求的是交點(diǎn)處t的值:

            t = a - f

            a的計(jì)算方法如下,設(shè)e為從p0指向c的向量:

            e = c - p0

            現(xiàn)在將e投影到d,這個(gè)向量的長(zhǎng)度為a,它的計(jì)算式為:

            a = e . d

             

            兩個(gè)圓/球的相交性檢測(cè)

            兩個(gè)球的靜態(tài)測(cè)試是相對(duì)比較簡(jiǎn)單的(這里的討論對(duì)圓也適用,事實(shí)上,圖13.9中用的就是圓)。考慮由球心c1c2和半徑r1、r2定義的兩個(gè)球(如圖13.9所示)。設(shè)d為球心間的距離,很明顯,當(dāng)d < r1 + r2時(shí)它們相交。在實(shí)踐中通過(guò)比較d2 < (r1 + r2)2,可以避免包括計(jì)算d在內(nèi)的平方根運(yùn)算。

            對(duì)兩個(gè)運(yùn)動(dòng)的球進(jìn)行相交性檢測(cè)要麻煩一些。假設(shè)有兩個(gè)單獨(dú)的位移向量d1d2,球與位移向量是一一對(duì)應(yīng)的,它們描述了在所討論的時(shí)間段中球的運(yùn)動(dòng)方式。如圖13.10所示:

            從第一個(gè)球的角度來(lái)看能夠簡(jiǎn)化這個(gè)問(wèn)題,現(xiàn)在假設(shè)這個(gè)球是"靜止的",另一個(gè)球是"運(yùn)動(dòng)"的。這給出了單一的位移向量d,它等于原位移向量d2d1的差d2 - d1,如圖13.11所示:

            設(shè)靜止球由球心cs和半徑rs定義。運(yùn)動(dòng)球的半徑為rm,當(dāng)t=0時(shí),球心為cm。t不再?gòu)?變化到1,而是將d單位化,t的取值范圍從0到L,L是移動(dòng)的距離。所以在t時(shí)刻運(yùn)動(dòng)球的球心為cm + td,所要求的是當(dāng)運(yùn)動(dòng)球接觸靜止球時(shí)的t。其中的幾何關(guān)系如圖13.12所示:


            這里有一些重要的注意事項(xiàng):

            (1)如果||e|| < r,則球在t=0時(shí)就相交。

            (2)如果t<0或t>L,那么在所討論的時(shí)間段內(nèi)兩個(gè)球不會(huì)發(fā)生接觸。

            (3)如果根號(hào)內(nèi)的值是負(fù)的,那么兩個(gè)球不會(huì)相交。

             

            球和AABB的相交性檢測(cè)

            為了進(jìn)行球和AABB的靜態(tài)相交性檢測(cè),首先找到AABB中距球心最近的頂點(diǎn)。計(jì)算該點(diǎn)到球心的距離,并和球的半徑比較(實(shí)際上,比較的是距離的平方和半徑的平方,以避免平方根運(yùn)算)。如果距離小于半徑,那么球和AABB相交。


            posted on 2008-02-27 10:54 lovedday 閱讀(1085) 評(píng)論(3)  編輯 收藏 引用

            評(píng)論

            # re: 幾何檢測(cè)(3) 2008-03-14 12:20 DrawPixel

            球和AABB的相交性檢測(cè)是錯(cuò)誤的  回復(fù)  更多評(píng)論   

            # re: 幾何檢測(cè)(3) 2008-03-14 13:02 lovedday

            哪錯(cuò)呢?  回復(fù)  更多評(píng)論   

            # re: 幾何檢測(cè)(3) 2009-03-05 12:29 路人甲

            球和AABB的相交性檢測(cè),確實(shí)錯(cuò)了!  回復(fù)  更多評(píng)論   


            只有注冊(cè)用戶(hù)登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


            公告

            導(dǎo)航

            統(tǒng)計(jì)

            常用鏈接

            隨筆分類(lèi)(178)

            3D游戲編程相關(guān)鏈接

            搜索

            最新評(píng)論

            久久精品国产男包| 久久只这里是精品66| 久久精品国产亚洲αv忘忧草| 久久精品人人做人人爽电影| 久久亚洲精品无码AV红樱桃| 久久99热这里只有精品66| 99久久精品费精品国产| 久久久久99精品成人片牛牛影视| 亚洲AV无码一区东京热久久| 色播久久人人爽人人爽人人片aV | 东京热TOKYO综合久久精品| 伊人久久综合成人网| 亚洲精品乱码久久久久久中文字幕| 日韩人妻无码一区二区三区久久99| 亚洲精品NV久久久久久久久久| 久久亚洲色一区二区三区| 日日狠狠久久偷偷色综合0 | 国产精品熟女福利久久AV| 日韩精品国产自在久久现线拍| 亚洲乱亚洲乱淫久久| 久久免费99精品国产自在现线 | 久久久久AV综合网成人 | 99久久免费国产精品热| 国产精品久久成人影院| A级毛片无码久久精品免费| 久久人人爽人人爽人人片AV麻豆 | 久久国产乱子精品免费女| 欧美久久综合性欧美| 久久亚洲国产精品123区| 免费精品久久天干天干| 2021精品国产综合久久| 99精品久久久久久久婷婷| 一级A毛片免费观看久久精品| 伊人久久精品无码二区麻豆| 久久成人影院精品777| 人妻系列无码专区久久五月天| 亚洲AV日韩精品久久久久久| 久久er热视频在这里精品| 久久人妻无码中文字幕| 色综合久久中文综合网| 亚洲国产香蕉人人爽成AV片久久|