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

牽著老婆滿街逛

嚴以律己,寬以待人. 三思而后行.
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 楊粼波 閱讀(790) 評論(0)  編輯 收藏 引用


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产亚洲激情在线| 国产精品青草久久久久福利99| 国产欧美精品日韩| 亚洲欧美欧美一区二区三区| 一区二区精品| 国产精品久久亚洲7777| 亚洲综合日韩在线| 午夜精品福利一区二区三区av | 欧美sm极限捆绑bd| 毛片av中文字幕一区二区| 亚洲国产精品专区久久| 欧美激情中文字幕乱码免费| 欧美精品自拍偷拍动漫精品| 在线综合+亚洲+欧美中文字幕| 一区二区精品| 激情一区二区三区| 亚洲第一色在线| 欧美另类videos死尸| 亚洲综合成人婷婷小说| 欧美中文字幕不卡| 亚洲男女自偷自拍| 亚洲欧洲av一区二区| 国产日产亚洲精品| 亚洲国产成人久久| 国产麻豆9l精品三级站| 毛片一区二区三区| 欧美日韩专区| 老司机成人网| 欧美特黄a级高清免费大片a级| 久久精品国产一区二区三| 免费观看一级特黄欧美大片| 亚洲一区三区电影在线观看| 久久久精品午夜少妇| 99精品视频免费| 久久久精品一品道一区| 亚洲一二三四久久| 老司机午夜免费精品视频| 亚洲免费网站| 欧美大片一区二区三区| 欧美在线一级视频| 欧美日韩免费在线视频| 久久综合伊人77777蜜臀| 欧美日韩在线一区二区三区| 美脚丝袜一区二区三区在线观看| 国产精品大片免费观看| 亚洲国产黄色片| 韩国亚洲精品| 亚洲欧美日韩在线观看a三区| 最新国产の精品合集bt伙计| 欧美一区二区三区四区夜夜大片 | 亚洲日本理论电影| 久久精品成人一区二区三区蜜臀| 亚洲一区二区三区中文字幕在线| 久久综合九色| 麻豆精品在线观看| 国产欧美视频在线观看| 国产精品99久久久久久久vr | 国产精品高清在线观看| 最新热久久免费视频| 136国产福利精品导航网址应用| 亚洲在线视频观看| 亚洲性人人天天夜夜摸| 欧美日韩国产成人在线免费| 欧美国产激情| 91久久综合亚洲鲁鲁五月天| 久久这里有精品视频| 男女精品网站| 91久久精品国产91久久| 免费看亚洲片| 亚洲国产裸拍裸体视频在线观看乱了| 亚洲国产激情| 男男成人高潮片免费网站| 女人香蕉久久**毛片精品| 在线观看91精品国产麻豆| 久久中文久久字幕| 欧美国产日韩一区二区三区| 亚洲黄色成人久久久| 免费看亚洲片| 亚洲美女色禁图| 亚洲午夜日本在线观看| 国产精品久久久999| 亚洲女优在线| 久久久久国产免费免费| 在线观看欧美日本| 一片黄亚洲嫩模| 欧美欧美天天天天操| 一区二区三区视频观看| 午夜在线视频观看日韩17c| 国产日韩欧美麻豆| 久久综合影音| 99香蕉国产精品偷在线观看| 性感少妇一区| 亚洲国产二区| 欧美日韩亚洲综合一区| 欧美亚洲专区| 亚洲日韩成人| 久久99在线观看| 亚洲国产精品一区二区尤物区| 欧美激情视频免费观看| 亚洲一区二区三区精品视频 | 亚洲电影在线免费观看| 欧美精品一区二区三区在线看午夜 | 激情婷婷亚洲| 欧美日韩国产欧| 西瓜成人精品人成网站| 亚洲第一页在线| 欧美一级二级三级蜜桃| 亚洲大胆av| 国产精品人人做人人爽人人添| 老司机67194精品线观看| 亚洲天堂男人| 亚洲国产婷婷| 久久久久国产一区二区三区| 9l视频自拍蝌蚪9l视频成人| 国产在线一区二区三区四区 | 欧美日韩国产一区| 久久爱另类一区二区小说| 亚洲欧洲日产国产综合网| 久久精品国产亚洲精品| 亚洲图片欧美日产| 亚洲国产精品一区二区www| 国产欧美一区二区三区国产幕精品| 免费日韩精品中文字幕视频在线| 亚洲欧美网站| 亚洲线精品一区二区三区八戒| 欧美激情精品| 久久久久久夜精品精品免费| 亚洲一区视频在线| 亚洲理论电影网| 亚洲第一天堂av| 一区三区视频| 国内自拍一区| 国产无一区二区| 国产精品资源| 国产精品女主播在线观看 | 亚洲桃花岛网站| 亚洲精品看片| 亚洲美女视频在线观看| 亚洲国产美女| 亚洲国产你懂的| 欧美成人一区在线| 免费在线欧美视频| 快播亚洲色图| 美女网站久久| 久久综合久久综合久久| 久久久噜噜噜久久狠狠50岁| 欧美专区日韩专区| 欧美一区二区三区视频在线观看| 亚洲免费视频中文字幕| 销魂美女一区二区三区视频在线| 亚洲在线第一页| 午夜精品视频网站| 欧美一区三区三区高中清蜜桃| 欧美一区二区视频97| 香蕉久久夜色精品国产| 老司机成人在线视频| 蜜桃久久av一区| 欧美激情精品久久久久久免费印度 | 亚洲激情电影在线| 99热精品在线| 午夜在线精品偷拍| 久久久久国产一区二区三区四区 | 久久久综合香蕉尹人综合网| 久久久久久久成人| 欧美大片免费观看| 亚洲伦理在线| 亚洲免费影院| 久久午夜电影网| 欧美日韩国产区| 国产日韩精品在线| 亚洲电影免费在线观看| 99视频精品| 久久精品盗摄| 亚洲国产成人高清精品| 中文在线不卡视频| 久久久免费观看视频| 欧美日韩一区不卡| 国产午夜精品全部视频播放| 亚洲二区在线观看| 亚洲一区在线观看免费观看电影高清| 欧美有码视频| 亚洲国产影院| 午夜欧美精品| 麻豆国产va免费精品高清在线| 欧美日韩中文字幕| 一区在线播放视频| 在线亚洲一区观看| 久久女同互慰一区二区三区| 亚洲日产国产精品| 久久另类ts人妖一区二区| 欧美精品国产精品| 激情小说另类小说亚洲欧美| 亚洲女性裸体视频| 欧美成人午夜激情在线| 国产精品99久久久久久人 | 亚洲黑丝在线| 久久国产精品一区二区| 国产精品swag| 99re6这里只有精品| 免费短视频成人日韩|