• <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>
            posts - 72,  comments - 4,  trackbacks - 0
            泰坦之旅的shader處理流程:
            例如讀取以下shader文件
            {fileName="Shaders/Overlay.ssh" resourceLoader=0x021090e0 resourceType=resourceShader ...}
            1. Block_Constants:
               共7個const:
                1)constants[0].elements[] = VertexShader
            VertexShader->bindings[0] {registerIndex=0, registerCount=4; valueisrefconst(const or param)=false, valueidx=0;}
               VertexShader->shader = 編譯好的shader;
            2)constants[1].elements[] = int;
            3)constants[2].elements[] = int;
            4)constants[3].elements[] = int;
            5)constants[4].elements[] = int;
            6)constants[5].elements[] = int;
            7)constants[6].elements[] = int;
            2. Block_Parameters:
               共2個Param:
               1) parameters[0] = "objectToScreenMatrix"  Type_Float4x4 
               2) parameters[1] = "vs", parameter.defaultValueIndex = 0; // 即缺省指向constants[0],也即1.1)中的VertexShader
               以上Param映射到parameterNameMap表中[name]=i; 這樣通過i可以直接索引設置parameters[i].value數值。
            3. Block_Styles:
               共1個Style
               styles[0].name="normal"          
               styles[0].order=0;
               numPasses=1;// 目前只支持1pass
               styles[0].bindings=7
              1).styles[0].bindins[0] {state=State_VertexShader stateIndex=0 valueReference={constant=false index=1} }     // 即指向parameters[1]
              2).styles[0].bindins[1] {state=State_DepthWriteMode stateIndex=0 valueReference={constant=true index=1} }    // 即指向constants[1]
              3).styles[0].bindins[2] {state=State_AlphaWriteMode stateIndex=0 valueReference={constant=true index=2} }    // 即指向constants[2]
              4).styles[0].bindins[3] {state=State_CullingMode stateIndex=0 valueReference={constant=true index=3} }       // 即指向constants[3]
              5).styles[0].bindins[2] {state=State_DepthTestFunction stateIndex=0 valueReference={constant=true index=4} } // 即指向constants[4]
              6).styles[0].bindins[2] {state=State_BlendSrcFactor stateIndex=0 valueReference={constant=true index=5} }    // 即指向constants[5]
              7).styles[0].bindins[2] {state=State_BlendDstFactor stateIndex=0 valueReference={constant=true index=6} }    // 即指向constants[6]
            說明:   
            a. 渲染前如果設置參數,將會搜索parameters[]并修改對應的值,
            b. 而當渲染時,會傳入styleindex進行渲染,這時會遍歷所有styles[styleindex].bindins[],按state進行設置, 如果state是渲染狀態則通過SetRenderState之類接設置則完成,
            如果是vs或者是ps,則設置對應vs->shader/ps->shader,并遍歷其bindings[]把索引到的param或者const值設置給shader.
            例如:
              我們使用const kGraphicsShader2* shader = gEngine->GetGraphicsEngine()->LoadShader2("Shaders/BasicTexture.ssh");這個帶貼圖的shader.
              在渲染前通過shader->SetTexture("baseTexture",0,currentTexture0);設置貼圖時會在parameters[]搜索找并設置該貼圖,
              之后渲染時會處理styles[當前style].bindins[], 如果state是普通渲染狀態則用SetRenderState之類接設置則完成,
            而如果是shader,那么會設置對應的shade,并遍歷shader.bindings[]索引找到對應的param把對應的貼圖傳遞給shader,從而得已正確渲染.
            posted on 2011-11-15 14:12 flipcode 閱讀(269) 評論(0)  編輯 收藏 引用
            亚洲综合婷婷久久| 久久这里只精品99re66| 国产精品久久久天天影视| 91精品国产9l久久久久| 久久最新免费视频| 久久精品水蜜桃av综合天堂| 国产成人精品久久一区二区三区av| 九九久久精品无码专区| 亚洲精品美女久久久久99| 国产精品女同一区二区久久| 久久精品国产日本波多野结衣| 久久青青草原国产精品免费| 国产精品久久久久久久app| 欧美精品一本久久男人的天堂| 超级碰碰碰碰97久久久久| 精品一区二区久久久久久久网站| 中文字幕久久精品| 精品国产婷婷久久久| 久久综合噜噜激激的五月天| 亚洲国产天堂久久久久久| 久久精品国产亚洲一区二区| 欧美亚洲色综久久精品国产| 色狠狠久久综合网| 久久免费香蕉视频| 97久久精品人人澡人人爽| 久久99国产精品尤物| 亚洲午夜久久久影院伊人| 一级A毛片免费观看久久精品| 国产亚洲成人久久| 国产精品xxxx国产喷水亚洲国产精品无码久久一区| 亚洲&#228;v永久无码精品天堂久久| 久久久女人与动物群交毛片| 人妻无码αv中文字幕久久琪琪布| 区亚洲欧美一级久久精品亚洲精品成人网久久久久 | 婷婷久久五月天| 一级a性色生活片久久无| 四虎国产精品成人免费久久| 亚洲精品视频久久久| 国产成人综合久久精品红| 久久久久久久波多野结衣高潮 | 亚洲中文字幕伊人久久无码|