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

            性能優化:(From D3D9 SDK)

            常規技巧

            1 只在必須的時候Clear。
               IDirect3DDevice9::Clear函數通常需要花費較多的時間,因此要盡量少調用,而且只清空的確需要清空的緩存。

            2 盡量減少狀態切換。并且將需要進行的狀態切換組合在一起設置。
               狀態包括RenderState,SamplerState,TextureStageState等

            3 紋理尺寸盡可能小

            4 從前至后渲染場景中的對象
               從前至后渲染可以盡可能早地精選出不需要繪制的對象和象素

            5 使用三角條帶代替三角列表和三角扇。為了能更有效利用頂點高速緩存(cache),在排列條帶時因考慮盡快重用頂點。

            6  根所需要據消耗的系統資源來逐步減少特效。

            7 經常性地檢測程序的性能。
               這樣可以更容易發現引起性能突變的部分

            8 最小化頂點緩存的切換

            9 盡可能使用靜態頂點緩存

            10 對靜態對象,對每種FVF使用一個大的靜態頂點緩存來保存多個對象的頂點數據,而不是每個對象使用一個頂點緩存。
               其目的也是減少頂點緩存的切換

            11 如果程序需要隨機訪問AGP內存中的頂點緩存,頂點格式的大小最好是32bytes的倍數。否則,選擇合適的最小的格式。
            32bytes 也就是8個float數據或2個vector4。

            12 使用頂點索引方式渲染,這樣可以更有效利用頂點高速緩存。

            13 如果深度緩存格式中包含有模版緩存,總是將兩者一起Clear。

            14 將計算結果和輸出的shader指令合并:
            // Rather than doing a multiply and add, and then output the data with
            //   two instructions:
            mad r2, r1, v0, c0
            mov oD0, r2

            // Combine both in a single instruction, because this eliminates an 
            //   additional register copy.
            mad oD0, r1, v0, c0

            建立一個場景對象的數據庫,首先使用最低精度的模型,在保證性能的前提下逐步使用更高精度的模型。密切關注渲染的總的三角面數。

            將使用相同渲染狀態和貼圖的圖元集中在一起繪制,這樣能盡量減少頂點緩存和狀態的切換。并且將狀態切換操作集中成一組設置。

            盡量減少光源數量,使用環境光來提高亮度。方向光源比點光源和聚光燈更高效,因為光的方向是固定的。使用光照范圍參數來剔除不受光照影響的物體。鏡面高光幾乎使光照計算量加倍,因此只在需要時使用,將D3DRS_SPECULARENABLE設為FALSE,將材質的specular power 設為0,將材質的specular color 設為0。

            盡量減小紋理尺寸,這樣可以增加紋理被緩存的可能性。盡量減少紋理的切換,將使用同一紋理的對象集中繪制。盡量使用正方形紋理。最快的紋理是256×256,將4張128×128的紋理拼接成256×256使用。

            連接World-View Matrix, 將ViewMatrix設為Identity減少矩陣乘法運算。

            動態紋理。首先要檢查D3DCAPS2_DYNAMICTEXTURES來判斷硬件是否支持。
            其二,動態紋理不能放在MANAGED pool中。動態紋理總是能鎖定,甚至是在D3DPOOL_DEFAULT中。D3DLOCK_DISCARD是合法的。
            DrawProceduralTexture(pTex)
            {
                // pTex should not be very small because overhead of
                //   calling driver every D3DLOCK_DISCARD will not
                //   justify the performance gain. Experimentation is encouraged.
                pTex->Lock(D3DLOCK_DISCARD);
                <Overwrite *entire* texture>
                pTex->Unlock();
                pDev->SetTexture();
                pDev->DrawPrimitive();
            }

            當需要在每幀里鎖定頂點或索引緩存是,應該使用動態緩存(D3DUSAGE_DYNAMIC)。對動態緩存使用D3DLOCK_DISCARD鎖定能減少延遲。D3DLOCK_NOOVERWRITE鎖定可以用于在緩存空閑處添加新的數據而不修改已經寫入的數據。

            使用Effect時,應該根據Effect,然后根據Technique來安排渲染順序,也就是使用相同Effect和Technique的物體應該集中繪制。這樣可以減少狀態切換開銷。

            posted on 2007-06-04 12:57 隨便寫寫 閱讀(1338) 評論(1)  編輯 收藏 引用

            評論

            # re: 性能優化:(From D3D9 SDK) 2014-12-25 16:00 陳默

            LZ威猛哦!  回復  更多評論   

            導航

            <2025年5月>
            27282930123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            統計

            常用鏈接

            留言簿(1)

            隨筆分類(30)

            隨筆檔案(16)

            文章分類(18)

            文章檔案(9)

            鏈接

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            2021国产成人精品久久| 蜜臀av性久久久久蜜臀aⅴ麻豆 | 久久久久国产精品| 亚洲成色999久久网站| 久久久久亚洲精品天堂久久久久久| 国产精品美女久久久久av爽| 一本色道久久88综合日韩精品 | 久久亚洲2019中文字幕| 久久精品国产亚洲αv忘忧草| 久久夜色精品国产噜噜噜亚洲AV| 久久亚洲精品成人av无码网站| 亚洲午夜久久久精品影院| 欧美国产精品久久高清| 久久久久久久久久久久中文字幕 | 国产福利电影一区二区三区久久老子无码午夜伦不 | 久久精品无码一区二区日韩AV| 无码国内精品久久人妻| 久久久久人妻一区精品| 久久国产精品成人片免费| 亚洲精品tv久久久久久久久久| 久久九九青青国产精品| 亚洲精品乱码久久久久久蜜桃不卡| 激情五月综合综合久久69| 久久久久亚洲精品无码蜜桃| 久久亚洲精品无码aⅴ大香| 青青青青久久精品国产| 久久香蕉国产线看观看精品yw| 亚洲国产精品狼友中文久久久| 18岁日韩内射颜射午夜久久成人| 麻豆成人久久精品二区三区免费| 久久这里只有精品视频99| 久久青青草原综合伊人| 国内精品久久久久久久97牛牛| 久久久久久伊人高潮影院| 亚洲国产日韩欧美久久| 日日狠狠久久偷偷色综合免费 | 久久久久无码精品| 国内精品久久久久久久久| 国产高潮国产高潮久久久91 | 国产一区二区精品久久岳| 久久国产精品77777|