• <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 閱讀(2069) 評論(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久久香蕉国产线看观香| 亚洲国产精品狼友中文久久久| 久久久久人妻一区二区三区| 污污内射久久一区二区欧美日韩| 中文字幕无码av激情不卡久久| 久久婷婷午色综合夜啪| 亚洲欧洲日产国码无码久久99| 国产精品一区二区久久国产| 国产一区二区精品久久凹凸| 国内精品伊人久久久久妇| 久久久久亚洲AV无码专区体验 | 亚洲综合伊人久久综合| 99re这里只有精品热久久| 国产午夜福利精品久久| 2021国产精品午夜久久 | 99久久综合狠狠综合久久| 午夜肉伦伦影院久久精品免费看国产一区二区三区 | 青青热久久国产久精品 | 久久久久波多野结衣高潮| 精品久久久久久亚洲精品 | 精品久久一区二区| 久久精品成人免费国产片小草| 国产精品99久久久精品无码| 久久97久久97精品免视看| 亚洲国产精品无码久久| 久久一区二区三区免费| 国产精品久久久福利| 77777亚洲午夜久久多喷| 久久婷婷人人澡人人| 久久精品国产一区| 精品久久久久香蕉网| 久久精品日日躁夜夜躁欧美| 久久亚洲国产精品五月天婷| 国产巨作麻豆欧美亚洲综合久久| 国产精品99久久免费观看| 久久久久亚洲av无码专区导航| 亚洲AV乱码久久精品蜜桃| 婷婷伊人久久大香线蕉AV| 人妻少妇久久中文字幕|