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

            WOW地形Shader分析(轉)

            SPXG // 標識
            // 用到5張圖片:
            {
               blendTexture  = 0
               layer0Texture = 1
               layer1Texture = 2
               layer2Texture = 3
               layer3Texture = 4
            }
            !!ARBfp1.0
            // 定義常量:
            PARAM c[1] = { { 1, 0.30000001, 0.69999999 } };
            // 聲明3個寄存器:
            TEMP R0;
            TEMP R1;
            TEMP R2;
            // 開始混合:
            // 一.第0層和第1層使用第4張圖的x通道作為alpha進行混合:
            TEX R1, fragment.texcoord[0], texture[0], 2D;
            TEX R0, fragment.texcoord[1], texture[1], 2D;
            ADD R2, R0, -R1;
            // r2=Tex1-Tex0
            TEX R0, fragment.texcoord[4], texture[4], 2D;
            MAD R2, R0.x, R2, R1;
            // r2 = Tex4.x*r2+Tex0
            // 說明:
            // 其中的Tex4.x是對應第1層alpha值, 下面把Tex4.x當a1看
            // 即 r2 = a1 * (Tex1-Tex0) + Tex0
            // 轉換一下即是: Tex0*(1-a1)+a1*Tex1, 呵呵,看到了吧,這就是混合公式!
            // 二.第2層和前面結果使用第4張圖的y通道作為alpha進行混合:
            TEX R1, fragment.texcoord[2], texture[2], 2D;
            ADD R1, R1, -R2;
            // r1=Tex2-r2
            MAD R2, R0.y, R1, R2;
            // r2 = Tex4.y*r1+r2, 即 a2*r1+r2 = a2*(Tex2-r2)+r2, 即r2*(1-a2)+Tex2*a2, 其中r2即是上次0和1層混合后的結果
            // 三.第3層和前面結果使用第4張圖的z通道作為alpha進行混合:
            TEX R1, fragment.texcoord[3], texture[3], 2D;
            ADD R1, R1, -R2;
            // r1=Tex3-r2
            MAD R1, R0.z, R1, R2;
            // r1=a3*r1+r2 , 即 a3*r1+r2 = a3*(Tex3-r2)+r2, 即r2*(1-a3)+Tex3*a3
            // 這樣r1就保存了最終的混合結果
            // 四.讓陰影地表光澤系數為0(Tex4.w即a通道代表地形的陰影,0為陰影,1為正常.而每層貼圖中的a通道是光澤通道,所以R1.w保存的是最終的光澤通道值):
            MUL R0.x, R1.w, R0.w;
            // r0.x = r1.w(光澤)*Tex4.w(陰影值, 是陰影則=0,否則=1)
            // 計算削減系數?
            MAD R0.w, R0, c[0].y, c[0].z; // r0乘上0.3(削減了30%)再加上一個常量0.69999999
            // 反射高光 = secondary_color(反射光)*光澤:
            MUL R0.xyz, R0.x, fragment.color.secondary;
            // 貼圖最終color = 最終貼圖混出的color*削減系數:
            MUL R1.xyz, R1, R0.w;
            // 貼圖最終color * primary_color(光照色或是頂點色) + 反射高光:
            MAD result.color.xyz, R1, fragment.color.primary, R0;
            // alpha:
            MOV result.color.w, c[0].x;
            END
              
              

            本文來自CSDN博客,轉載請標明出處:http://blog.csdn.net/flipcode/archive/2008/03/03/2143452.aspx

            posted on 2009-12-11 02:04 RedLight 閱讀(844) 評論(0)  編輯 收藏 引用 所屬分類: 它不是一個人(WOW研究專區)

            <2009年5月>
            262728293012
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            導航

            統計

            公告


            Name: Galen
            QQ: 88104725

            常用鏈接

            留言簿(3)

            隨筆分類

            隨筆檔案

            相冊

            My Friend

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            亚洲国产成人精品女人久久久 | 青青草国产精品久久| 久久91亚洲人成电影网站| 国产精品美女久久久免费| 午夜精品久久久久久久无码| 中文字幕乱码人妻无码久久| 国产精品久久久久久久久| 国产三级精品久久| 中文字幕人妻色偷偷久久| segui久久国产精品| 久久WWW免费人成一看片| 99久久国产热无码精品免费久久久久| 人妻丰满?V无码久久不卡| 国产精品久久成人影院| 国产精品99久久久精品无码| 伊人久久大香线蕉影院95| 超级97碰碰碰碰久久久久最新| 大伊人青草狠狠久久| 新狼窝色AV性久久久久久| 久久伊人色| 久久国产精品一区| 色噜噜狠狠先锋影音久久| 亚洲AV无一区二区三区久久| 无码任你躁久久久久久久| 亚洲国产精品久久久久久| 久久久久久毛片免费播放| 伊人久久大香线蕉综合热线| 久久国产午夜精品一区二区三区| 国产精品久久久久久搜索| 人妻少妇久久中文字幕| 漂亮人妻被黑人久久精品| 久久精品国产2020| 亚洲国产精品高清久久久| 久久www免费人成看片| 狠狠色婷婷久久综合频道日韩| 中文字幕无码久久人妻| 久久最新免费视频| 久久人人青草97香蕉| 蜜臀av性久久久久蜜臀aⅴ | 2022年国产精品久久久久| 久久国产精品成人片免费|