• <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 - 94, comments - 250, trackbacks - 0, articles - 0
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            Nebula3繪制2D紋理

            Posted on 2008-12-14 22:03 Condor 閱讀(2067) 評論(1)  編輯 收藏 引用

            上次已經繪制過基本圖元了, 這次只不過要貼張圖而已.....

            本來我想用Graphics的Model渲染流程來做, 不過這一層太高級了, 都是什么場景管理資源映射之類的

            做低級的事情, 就要用低級的API嘛

            圖形渲染的底層是CoreGraphics, 這個層我不打算再單獨寫(翻譯)一篇了, 因為都是Direct3D概念的一些抽象. 也就是說D3D用熟了基本上一看就明白(用GL的我就不清楚啦, 嘿嘿, N3的作者都放棄用GL去實現@_@).

            還記得D3D Tutorial中的Textured例子不? 需要的東西有帶紋理坐標的點, 紋理. N3中也一樣, 不過, 這里沒法用固定管線了.

            N3的設計的時候就放棄了固定管線(多么明智呀, 別噴我-_-, 我只會shader.......), 所以在這之前我們要先寫一個shader來進行繪制.

            因為我們只是進行簡單的演示, 就盡量簡單了, 寫一個2D的紋理繪制, 你可以用來做UI:

            1. //------------------------------------------------------------------------------
            2. //  texture2d.fx
            3. //  texture shader for 2D(UI)
            4. //  (C) xoyojank
            5. //------------------------------------------------------------------------------
            6. float2 halfWidthHeight  : HalfWidthHeight;
            7. texture diffMap     : DiffMap0;
            8. sampler diffMapSampler = sampler_state
            9. {
            10.     Texture = <diffMap>;
            11.     AddressU = Clamp;
            12.     AddressV = Clamp;
            13.     MinFilter = Point;
            14.     MagFilter = Point;
            15.     MipFilter = None;
            16. };
            17. struct VS_INPUT
            18. {
            19.     float3 pos  : POSITION;
            20.     float2 uv       : TEXCOORD;
            21. };
            22. struct VS_OUTPUT
            23. {
            24.     float4 pos  : POSITION;
            25.     float2 uv       : TEXCOORD;
            26. };
            27. //------------------------------------------------------------------------------
            28. /**
            29. */
            30. VS_OUTPUT
            31. VertexShaderFunc(VS_INPUT input)
            32. {
            33.     VS_OUTPUT output;
            34.     output.pos.xy = float2(input.pos.x - halfWidthHeight.x, halfWidthHeight.y - input.pos.y) / halfWidthHeight;
            35.     output.pos.zw = float2(input.pos.z, 1.0f);
            36.     output.uv = input.uv;
            37. return output;
            38. }
            39. //------------------------------------------------------------------------------
            40. /**
            41. */
            42. float4
            43. PixelShaderFunc(float2 uv : TEXCOORD0) : COLOR
            44. {
            45. return tex2D(diffMapSampler, uv);
            46. }
            47. //------------------------------------------------------------------------------
            48. /**
            49. */
            50. technique Default
            51. {
            52.     pass p0
            53.     {
            54.         ColorWriteEnable  = RED|GREEN|BLUE|ALPHA;
            55.         ZEnable           = False;
            56.         ZWriteEnable      = False;
            57.         StencilEnable     = False;
            58.         FogEnable         = False;
            59.         AlphaBlendEnable  = True;
            60.         SrcBlend          = SrcAlpha;
            61.         DestBlend         = InvSrcAlpha;
            62.         AlphaTestEnable   = False;
            63.         ScissorTestEnable = False;
            64.         CullMode          = CW;        
            65.         VertexShader = compile vs_3_0 VertexShaderFunc();
            66.         PixelShader = compile ps_3_0 PixelShaderFunc();
            67.     }
            68. }

            值得一提的是CullMode = CW, 為什么? 因為N3用的右手坐標系, 這點又跟D3D不一樣了........為什么呢? 難道寫MAYA跟MAX的插件的時候比較省事?

            還是要跟上一次一樣設置頂點格式并載入VertexBuffer:

            1. // vertex
            2.             Array<VertexComponent> vertexComponents;
            3.             vertexComponents.Append(VertexComponent(VertexComponent::Position, 0, VertexComponent::Float3));
            4.             vertexComponents.Append(VertexComponent(VertexComponent::TexCoord, 0, VertexComponent::Float2));
            5. float vertex[4][5] = {
            6.                 {0.0f,  0.0f,   0.0f,   0.0f, 0.0f},
            7.                 {0.0f,  256.0f, 0.0f,   0.0f, 1.0f}, 
            8.                 {256.0f,0.0f,   0.0f,   1.0f, 0.0f}, 
            9.                 {256.0f,256.0f, 0.0f,   1.0f, 1.0f}
            10.             };
            11.             vertexBuffer = VertexBuffer::Create();
            12.             Ptr<MemoryVertexBufferLoader> vbLoader = MemoryVertexBufferLoader::Create();
            13.             vbLoader->Setup(vertexComponents, 4, vertex, 4 * 5 * sizeof(float));
            14.             vertexBuffer->SetLoader(vbLoader.upcast<ResourceLoader>());
            15.             vertexBuffer->Load();
            16.             vertexBuffer->SetLoader(NULL);

            紋理的創建其實跟頂點差不多, 因為它都是屬于資源的一種, 詳見Nebula3資源子系統

            1. // texture
            2.             texture = Texture::Create();
            3.             texture->SetResourceId(ResourceId("bin:razor.jpg"));
            4.             texture->SetLoader(StreamTextureLoader::Create());
            5.             texture->Load();
            6.             texture->SetLoader(NULL);

            shader的加載跟上一次一樣, 只是參數不同:

            1. // shader
            2. this->shaderInstance = this->shaderServer->CreateShaderInstance(ResourceId("shd:texture2d"));
            3.             Ptr<ShaderVariable> halfWidthHeight = this->shaderInstance->GetVariableBySemantic(ShaderVariable::Semantic("HalfWidthHeight"));
            4.             float2 halfWH = float2(this->renderDevice->GetDefaultRenderTarget()->GetWidth(), this->renderDevice->GetDefaultRenderTarget()->GetHeight()) * 0.5f;
            5.             halfWidthHeight->SetFloatArray(&halfWH.x(), 2);
            6.             Ptr<ShaderVariable> diffMap = this->shaderInstance->GetVariableBySemantic(ShaderVariable::Semantic("DiffMap0"));
            7.             diffMap->SetTexture(texture);

            繪制嘛, 當然改成矩形了, 圖片可貼不到一跟線上:

            1. this->renderDevice->BeginFrame();
            2. this->renderDevice->BeginPass(this->renderDevice->GetDefaultRenderTarget(), this->shaderInstance);
            3.         PrimitiveGroup primGroup;
            4.         primGroup.SetBaseVertex(0);
            5.         primGroup.SetNumVertices(4);
            6.         primGroup.SetPrimitiveTopology(PrimitiveTopology::TriangleStrip);
            7. this->renderDevice->SetVertexBuffer(this->vertexBuffer);
            8. this->renderDevice->SetPrimitiveGroup(primGroup);
            9. this->renderDevice->Draw();
            10. this->renderDevice->EndPass();
            11. this->renderDevice->EndFrame();
            12. this->renderDevice->Present();

            上圖:

            Feedback

            # re: Nebula3繪制2D紋理  回復  更多評論   

            2008-12-15 11:39 by saltyshrimp
            樓主這些是轉載吧?轉載的時候說明一下,或者把原文的鏈接也放上來吧
            精品久久久久国产免费| 久久夜色精品国产网站| 99久久精品无码一区二区毛片| 亚洲乱亚洲乱淫久久| 欧美大战日韩91综合一区婷婷久久青草 | 中文国产成人精品久久不卡| 偷偷做久久久久网站| 青青热久久综合网伊人| 欧美亚洲国产精品久久高清 | 亚洲国产成人乱码精品女人久久久不卡 | 中文成人久久久久影院免费观看| 久久精品一本到99热免费| 99精品久久久久中文字幕| 久久久久国产一区二区三区| 四虎影视久久久免费| 久久精品国产亚洲精品2020| 一本色道久久88综合日韩精品| 高清免费久久午夜精品| 国产精品久久久久久久人人看| 国产成人精品久久一区二区三区 | 久久伊人五月丁香狠狠色| 99久久精品国产毛片| 少妇精品久久久一区二区三区| 内射无码专区久久亚洲| segui久久国产精品| 国产精品久久久久久久久免费| 久久久久亚洲av综合波多野结衣| 曰曰摸天天摸人人看久久久| 国内精品久久人妻互换| 久久婷婷成人综合色综合| 久久综合亚洲色HEZYO社区| 久久五月精品中文字幕| 国产精品久久久天天影视香蕉| 久久99国产乱子伦精品免费| 久久夜色精品国产网站| 性做久久久久久久| 久久精品国产亚洲AV大全| 久久精品午夜一区二区福利| 久久精品麻豆日日躁夜夜躁| 韩国无遮挡三级久久| 99久久国产亚洲高清观看2024|