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

            戰(zhàn)魂小筑

            討論群:309800774 知乎關(guān)注:http://zhihu.com/people/sunicdavy 開源項(xiàng)目:https://github.com/davyxu

               :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
              257 隨筆 :: 0 文章 :: 506 評論 :: 0 Trackbacks

            昨天研究了下Node Based Material System, 虛幻3的材質(zhì)系統(tǒng)是沒戲了,還沒用會(huì)呢. 不過Max的一個(gè)插件: ShaderFX倒是給我很大的啟發(fā),這東西就是結(jié)點(diǎn)型材質(zhì)系統(tǒng), 而且能生成真正的FX. 不像虛幻3那么不厚道,只是局部顯示HLSL.

            image

            經(jīng)過分析ShaderFX導(dǎo)出的Shader文件, 發(fā)現(xiàn)其標(biāo)準(zhǔn)材質(zhì)系統(tǒng)使用的就是逐像素光照模型, 而不同的Materials對應(yīng)的就是一種Shader處理管線, 分別可以處理各種光照,甚至達(dá)到Compositor的混合效果. 而Shader Code Generation這個(gè)環(huán)節(jié),也遠(yuǎn)沒有虛幻3那樣復(fù)雜(虛幻是神,咱們不評論神到底如何),只是將光照需要的各種分量,例如Emissive, Ambient, Diffuse, Specular等根據(jù)各分量提供的計(jì)算因子直接嵌入到Pixel Shader主函數(shù)體即可.

            逐頂點(diǎn)光照在前面的文章已經(jīng)有介紹,代碼相對簡單, 因此以后在材質(zhì)系統(tǒng)中準(zhǔn)備直接上逐像素光照. 因此,需要在我的模型插件中加入Tangent及Binormal支持.

            這里是一篇很不錯(cuò)的講解Tangent Space Vector的文章. 文中有貼過OGRE的Tangent計(jì)算代碼,不過查閱OGRE 1.65代碼后發(fā)現(xiàn),OGRE現(xiàn)在根本就不用這個(gè)函數(shù)計(jì)算Tangent,而是更為復(fù)雜的一個(gè)類.

            最終,我還是使用了大野豬的ev3d的max插件代碼, 如果需要的話,可以去他博客找svn下載

             

            bool CMaxMesh::__cacl_tbn(sFace_t& face,bool isSkin)
            {
                Point3  normal[3];
                Point3  Tangent; 
                Point3  p[3];
             
                assign(normal[0],m_MeshData.m_VertexData.m_Normals[face.vert[0]]);
                assign(normal[1],m_MeshData.m_VertexData.m_Normals[face.vert[1]]);
                assign(normal[2],m_MeshData.m_VertexData.m_Normals[face.vert[2]]);
             
                if(isSkin == false)
                {
                    assign(p[0],m_MeshData.m_VertexData.m_Positons[face.vert[0]]);
                    assign(p[1],m_MeshData.m_VertexData.m_Positons[face.vert[1]]);
                    assign(p[2],m_MeshData.m_VertexData.m_Positons[face.vert[2]]);
                }
                else
                {
                    assign(p[0],m_MeshData.m_VertexData.m_VertexWeights[face.vert[0]].m_InitPos);
                    assign(p[1],m_MeshData.m_VertexData.m_VertexWeights[face.vert[1]].m_InitPos);
                    assign(p[2],m_MeshData.m_VertexData.m_VertexWeights[face.vert[2]].m_InitPos);
                }
             
             
                sUVCoord_t uv[3];
                uv[0] = m_MeshData.m_VertexData.m_UVChannels[0][face.vert[0]];
                uv[1] = m_MeshData.m_VertexData.m_UVChannels[0][face.vert[1]];
                uv[2] = m_MeshData.m_VertexData.m_UVChannels[0][face.vert[2]];
             
                Point3  e1 = p[1] - p[0];
                Point3  e2 = p[2] - p[0];
                sUVCoord_t u1 = { uv[1].u - uv[0].u , uv[1].v - uv[0].v};
                sUVCoord_t u2 = { uv[2].u - uv[0].u , uv[2].v - uv[0].v};
             
                float det =  ( u1.u * u2.v - u2.u * u1.v);
                if(det == 0.0f)
                {
                    Tangent = e1;
                }
                else
                {
                    Tangent = u2.v * e1 - u1.v * e2;
                }
             
                //從Normal 和 Tangent里重新計(jì)算出Tangent,因?yàn)槊娴腡angent和頂點(diǎn)的Normal可能不垂直
                Point3 final_tangent;
                for(int i = 0 ;i < 3 ; ++i)
                {
                    Point3 binormal  = CrossProd(normal[i],Tangent);
                    final_tangent = CrossProd(binormal,normal[i]);
                    final_tangent.Normalize();
                    m_MeshData.m_VertexData.m_Tangents[face.vert[i]].x += final_tangent.x;
                    m_MeshData.m_VertexData.m_Tangents[face.vert[i]].y += final_tangent.y;
                    m_MeshData.m_VertexData.m_Tangents[face.vert[i]].z += final_tangent.z;
             
                }
                return true;
            }

             

            感謝大野豬友情出演,正片開始:)

            image

            posted on 2010-06-02 15:55 戰(zhàn)魂小筑 閱讀(2107) 評論(2)  編輯 收藏 引用 所屬分類: 渲染 Shader 引擎

            評論

            # re: 曬下材質(zhì)系統(tǒng)進(jìn)度: 導(dǎo)出Tangent Space Vector 2010-06-03 11:22 小熙
            可以看看游戲編程精粹5上的Shader重組,另外,GPU Gems 1 書上33章上的材質(zhì)樹,使用cg實(shí)現(xiàn),材質(zhì)類用到了Interface和函數(shù)重載  回復(fù)  更多評論
              

            # re: 曬下材質(zhì)系統(tǒng)進(jìn)度: 導(dǎo)出Tangent Space Vector 2010-06-03 18:01 戰(zhàn)魂小筑
            @小熙
            呵呵,這2個(gè)都看了. Gem5那個(gè)太簡單, Cg暫時(shí)不考慮
            ShaderFX的模型很好,再結(jié)合下虛幻的,那就齊了
              回復(fù)  更多評論
              

            亚洲va中文字幕无码久久| 超级碰碰碰碰97久久久久| 久久人与动人物a级毛片| 国产精品美女久久久免费| 亚洲精品国产成人99久久| 国产成人无码久久久精品一| www性久久久com| 久久精品国产福利国产秒| 久久久青草久久久青草| 久久精品国产黑森林| 2020久久精品亚洲热综合一本| 中文字幕精品无码久久久久久3D日动漫 | 久久99久久99精品免视看动漫| 久久夜色精品国产噜噜亚洲a| 久久久亚洲裙底偷窥综合| 亚洲国产精品无码久久一线| 精品久久无码中文字幕| 激情久久久久久久久久| 久久亚洲精品国产亚洲老地址| 色欲综合久久躁天天躁蜜桃| 91精品国产综合久久精品| 欧美一级久久久久久久大| 亚洲精品高清国产一线久久| 免费观看久久精彩视频| 日韩精品无码久久一区二区三| 99蜜桃臀久久久欧美精品网站| 91精品国产乱码久久久久久 | 国产精品免费久久| 久久综合亚洲鲁鲁五月天| 久久久精品国产sm调教网站| 国产精品成人久久久久三级午夜电影| 久久久久国产视频电影| 人妻无码久久一区二区三区免费| 欧美激情精品久久久久| 亚洲国产精品无码久久久秋霞2| 99精品久久久久久久婷婷| 天天躁日日躁狠狠久久| 久久久精品波多野结衣| 狠狠色噜噜狠狠狠狠狠色综合久久| 久久久久久久综合狠狠综合| 国产AV影片久久久久久|