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

牽著老婆滿街逛

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

計(jì)算三角形網(wǎng)格的tangent space

轉(zhuǎn)載自:http://absolute.javaeye.com/blog/213872

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

 

 

 

 

 算法:

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

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

目前已知的數(shù)據(jù)有三角形的三個頂點(diǎn)在世界坐標(biāo)中的位置: P0, P1,P2, 以及相應(yīng)的紋理坐標(biāo)在紋理空間中的位置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在世界坐標(biāo)中的方向和C10在紋理空間中的方向是一致的(這一點(diǎn)確實(shí)比較抽象,偶畫圖研究了好久才弄明白-_-),同樣,20C20也是如此,發(fā)現(xiàn)這一點(diǎn)很重要,可以說是整個計(jì)算的基石。進(jìn)一步來說,T,B分別和紋理坐標(biāo)軸U,V是平行的。因此我們有:

 

P10 = U10T + V10B

P­20 = U20T + V20B

把矢量展開得到:

 

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

 

法線N = T x B

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

 

實(shí)現(xiàn):

 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 楊粼波 閱讀(788) 評論(0)  編輯 收藏 引用


只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   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视频+国产日韩欧美| 欧美在线一二三| 国产欧美在线看| 久久九九99| 久久久精品久久久久| 亚洲高清久久久| 最新成人av网站| 欧美三区在线| 久久激情久久| 美女脱光内衣内裤视频久久网站| 亚洲黄色免费电影| 亚洲精品视频啊美女在线直播| 欧美日韩一区二区欧美激情| 亚洲免费一在线| 欧美一区影院| 亚洲精品久久久蜜桃| 一本色道久久88综合亚洲精品ⅰ| 国产日产精品一区二区三区四区的观看方式 | 国产精品乱码久久久久久| 欧美在线视频播放| 久久在线播放| 一区二区三区欧美成人| 午夜久久一区| 日韩视频不卡| 性欧美激情精品| 亚洲区在线播放| 午夜精品影院在线观看| 亚洲经典一区| 亚洲欧美色一区| 亚洲精品久久久久中文字幕欢迎你| 亚洲免费观看高清完整版在线观看熊| 久久国产精品99精品国产| 久久国产黑丝| 亚洲欧美国产日韩天堂区| 久久这里有精品15一区二区三区| 亚洲天堂黄色| 欧美不卡一区| 毛片一区二区三区| 国产欧美三级| 一二三区精品| 99这里只有久久精品视频| 久久精品久久99精品久久| 亚洲在线观看视频网站| 欧美大片在线观看一区二区| 久久久久9999亚洲精品| 国产精品va在线播放| 亚洲电影第三页| 狠狠色综合色区| 先锋影音国产一区| 亚洲欧美中文字幕| 欧美日韩一区在线| 亚洲人成网站999久久久综合| 红桃视频国产一区| 性欧美18~19sex高清播放| 亚洲一区二区在线看| 欧美刺激性大交免费视频 | 亚洲精品久久久久久久久| 欧美亚洲免费| 亚洲欧美在线免费观看| 欧美日韩一级片在线观看| 亚洲国产高清一区二区三区| 激情自拍一区| 久久久久久久综合| 久久天天躁夜夜躁狠狠躁2022 | 国产日韩欧美一区二区| 一区二区三区四区五区在线| 一本色道久久综合亚洲精品按摩| 嫩草国产精品入口| 最新中文字幕一区二区三区| 亚洲欧洲精品一区二区三区波多野1战4 | 夜夜嗨一区二区| 亚洲一级二级| 国产精品任我爽爆在线播放 | 91久久国产综合久久| 亚洲人成艺术| 欧美了一区在线观看| 亚洲免费观看| 欧美一级理论片| 国产主播精品在线| 久久青青草综合| 亚洲人体1000| 午夜激情综合网| 国产亚洲精品久久久久婷婷瑜伽 | 亚洲精品乱码久久久久久蜜桃麻豆 | 国产精品亚洲美女av网站| 亚洲欧美激情视频| 久久久人人人| 亚洲人成人一区二区在线观看| 欧美精品亚洲二区| 亚洲自拍三区| 欧美国产一区视频在线观看| 99在线|亚洲一区二区| 国产精品女人久久久久久| 久久精品网址| 日韩午夜在线播放| 久久国产乱子精品免费女 | 欧美另类在线观看| 亚洲欧美日韩精品| 欧美激情综合| 午夜免费日韩视频| 亚洲第一网站免费视频| 国产精品大片wwwwww| 久久久精品国产99久久精品芒果| 亚洲欧洲精品一区二区三区| 午夜亚洲影视| 日韩视频一区二区三区在线播放| 国产精品视频一二三| 欧美成人乱码一区二区三区| 亚洲一区国产| 亚洲区第一页| 麻豆成人精品| 欧美一级片在线播放| av成人免费观看| 在线不卡亚洲| 国产亚洲精品bt天堂精选| 欧美久久久久免费| 狂野欧美性猛交xxxx巴西| 亚洲免费影视第一页| 亚洲精品影视在线观看| 欧美成人免费小视频| 久久福利视频导航| 亚洲欧美激情一区| 一区二区三区高清在线| 亚洲国产合集| 伊人久久婷婷| 国产在线观看精品一区二区三区| 欧美日韩中国免费专区在线看| 免费视频一区| 久久在线精品| 久久婷婷国产综合精品青草| 性欧美大战久久久久久久久| 亚洲在线国产日韩欧美| 亚洲精选视频在线| 欧美黄色aaaa| 亚洲大胆美女视频| 女女同性精品视频| 嫩草伊人久久精品少妇av杨幂| 久久久免费精品视频| 欧美在线视频免费播放| 欧美亚洲在线| 欧美一区二区三区免费在线看| 亚洲欧美在线aaa| 亚洲女人小视频在线观看| 亚洲小视频在线| 午夜电影亚洲| 欧美在线综合| 久久亚洲私人国产精品va| 久久蜜桃精品| 欧美承认网站| 亚洲国产日韩欧美| 亚洲毛片av| 亚洲网在线观看| 亚洲欧美高清| 久久噜噜噜精品国产亚洲综合| 久久久蜜桃一区二区人| 狂野欧美激情性xxxx欧美| 欧美成人免费在线观看| 欧美激情在线播放| 国产精品www994| 国产主播一区二区三区四区| 激情国产一区| 亚洲精品欧美| 亚洲欧美日韩国产中文| 久久高清免费观看| 欧美顶级艳妇交换群宴| 亚洲人体影院| 国产精品99久久99久久久二8| 亚洲欧美日韩国产成人| 久久久久久91香蕉国产| 欧美国产先锋| 国产精品一区亚洲| 亚洲国产成人精品女人久久久| 亚洲理伦在线| 久久精品天堂| 亚洲精品国产精品国自产观看| 亚洲无玛一区| 老牛国产精品一区的观看方式| 欧美日韩三级视频| 狠久久av成人天堂| 一区二区三区欧美在线| 久久久久久久综合狠狠综合| 亚洲国产三级| 欧美一区二区三区四区高清| 欧美wwwwww| 国产在线精品二区| 一区二区三区四区国产| 久久综合影视| 亚洲自拍高清| 欧美另类久久久品| 伊人男人综合视频网| 午夜精品www| 亚洲激情电影在线| 久久久av毛片精品| 国产精品一区免费观看| aa级大片欧美三级| 欧美第一黄网免费网站| 欧美在线高清| 国产精品网站在线| 亚洲一区二区三区精品在线观看|