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

            天行健 君子當自強而不息

            ALPHA混合示例

            技巧如下:

            設置可變頂點格式時增加一個D3DCOLOR類型的漫反射分量,其中的alpha值指定了alpha混合因子。

            // The 2D vertex format and descriptor
            typedef struct
            {
                
            float x, y, z;      // 2D coordinates
                float rhw;          // rhw
                D3DCOLOR diffuse;   // diffuse color component
            } VERTEX;

            #define VERTEX_FVF   (D3DFVF_XYZRHW | D3DFVF_DIFFUSE)

            // initialize vertex data
                VERTEX verts[] = {
                  { 
            100.0f100.0f1.0f1.0f, D3DCOLOR_RGBA(0,64,128,255) },
                  { 
            300.0f100.0f1.0f1.0f, D3DCOLOR_RGBA(0,64,128,255) },
                  { 
            100.0f300.0f1.0f1.0f, D3DCOLOR_RGBA(0,64,128,255) },
                  { 
            300.0f300.0f1.0f1.0f, D3DCOLOR_RGBA(0,64,128,255) },
                  {  
            50.0f150.0f1.0f1.0f, D3DCOLOR_RGBA(128,0,0,128)  },
                  { 
            350.0f150.0f1.0f1.0f, D3DCOLOR_RGBA(128,0,0,128)  },
                  {  
            50.0f350.0f1.0f1.0f, D3DCOLOR_RGBA(128,0,0,128)  },
                  { 
            350.0f350.0f1.0f1.0f, D3DCOLOR_RGBA(128,0,0,128)  }
                };

            D3DCOLOR類型可以用D3DCOLOR_RGBA宏來生成,定義如下:

            // maps unsigned 8 bits/channel to D3DCOLOR
            #define D3DCOLOR_ARGB(a,r,g,b) \
                ((D3DCOLOR)((((a)
            &0xff)<<24)|(((r)&0xff)<<16)|(((g)&0xff)<<8)|((b)&0xff)))

            #define D3DCOLOR_RGBA(r,g,b,a) D3DCOLOR_ARGB(a,r,g,b)

            其中的a指定了alpha因子,a為255表示該顏色完全不透明,a為0表示該顏色完全透明。

            在繪制的時候,將首先繪制的圖形設置為禁用alpha混合模式,將后面繪制的圖形設置為啟用alpha混合模式,并設置alpha混合具體模式。

                   // disable alpha blending and draw 2 polygons
                    g_d3d_device->SetRenderState(D3DRS_ALPHABLENDENABLE, FALSE);
                    g_d3d_device
            ->DrawPrimitive(D3DPT_TRIANGLESTRIP, 02);

                    
            // enable alpha blending and draw 2 polygons
                    g_d3d_device->SetRenderState(D3DRS_ALPHABLENDENABLE, TRUE);
                    g_d3d_device
            ->SetRenderState(D3DRS_SRCBLEND, D3DBLEND_SRCALPHA);
                    g_d3d_device
            ->SetRenderState(D3DRS_DESTBLEND, D3DBLEND_INVSRCALPHA);
                    g_d3d_device
            ->DrawPrimitive(D3DPT_TRIANGLESTRIP, 42);   

            完整源碼如下:

            /***************************************************************************************
            PURPOSE:
                Alpha blending Demo

            Required libraries:
              D3D9.LIB
             **************************************************************************************
            */

            #include 
            <windows.h>
            #include 
            <stdio.h>
            #include 
            "d3d9.h"

            #pragma comment(lib, 
            "d3d9.lib")

            #define WINDOW_WIDTH    400
            #define WINDOW_HEIGHT   400

            #define Safe_Release(p) if((p)) (p)->Release();

            // window handles, class and caption text.
            HWND        g_hwnd;
            HINSTANCE   g_inst;
            static char g_class_name[] = "AlphaClass";
            static char g_caption[]    = "Alpha Blending Demo";

            // the Direct3D and device object
            IDirect3D9* g_d3d = NULL;
            IDirect3DDevice9
            * g_d3d_device = NULL;

            // The 2D vertex format and descriptor
            typedef struct
            {
                
            float x, y, z;      // 2D coordinates
                float rhw;          // rhw
                D3DCOLOR diffuse;   // diffuse color component
            } VERTEX;

            #define VERTEX_FVF   (D3DFVF_XYZRHW | D3DFVF_DIFFUSE)

            IDirect3DVertexBuffer9
            * g_vertex_buffer = NULL;
            IDirect3DTexture9
            *      g_texture = NULL;

            //--------------------------------------------------------------------------------
            // Window procedure.
            //--------------------------------------------------------------------------------
            long WINAPI Window_Proc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam)
            {
                
            switch(msg)
                {
                
            case WM_DESTROY:
                    PostQuitMessage(
            0);
                    
            return 0;
                }

                
            return (long) DefWindowProc(hwnd, msg, wParam, lParam);
            }

            //--------------------------------------------------------------------------------
            // Initialize d3d, d3d device, vertex buffer, texutre. 
            //--------------------------------------------------------------------------------
            BOOL Do_Init()
            {
                D3DPRESENT_PARAMETERS present_param;
                D3DDISPLAYMODE  display_mode;
                BYTE
            * vertex_ptr;

                
            // initialize vertex data
                VERTEX verts[] = {
                  { 
            100.0f100.0f1.0f1.0f, D3DCOLOR_RGBA(0,64,128,255) },
                  { 
            300.0f100.0f1.0f1.0f, D3DCOLOR_RGBA(0,64,128,255) },
                  { 
            100.0f300.0f1.0f1.0f, D3DCOLOR_RGBA(0,64,128,255) },
                  { 
            300.0f300.0f1.0f1.0f, D3DCOLOR_RGBA(0,64,128,255) },
                  {  
            50.0f150.0f1.0f1.0f, D3DCOLOR_RGBA(128,0,0,128)  },
                  { 
            350.0f150.0f1.0f1.0f, D3DCOLOR_RGBA(128,0,0,128)  },
                  {  
            50.0f350.0f1.0f1.0f, D3DCOLOR_RGBA(128,0,0,128)  },
                  { 
            350.0f350.0f1.0f1.0f, D3DCOLOR_RGBA(128,0,0,128)  }
                }; 

                
            // do a windowed mode initialization of Direct3D
                if((g_d3d = Direct3DCreate9(D3D_SDK_VERSION)) == NULL)
                    
            return FALSE;

                
            // retrieves the current display mode of the adapter
                if(FAILED(g_d3d->GetAdapterDisplayMode(D3DADAPTER_DEFAULT, &display_mode)))
                    
            return FALSE;

                ZeroMemory(
            &present_param, sizeof(present_param));

                
            // initialize d3d presentation parameter
                present_param.Windowed          = TRUE;
                present_param.SwapEffect        
            = D3DSWAPEFFECT_DISCARD;
                present_param.BackBufferFormat  
            = display_mode.Format;

                
            // creates a device to represent the display adapter
                if(FAILED(g_d3d->CreateDevice(D3DADAPTER_DEFAULT, D3DDEVTYPE_HAL, g_hwnd,
                                              D3DCREATE_SOFTWARE_VERTEXPROCESSING, 
            &present_param, &g_d3d_device)))
                    
            return FALSE;     

                
            // create the vertex buffer and set data
                g_d3d_device->CreateVertexBuffer(sizeof(VERTEX) * 80, VERTEX_FVF, D3DPOOL_DEFAULT, &g_vertex_buffer, NULL);

                
            // locks a range of vertex data and obtains a pointer to the vertex buffer memory
                g_vertex_buffer->Lock(00, (void**)&vertex_ptr, 0);

                memcpy(vertex_ptr, verts, 
            sizeof(verts));

                
            // unlocks vertex data
                g_vertex_buffer->Unlock();

                
            return TRUE;
            }

            //--------------------------------------------------------------------------------
            // Release all d3d resource.
            //--------------------------------------------------------------------------------
            BOOL Do_Shutdown()
            {
                Safe_Release(g_vertex_buffer);
                Safe_Release(g_d3d_device);
                Safe_Release(g_d3d);

                
            return TRUE;
            }

            //--------------------------------------------------------------------------------
            // Render a frame.
            //--------------------------------------------------------------------------------
            BOOL Do_Frame()
            {
                
            // clear device back buffer
                g_d3d_device->Clear(0, NULL, D3DCLEAR_TARGET, D3DCOLOR_RGBA(000255), 1.0f0);

                
            // Begin scene
                if(SUCCEEDED(g_d3d_device->BeginScene()))
                {
                    
            // set the vertex stream, shader, and texture.

                    
            // binds a vertex buffer to a device data stream
                    g_d3d_device->SetStreamSource(0, g_vertex_buffer, 0sizeof(VERTEX));

                    
            // set the current vertex stream declation
                    g_d3d_device->SetFVF(VERTEX_FVF);

                    
            // assigns a texture to a stage for a device
                    g_d3d_device->SetTexture(0, g_texture);

                    
            // disable alpha blending and draw 2 polygons
                    g_d3d_device->SetRenderState(D3DRS_ALPHABLENDENABLE, FALSE);
                    g_d3d_device
            ->DrawPrimitive(D3DPT_TRIANGLESTRIP, 02);

                    
            // enable alpha blending and draw 2 polygons
                    g_d3d_device->SetRenderState(D3DRS_ALPHABLENDENABLE, TRUE);
                    g_d3d_device
            ->SetRenderState(D3DRS_SRCBLEND, D3DBLEND_SRCALPHA);
                    g_d3d_device
            ->SetRenderState(D3DRS_DESTBLEND, D3DBLEND_INVSRCALPHA);
                    g_d3d_device
            ->DrawPrimitive(D3DPT_TRIANGLESTRIP, 42);        

                    
            // end the scene
                    g_d3d_device->EndScene();
                }

                
            // present the contents of the next buffer in the sequence of back buffers owned by the device
                g_d3d_device->Present(NULL, NULL, NULL, NULL);

                
            return TRUE;
            }

            //--------------------------------------------------------------------------------
            // Main function, routine entry.
            //--------------------------------------------------------------------------------
            int WINAPI WinMain(HINSTANCE inst, HINSTANCE, LPSTR cmd_line, int cmd_show)
            {
                WNDCLASSEX  win_class;
                MSG         msg;

                g_inst 
            = inst;

                
            // create window class and register it
                win_class.cbSize        = sizeof(win_class);
                win_class.style         
            = CS_CLASSDC;
                win_class.lpfnWndProc   
            = Window_Proc;
                win_class.cbClsExtra    
            = 0;
                win_class.cbWndExtra    
            = 0;
                win_class.hInstance     
            = inst;
                win_class.hIcon         
            = LoadIcon(NULL, IDI_APPLICATION);
                win_class.hCursor       
            = LoadCursor(NULL, IDC_ARROW);
                win_class.hbrBackground 
            = NULL;
                win_class.lpszMenuName  
            = NULL;
                win_class.lpszClassName 
            = g_class_name;
                win_class.hIconSm       
            = LoadIcon(NULL, IDI_APPLICATION);

                
            if(! RegisterClassEx(&win_class))
                    
            return FALSE;

                
            // create the main window
                g_hwnd = CreateWindow(g_class_name, g_caption, WS_CAPTION | WS_SYSMENU, 00,
                                      WINDOW_WIDTH, WINDOW_HEIGHT, NULL, NULL, inst, NULL);

                
            if(g_hwnd == NULL)
                    
            return FALSE;

                ShowWindow(g_hwnd, SW_NORMAL);
                UpdateWindow(g_hwnd);

                
            // initialize game
                if(Do_Init() == FALSE)
                    
            return FALSE;

                
            // start message pump, waiting for signal to quit.
                ZeroMemory(&msg, sizeof(MSG));

                
            while(msg.message != WM_QUIT)
                {
                    
            if(PeekMessage(&msg, NULL, 00, PM_REMOVE))
                    {
                        TranslateMessage(
            &msg);
                        DispatchMessage(
            &msg);
                    }
                    
                    
            // draw a frame
                    if(Do_Frame() == FALSE)
                        
            break;
                }

                
            // run shutdown function
                Do_Shutdown();

                UnregisterClass(g_class_name, inst);
                
                
            return (int) msg.wParam;
            }

            效果圖:




            posted on 2007-07-02 22:56 lovedday 閱讀(436) 評論(0)  編輯 收藏 引用 所屬分類: ■ DirectX 9 Program

            公告

            導航

            統計

            常用鏈接

            隨筆分類(178)

            3D游戲編程相關鏈接

            搜索

            最新評論

            日产精品99久久久久久| 久久久久久久综合综合狠狠| avtt天堂网久久精品| 精品久久久久国产免费| 亚洲午夜久久久| 婷婷综合久久中文字幕| 2021国内精品久久久久久影院| 久久大香香蕉国产| 亚洲精品午夜国产va久久| 国产精品久久久久一区二区三区| 日本久久久久久久久久| 国产精品久久久久jk制服| 久久亚洲天堂| 久久国产精品成人免费| 久久精品中文无码资源站| 久久精品女人天堂AV麻| 久久久久亚洲av无码专区喷水| 人人狠狠综合久久亚洲| 久久久精品一区二区三区| 伊人久久大香线蕉综合影院首页 | 欧美成a人片免费看久久| 欧美黑人激情性久久| 伊人久久大香线蕉成人| 99久久免费国产精品| 大伊人青草狠狠久久| 性欧美大战久久久久久久久| 狠狠色丁香久久婷婷综合_中| 久久久精品人妻无码专区不卡| 热99re久久国超精品首页| a级成人毛片久久| 国产成人久久激情91| 麻豆亚洲AV永久无码精品久久| 久久婷婷人人澡人人爽人人爱| 欧美麻豆久久久久久中文| 久久精品国产一区二区电影| 91精品国产91久久久久久| 久久综合九色综合97_久久久 | 久久精品国产乱子伦| 麻豆av久久av盛宴av| 色综合久久久久综合体桃花网 | 欧美大香线蕉线伊人久久|