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

            戰魂小筑

            討論群:309800774 知乎關注:http://zhihu.com/people/sunicdavy 開源項目:https://github.com/davyxu

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

            Direct3D中的Shader是這樣的:

            1. ASM Shader是最元老的也是DX8主要使用Shader

            2. fxc編譯器可以同時編譯ASM,HLSL和fx腳本,其中HLSL和fx可以查看編譯后的GPU匯編代碼

            3. D3D9中,fx是HLSL的一種渲染腳本,簡化了HLSL設置及常量綁定,并且附帶RenderStateBlock及設置

            但只能用于制作簡單的Shader

            4. DirectXSDK中有一個概念混淆:C++例子中的BasicHLSL使用的其實還是fx,HLSLwithoutEffects例子才是真正的純HLSL

            5.fx與HLSL程序鑒別:

            使用fx程序必定含有:D3DXCreateEffectXXX 系列函數, ID3DXEffect對象,渲染中能看到SetTechnique,BeginPass,EndPass之類的字眼

            使用純HLSL程序含有:D3DXCompileShader,ID3DXConstantTable對象,GetConstantByName,GetConstantDesc之類的字眼

            6. 在fx中包含有 VertexShader,PixelShader代碼及profile,entry,RenderState設置及簡單的繪制過程(pass)。一次編譯后,VS,PS,Texture,Sampler及常量都是在ID3DXEffect對象中自動完成,無需手動設置。

            7. HLSL可以將VS及PS代碼寫入1個.hlsl文件。注意,以下這種代碼可以在HLSL中編譯過,但實際沒有任何效果

               1:  sampler_state
               2:  {
               3:      Texture = <tex>;
               4:      MipFilter = LINEAR;
               5:      MinFilter = LINEAR;
               6:      MagFilter = LINEAR;
               7:  };

            這點可以參考AMD RenderMonkey中只在shader中使用sampler而忽略texture。

            8. fx中往shader設置紋理使用的是ID3DXBaseEffect::SetTexture下的這個函數

               1:  HRESULT SetTexture(
               2:    D3DXHANDLE hParameter,
               3:    LPDIRECT3DBASETEXTURE9 pTexture
               4:  );

            但是在HLSL中,這點就變得很麻煩,需要手動設置,可以參考這篇文章

            Shader代碼片段:

               1:  sampler Samp0 = sampler_state
               2:  {
               3:      Texture = <Tex0>;
               4:      MipFilter = LINEAR;
               5:      MinFilter = LINEAR;
               6:      MagFilter = LINEAR;
               7:  };

            編譯HLSL代碼后得到ConstantTable,然后取出句柄:

               1:  ScalarHandle = pixelConstTable->GetConstantByName(0, "Scalar");
               2:   
               3:  Samp0Handle = pixelConstTable->GetConstantByName(0, "Samp0");
               4:   
               5:  Samp1Handle = pixelConstTable->GetConstantByName(0, "Samp1");

            再從句柄取出symbol的描述:

               1:  UINT count;
               2:   
               3:  pixelConstTable->GetConstantDesc(Samp0Handle, & Samp0Desc, &count);
               4:   
               5:  pixelConstTable->GetConstantDesc(Samp1Handle, & Samp1Desc, &count);

            通過上面的描述,將紋理變量的寄存器偏移作為紋理的stage

            8.  優化常量設置速度的方法一般就是根據字符串取出句柄,以后每次渲染時,只通過句柄設置。但ID3DXConstantTable最后還是通過

            IDirect3DDevice9::SetPixelShaderConstantX 系列函數來實現的

               1:  HRESULT SetPixelShaderConstantF(
               2:    UINT StartRegister,
               3:    CONST float * pConstantData,
               4:    UINT Vector4fCount
               5:  );

            9. HLSL將一段包含VS和PS代碼編譯完成后,將得到VS和PS兩個單獨的ID3DXConstantTable

            posted on 2010-03-05 14:26 戰魂小筑 閱讀(3280) 評論(0)  編輯 收藏 引用 所屬分類: C++/ 編程語言渲染 Shader 引擎
            亚洲精品国产美女久久久| 国产精品美女久久久久AV福利| 午夜精品久久久久久影视777 | 亚洲熟妇无码另类久久久| AV无码久久久久不卡蜜桃| 精品国产乱码久久久久久郑州公司| 国产精品99精品久久免费| 欧美伊人久久大香线蕉综合69| 人妻无码αv中文字幕久久琪琪布| 久久综合狠狠色综合伊人| 噜噜噜色噜噜噜久久| 日本道色综合久久影院| 婷婷久久五月天| 久久无码av三级| 一本久久a久久精品vr综合| 精品久久久久久国产三级| 国内精品久久久久久久97牛牛| 久久午夜福利电影| 久久99中文字幕久久| 亚洲va中文字幕无码久久不卡| 久久夜色精品国产| 日韩亚洲欧美久久久www综合网| 久久香蕉超碰97国产精品| 亚洲午夜久久久| 香蕉久久AⅤ一区二区三区| 色综合久久88色综合天天| 久久99国产综合精品免费| 亚洲女久久久噜噜噜熟女| 日韩va亚洲va欧美va久久| 久久成人国产精品一区二区| 99国产欧美精品久久久蜜芽| 亚洲AV无码1区2区久久| 综合久久一区二区三区| 久久久WWW成人免费精品| 久久线看观看精品香蕉国产| 99久久精品午夜一区二区| 亚洲AV成人无码久久精品老人| 国产亚洲精久久久久久无码77777| 久久综合九色综合欧美就去吻| 精品久久久久久久中文字幕 | 日韩欧美亚洲综合久久影院d3|