• <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 開源項目:https://github.com/davyxu

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

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

            image

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

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

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

            最終,我還是使用了大野豬的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里重新計算出Tangent,因為面的Tangent和頂點的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)進度: 導出Tangent Space Vector 2010-06-03 11:22 小熙
            可以看看游戲編程精粹5上的Shader重組,另外,GPU Gems 1 書上33章上的材質(zhì)樹,使用cg實現(xiàn),材質(zhì)類用到了Interface和函數(shù)重載  回復(fù)  更多評論
              

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

            97r久久精品国产99国产精| 天堂无码久久综合东京热| 99久久免费国产精品热| 嫩草影院久久国产精品| 开心久久婷婷综合中文字幕| 亚洲va久久久噜噜噜久久男同| 久久久久99精品成人片欧美| 久久天天躁狠狠躁夜夜2020| 亚洲∧v久久久无码精品| 亚洲国产精品久久66| 亚洲欧美日韩精品久久亚洲区 | 久久亚洲高清观看| 欧美精品丝袜久久久中文字幕| 伊人久久综合精品无码AV专区| 国产成人精品久久亚洲高清不卡 国产成人精品久久亚洲高清不卡 国产成人精品久久亚洲 | 久久免费99精品国产自在现线| 狠狠色丁香久久婷婷综合图片| 国产精品视频久久久| 久久人人爽人人爽人人片AV不| 人人狠狠综合久久亚洲婷婷| 久久精品黄AA片一区二区三区| 中文字幕久久精品| 久久天天躁狠狠躁夜夜不卡| 久久精品国产一区| 国产精品99久久99久久久| 欧美激情一区二区久久久| 久久午夜福利电影| www亚洲欲色成人久久精品| 久久国产免费观看精品| 久久久久成人精品无码中文字幕| 欧美日韩精品久久免费| 久久国内免费视频| 久久久国产99久久国产一| 国产精品一区二区久久精品涩爱 | 国产69精品久久久久777| 久久精品人人做人人爽电影| 久久久精品国产| 色婷婷综合久久久久中文| 亚洲AV无一区二区三区久久| 亚洲人成伊人成综合网久久久| 精品国产乱码久久久久软件 |