• <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ǎo)航

            <2008年12月>
            30123456
            78910111213
            14151617181920
            21222324252627
            28293031123
            45678910

            統(tǒng)計(jì)

            常用鏈接

            留言簿(12)

            隨筆分類

            隨筆檔案

            Friends

            WebSites

            積分與排名

            最新隨筆

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            鏡面反射矩陣推導(dǎo)

            最近公司游戲正在準(zhǔn)備上線,所以FlasCC也就沒(méi)有研究了,偶爾有閑功夫,也是玩玩3DMAX和UNITY3D。 感覺(jué)不會(huì)3DMAX,是一種局限。

            回到主題,記錄一下鏡面反射矩陣的推導(dǎo)。

            在用Irrlicht和RTT做鏡面效果的時(shí)候,用到了反射矩陣。 就是需要把攝相機(jī)鏡像,渲染一個(gè)RT,貼到鏡面模型上。這個(gè)其實(shí)還糾結(jié)了許久,因?yàn)橹白鏊驿秩镜臅r(shí)候,水面是平的,很好計(jì)算攝相機(jī)在水面以下的位置。 但是換成鏡面,就不一樣了,因?yàn)殓R面可能是任意面。 于是就需要一個(gè)通用的反射矩陣。

            反射矩陣的計(jì)算是基于平面的,因?yàn)椋魏畏瓷洌夹枰粋€(gè)反射面。

            所以,我們先給出平面表示 Plane(nx,ny,nz,d); 其中(nx,ny,nz)已經(jīng)單位化。

            然后,我們假設(shè)空間中有任意一點(diǎn)P(x,y,z,1)

            設(shè)這個(gè)點(diǎn)P以Plane為反射面的鏡像點(diǎn)為P1(x1,y1,z1,w)。

             

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

            根據(jù)定理,我們知道, 若兩個(gè)點(diǎn)以某一點(diǎn)為鏡像,則兩個(gè)點(diǎn)的坐標(biāo)之和除以2,就剛好是中點(diǎn)。

            這個(gè)理論我們用到這里的話, 那這個(gè)中點(diǎn)就剛好是平面上的一個(gè)點(diǎn)。 平面上的這個(gè)點(diǎn)就是 P(x,y,z,1) - (nx,ny,nz,0)*D .  其中D就是點(diǎn)P到平面的距離

            而D=Plane dot P = (x*nx+y*ny+z*nz+d);

            由上面的描述,我們馬上想到,那么要求點(diǎn)P1的話,就是這樣 

            (P+P1)/2 = P(x,y,z,1) - (nx,ny,nz,0)*D

            => P1 = P(x,y,z,1) - 2(nx,ny,nz,0)*D

            =>P1 = P(x,y,z,1) - 2(nx,ny,nz,0)*(x*nx+y*ny+z*nz+d)

             

            換成矩陣形式則為

                                        |1-2*nx*nx   -2*nx*ny         -2*nx*nz         0  |

                                         | -2*ny*nx     1 - 2*ny*ny     -2*ny*nz         0  |

            P1 = {x,y,z,1}   x   | -2*nz*nx     -2*nz*ny         1-2*nz*nz        0  |

                                         | -2*d*nx      -2*d*ny           -2*d*nz           1  |

             

            大功告成

            btw:這是行主矩陣表示法

            posted on 2013-06-15 00:48 麒麟子 閱讀(9687) 評(píng)論(2)  編輯 收藏 引用 所屬分類: ProgrammingGPU and GraphicGame and Engine

            評(píng)論

            # re: 鏡面反射矩陣推導(dǎo) 2013-11-04 10:24 ITboy_Lemon

            博主,最近看到你的帖子,但是對(duì)最后一步不是太明白,
            怎么從
            P1 = P(x,y,z,1) - 2(nx,ny,nz,0)*(x*nx+y*ny+z*nz+d)
            推導(dǎo)出變換矩陣的。
            通過(guò)矩陣運(yùn)算的話,要用到逆矩陣,可是{x,y,z,1}并不是可逆的啊???
            不是太懂線性代數(shù),能給點(diǎn)解釋嗎?或者給點(diǎn)資料也可以  回復(fù)  更多評(píng)論   

            # re: 鏡面反射矩陣推導(dǎo) 2014-05-22 10:53 Anonymous

            博主的推導(dǎo)基本都是正確的,但是最后一步錯(cuò)誤了,正確形式是P(x,y,z,1) - 2 * (x*nx + y*ny + z*na +d) * (nx, ny, nz, 0)T(就是矩陣的tranpose)
            合并得到P(x, y, z, 1) * (1 - 2 * (nx, ny, nz, d) * (nx, ny, nz, 1)T), 把1變成4x4單位矩陣I, 即可得到博主的答案了。  回復(fù)  更多評(píng)論   

            国产69精品久久久久9999| 97超级碰碰碰碰久久久久| 久久精品?ⅴ无码中文字幕| 狠狠狠色丁香婷婷综合久久俺| 久久精品国产日本波多野结衣| 亚洲成av人片不卡无码久久| 亚洲嫩草影院久久精品| 久久er国产精品免费观看2| 91精品国产高清久久久久久io| 久久久噜噜噜www成人网| 精品久久久久久成人AV| 精品久久久久久亚洲| 麻豆精品久久久一区二区| 国产精品永久久久久久久久久| 久久精品一区二区三区中文字幕 | 狠狠狠色丁香婷婷综合久久五月| 99久久国产热无码精品免费| 99国产欧美精品久久久蜜芽| 久久久久AV综合网成人| 国产精品久久久久久久| 国产精品成人久久久久三级午夜电影| 久久国产成人午夜AV影院| 久久国产三级无码一区二区| 久久影院午夜理论片无码| 国产精品美女久久福利网站| 无码人妻久久一区二区三区免费| 99精品国产在热久久| 成人午夜精品久久久久久久小说| 亚洲色欲久久久久综合网 | 人妻精品久久无码专区精东影业 | 久久久精品免费国产四虎| 久久影院午夜理论片无码| 久久香蕉超碰97国产精品 | 久久久久国产精品嫩草影院| 久久天天躁狠狠躁夜夜躁2O2O| 日本精品久久久久中文字幕8| 日韩电影久久久被窝网| 久久精品亚洲一区二区三区浴池| 国产无套内射久久久国产| 丁香色欲久久久久久综合网| 99热成人精品热久久669|