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

牽著老婆滿街逛

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

計算三角形網格的tangent space

轉載自:http://absolute.javaeye.com/blog/213872

     又一篇學習筆記,參考Mathematics for 3D Game Programming and Computer Graphics和ShaderX4上一篇關于tangent space計算的文章寫的東西。對于計算時需要分裂頂點的內容看的還不是太清楚-_-b。另外,目前的算法還不能完美處理鏡像或者在紋理不連續處可能出現的問題,就算在Farcry中,很多問題也是通過美工來“隱藏”的,再一次應證了之前對美工重要性的結論^^。

 

 

 

 

 算法:

      Tangent spaceBump Map中有著重要作用,通常需要把燈光轉換到tangent space進行計算。對由參數方程計算出的規則曲面(比如,球體,圓環)來說,很容易通過方程計算出tangent space,但對任意的三角形網格來說,則沒有那么簡單。

Tangent space是一個三維空間。對3D空間中的一個頂點來說,切空間的三條座標軸分別對應該點的法線N,切線T,和副法線(binormalB,顯然,對不同的頂點來說,切空間是不同的。那么在已知三角形三個頂點及其紋理坐標的時候,如何計算出NTB呢?

目前已知的數據有三角形的三個頂點在世界坐標中的位置: P0, P1,P2, 以及相應的紋理坐標在紋理空間中的位置C0 (U0,V0)C1C2,則有:

 

P10 = P1 – P0

P­20 = P2 - P1 ,

C10 = C1 – C0 = (U1-U0, V1-V0) = ( U10 ,V10)

C20 = C2 – C0.= (U2-U0, V2-V0) = ( U20 ,V20)

 

注意,P10在世界坐標中的方向和C10在紋理空間中的方向是一致的(這一點確實比較抽象,偶畫圖研究了好久才弄明白-_-),同樣,20C20也是如此,發現這一點很重要,可以說是整個計算的基石。進一步來說,TB分別和紋理坐標軸UV是平行的。因此我們有:

 

P10 = U10T + V10B

P­20 = U20T + V20B

把矢量展開得到:

 

兩邊乘以[C10 C20]的逆矩陣,最后得到

 

法線N = T x B

這樣我們就得到了坐標從切空間轉變到世界坐標下的變換矩陣M = [ T B N ],當然,更加常用的是M的逆矩陣。注意,這里計算得出的只是面法線,如果需要計算每個頂點的法線,則應該對共享該頂點的多個面的法線取均值,求出結果。

 

實現:

 ogre calculate tangent:

Vector3 Math::calculateTangentSpaceVector(
 
const Vector3& position1, const Vector3& position2, const Vector3& position3,
 Real u1, Real v1, Real u2, Real v2, Real u3, Real v3)
 
{
   
//side0 is the vector along one side of the triangle of vertices passed in, 
   
//and side1 is the vector along another side. Taking the cross product of these returns the normal.
   Vector3 side0 = position1 - position2;
   Vector3 side1 
= position3 - position1;
   
//Calculate face normal
   Vector3 normal = side1.crossProduct(side0);
   normal.normalise();
   
//Now we use a formula to calculate the tangent. 
   Real deltaV0 = v1 - v2;
   Real deltaV1 
= v3 - v1;
   Vector3 tangent 
= deltaV1 * side0 - deltaV0 * side1;
   tangent.normalise();
   
//Calculate binormal
   Real deltaU0 = u1 - u2;
   Real deltaU1 
= u3 - u1;
   Vector3 binormal 
= deltaU1 * side0 - deltaU0 * side1;
   binormal.normalise();
   
//Now, we take the cross product of the tangents to get a vector which 
   
//should point in the same direction as our normal calculated above. 
   
//If it points in the opposite direction (the dot product between the normals is less than zero), 
   
//then we need to reverse the s and t tangents. 
   
//This is because the triangle has been mirrored when going from tangent space to object space.
   
//reverse tangents if necessary
   Vector3 tangentCross = tangent.crossProduct(binormal);
   
if (tangentCross.dotProduct(normal) < 0.0f)
   
{
     tangent 
= -tangent;
     binormal 
= -binormal;
   }


 
return tangent;

 }

posted on 2008-12-09 04:37 楊粼波 閱讀(781) 評論(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| 一区二区三区**美女毛片| 欧美亚洲在线| 亚洲一区中文字幕在线观看| 国产免费成人在线视频| 久久久亚洲午夜电影| 另类亚洲自拍| 一区二区高清视频| 亚洲欧美韩国| 狠狠色狠色综合曰曰| 欧美高清不卡在线| 欧美女同在线视频| 中文有码久久| 性色av一区二区三区在线观看| 国产日韩在线一区| 欧美mv日韩mv亚洲| 女仆av观看一区| 亚洲视频精品| 久久亚洲春色中文字幕久久久| 亚洲片国产一区一级在线观看| 亚洲素人在线| 亚洲福利电影| 亚洲欧美日韩精品综合在线观看 | 欧美国产三级| 欧美综合国产| 欧美精品成人| 麻豆视频一区二区| 欧美视频一区在线观看| 老司机凹凸av亚洲导航| 欧美久久婷婷综合色| 性欧美超级视频| 欧美激情中文字幕在线| 午夜精品一区二区三区在线视| 久久尤物视频| 久久精品国产77777蜜臀| 欧美好吊妞视频| 久久综合图片| 国产亚洲欧美一区| 在线一区日本视频| 日韩视频亚洲视频| 久久久久88色偷偷免费| 日韩一区二区高清| 一区二区三区www| 亚洲国产一成人久久精品| 午夜精品久久久久久久99水蜜桃| 99日韩精品| 欧美成人国产va精品日本一级| 久久久www成人免费精品| 欧美日韩在线第一页| 亚洲国产专区校园欧美| 国产亚洲va综合人人澡精品| 亚洲综合成人在线| 亚洲自拍偷拍色片视频| 欧美三级精品| 亚洲三级色网| 在线看无码的免费网站| 亚洲美女免费精品视频在线观看| 亚洲区欧美区| 欧美—级在线免费片| 亚洲第一页在线| 精东粉嫩av免费一区二区三区| 性欧美长视频| 久久久精品免费视频| 国内精品**久久毛片app| 欧美一级理论片| 久久久久久久久久久久久女国产乱 | 国产精品av久久久久久麻豆网 | 久久成人精品无人区| 国产精品美女久久福利网站| 一本一本久久a久久精品牛牛影视| 99国产精品久久久久久久| 欧美日韩精品免费看| 亚洲美女精品一区| 亚洲一区二区三区精品动漫| 国产精品激情av在线播放| 一区二区电影免费观看| 亚洲欧美成人网| 国产乱肥老妇国产一区二| 性色av一区二区三区红粉影视| 久久久国际精品| 亚洲国产成人精品女人久久久| 欧美激情a∨在线视频播放| 亚洲美女精品成人在线视频| 性色av一区二区三区在线观看| 国产精品综合网站| 久久久国产精品一区| 亚洲国产欧美一区| 亚洲自拍高清| 在线免费观看视频一区| 欧美日本国产| 欧美一区二区三区在线视频 | 免费亚洲一区二区| 一片黄亚洲嫩模| 国产欧美日韩视频一区二区三区| 久久精品亚洲一区| 亚洲三级影院| 久久免费视频在线观看| 日韩一区二区精品葵司在线| 国产精品免费一区二区三区在线观看 | 老司机免费视频一区二区| 最新中文字幕一区二区三区| 国产精品视频男人的天堂| 久久人人九九| 亚洲一区二区三区四区五区午夜| 老牛嫩草一区二区三区日本| 制服诱惑一区二区| 黄色欧美日韩| 国产精品国产自产拍高清av王其| 久久久久久久97| 亚洲欧美国内爽妇网| 亚洲精品乱码| 免费观看亚洲视频大全| 亚洲欧美精品一区| 夜夜嗨av色综合久久久综合网| 国内精品久久久| 国产精品国产自产拍高清av王其| 欧美成黄导航| 久久人人超碰| 性色一区二区三区| 亚洲伊人色欲综合网| 亚洲人成人99网站| 麻豆成人av| 久久久亚洲午夜电影| 亚洲午夜在线观看视频在线| 亚洲第一免费播放区| 国产精品久久久久久久久久免费| 狼狼综合久久久久综合网| 欧美一区午夜精品| 亚洲一区二区网站| 一区二区欧美激情| 亚洲精品人人| 亚洲国产精品第一区二区| 美女视频黄a大片欧美| 久久天天躁狠狠躁夜夜av| 欧美一级久久| 午夜精品视频在线| 午夜精品999| 亚洲自拍另类| 亚洲一级免费视频| 亚洲在线观看视频| 亚洲国产另类精品专区| 亚洲国产精品va在线看黑人动漫| 精品1区2区| 亚洲国产高清一区| 亚洲国产精品传媒在线观看| 亚洲国产精品嫩草影院| 伊人久久婷婷色综合98网| 国产欧美一区二区精品仙草咪| 欧美88av| 欧美日韩精品一区视频| 久久精品亚洲精品| 亚洲男人第一网站| 性色av一区二区三区在线观看| 欧美在线资源| 久久成人羞羞网站| 久久女同互慰一区二区三区| 久久亚洲影音av资源网| 欧美一区二区在线观看| 亚洲精品综合| 亚洲网站视频福利| 午夜视黄欧洲亚洲| 久久成人一区二区| 欧美www视频在线观看| 欧美日韩国产限制| 国产精品视频男人的天堂 | 老司机成人网| 欧美日韩在线电影| 国产深夜精品福利| 亚洲人成在线免费观看| 亚洲视频导航| 久久福利视频导航| 亚洲成人在线网| 一本久久青青| 久久久久久一区| 欧美精品一区在线发布| 国产欧美日韩视频一区二区三区| 狠狠色狠狠色综合日日91app| 日韩午夜电影在线观看| 羞羞视频在线观看欧美| 蜜桃av一区| 99视频在线观看一区三区| 久久精品人人做人人爽| 欧美成人精品h版在线观看| 国产精品美女黄网| 亚洲欧洲在线一区| 欧美一区三区二区在线观看| 欧美激情a∨在线视频播放| 亚洲午夜一区| 欧美大香线蕉线伊人久久国产精品| 国产精品久久久久一区| 在线观看视频一区| 午夜精品久久久久久久久久久久久| 老鸭窝91久久精品色噜噜导演| 9久re热视频在线精品| 久久亚洲高清| 国产日本精品| 亚洲一二三区精品| 欧美大片免费看| 久久国产精品久久久久久电车| 欧美精品在线观看91|