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

            月下的博客

              C++博客 :: 首頁 :: 聯(lián)系 :: 聚合  :: 管理
              34 Posts :: 0 Stories :: 59 Comments :: 0 Trackbacks

            常用鏈接

            留言簿(5)

            我參與的團隊

            搜索

            •  

            最新評論

            • 1.?re: 五年感想
            • 5年一轉(zhuǎn)眼,我已經(jīng)進入工作的第9個年頭了,缺少的是思考,一直安于現(xiàn)狀,也該反思了
            • --liquanhai
            • 2.?re: 五年感想
            • 認為是設(shè)計-》現(xiàn)在轉(zhuǎn)變?yōu)槿?!
            • --linda
            • 3.?re: 五年感想
            • 決定游戲成功的因素
            • --linda
            • 4.?re: 五年感想
            • 果真人會沉淀是真的
            • --張恒
            • 5.?re: 五年感想
            • 樓主 最近股市大漲
              希望你能再接再厲
              再創(chuàng)輝煌
            • --ccsdu2009

            閱讀排行榜

            評論排行榜

               這兩天在準備面試,然后復(fù)習(xí)了下數(shù)學(xué)的東西,好多東西以前基礎(chǔ)不好,就是走馬觀花的看一下,過了一段時間立馬就忘記了,索性記下來的好。這里的3D空間都是右手坐標系,向量為列為主
            一,法線變換乘WorldView矩陣的逆的轉(zhuǎn)置
            肯定不是直接乘worldView矩陣了,推導(dǎo)其實很簡單,(像我這樣腦子不行的只能看完了感慨了)設(shè)原mesh上一個頂點為v,其法線為n,WorldViewMatrix為Mwv,那么在object space里,滿足v dot n == 0,以此我們可以換個形式表示,也就是(v)T * n == 0, (1x4和4x1的矩陣相乘實際就是點乘了),那么在變換之后,設(shè)變化后的頂點為v',變換后的法線為n',那么同樣也需要滿足這個條件,
            (v')T * n' == 0, 而v' = Mwv * v,
            代入=> (Mwv * v)T * n' == 0 =>  vT * MwvT * n'  == 0,  而n'等于Mn * n(我們要求的),
            =>vT * (MwvT * Mn )* n == 0 ,而(v)T * n == 0, 那么中間的(MwvT * Mn )== I => Mn = (MwvT)-1,而因為方陣(當然得有逆的情況。。)的逆的轉(zhuǎn)置等于轉(zhuǎn)置的逆,所以就能證明出來咯~。我剛想了下,應(yīng)該行為主的結(jié)果也是一樣的,這里錯了話,望糾正。


            二,判斷點是否在三角形內(nèi)準備筆試的時候正好看到這道題,以前在ogre代碼里也看到過,但原理沒深究過,google中文搜了下,貌似沒什么講的很好的,英文一搜就搜到了很多非常詳細的。這里就做個整理吧,省得和我一樣的搜兩次了~~。設(shè)三角形ABC,點為P,(向量我就寫成行形式了~)
            1,面積法,基本上是最直接低效的,點P如果在三角形內(nèi),則分割的三個三角形面積和等于ABC面積,這個不說了。
            2,網(wǎng)上最常見的,所謂的2D叉乘法,實際上叉乘是不存在于2D空間的,只存在于3D和7D(!。。這個沒細看。反正wiki還是哪里看到的),但2D空間里我們可以用一點小技巧,就是假設(shè)一個垂直于xy平面的z軸,那么2D平面的z值則一直為0,設(shè) 向量B-A為V1(x1,y1,z1),向量P-A為V2(x2,y2,z2),根據(jù)3D叉乘公式,(x1,y1,z1)  X (x2,y2,z2) = (y1z2 - y2z1, x1z2-x2z1, x1y2-x2y1),由于z為0,那么x,y則為0,所以實際2d叉乘值就是z值,其實我們得到的還是一個向量,它垂直于我們2d空間的xy平面,不管是順時針還是逆時針,我們只要按一個方向同樣再對另外兩邊做同樣的叉乘,只要得到的這三個值符號一致,這就說明點P在三角形三邊的同一側(cè),也就是在三角形內(nèi)了,其實再想想,只需要確定在兩條邊的同側(cè),那么就是在三角形內(nèi)了。
            3,重心法,從二維空間上看,我們可以把p當乘以以三角形一個頂點的兩條邊向量乘以兩個標量權(quán)重的和,設(shè)這兩個權(quán)重為u,v,只要u,v大于0,且和小于1,那么P就在三角形內(nèi),所以我們下來就是求出u,v了:
            =>P = A +  u * (C - A)+ v * (B - A), u,v這也就是三角形的重心坐標系坐標,這就是個二元一次方程,這里我們化簡下,設(shè)P-A為v2, C - A為v0,B - A為v1,
             =>v2 = u * v0 + v*v1, 乘v0,v1我們就能得到兩個方程
            =>v2 * v0 = (u * v0 + v*v1)* v0, (1)
                v2 * v1 = (u * v0 + v*v1)* v1, (2)
            略化簡。。
            =>u = ((v1 * v1)(v2 * v0) - (v1 * v0)(v2 * v1))/(((v0 * v0)(v1 * v1) - (v0 * v1)(v1 * v0))
            v = ((v0 * v0)(v2 * v1) - (v0 * v1)(v2 * v0))/(((v0 * v0)(v1 * v1) - (v0 * v1)(v1 * v0))
            posted on 2011-04-03 20:26 月下圓舞曲 閱讀(498) 評論(0)  編輯 收藏 引用 所屬分類: 開發(fā)
            国产麻豆精品久久一二三| 国产亚洲精品久久久久秋霞| 久久免费视频观看| 国产精品久久毛片完整版| 国产精品VIDEOSSEX久久发布| 久久青青草原精品国产不卡| 亚洲国产日韩欧美久久| 国产亚洲美女精品久久久2020| 狠狠干狠狠久久| 亚洲va久久久久| 久久综合欧美成人| 欧美精品国产综合久久| 久久精品成人国产午夜| 噜噜噜色噜噜噜久久| 97精品国产97久久久久久免费| 久久婷婷人人澡人人爽人人爱| 国产精品久久久久久| 一本一道久久综合狠狠老| 国产一区二区精品久久凹凸 | 久久精品国产91久久麻豆自制 | 亚洲综合熟女久久久30p| 一级做a爱片久久毛片| 亚洲AV无码久久寂寞少妇| 久久天天躁狠狠躁夜夜2020老熟妇 | 精品久久久久久中文字幕人妻最新| 久久WWW免费人成—看片| 99久久99这里只有免费费精品 | 97久久超碰国产精品2021| 国产精品久久久香蕉| 性做久久久久久久久久久| 97精品伊人久久久大香线蕉| 成人资源影音先锋久久资源网| 亚洲午夜久久久久妓女影院 | 久久无码专区国产精品发布| 一级做a爰片久久毛片16| 久久久久亚洲AV成人片| 久久精品国产亚洲AV无码娇色| 国产成年无码久久久免费| 久久久高清免费视频| 久久国产欧美日韩精品免费| 亚洲欧美精品一区久久中文字幕|