青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

天行健 君子當自強而不息

D3D中粒子效果實現示例


源碼及素材下載

大爆炸,煙霧痕跡甚至魔術飛彈尾部發出的微小火花,都是粒子(particle)所制造出來的特殊效果。在適當的時機,啟用alpha混合并繪制粒子,這樣粒子就能朝向觀察點(使用公告板),得到的結果就是混合對象的抽象拼貼,他們可以用于創建一些奇妙的效果。

粒子奇妙的地方就在于粒子的大小實際上是任意的,原因在于可以創建一個縮放矩陣,使其同粒子多邊形的世界變換矩陣結合起來。也就是說,除非粒子紋理不同,否則只需要使用一個多邊形來繪制所有的粒子,無論如何,多邊形的數目都必須同紋理的數目保持一致。

還需要創建粒子圖像,圖像中心為一個實心(不透明)圓形,向圖像的邊緣延伸,圖像逐漸變透明,如下圖所示:



接著,需要設置4個頂點,這4個頂點使用了2個多邊形(可以使用三角形帶進行優化)。頂點的坐標表示粒子的缺省大小,稍后需要將粒子進行縮放,以適合這個大小。每個粒子都可以擁有獨特的屬性,包括粒子顏色(通過使用材質來實現)。

接下來,將這個結構體同一個含有兩個多邊形(創建一個正方形)的頂點緩沖結合起來,以便將多邊形渲染到3D設備上。在被繪制出來之前,每個粒子都需要通過它自己的世界矩陣進行定向(當然使用公告板)。然后將世界變換矩陣同每個粒子的縮放變換矩陣組合起來,再設置一個材質(使用 IDirect3DDevice::SetMaterial函數),用來改變粒子的顏色。最后,繪制粒子。

完整源碼如下所示:

/***************************************************************************************
PURPOSE:
    Particle Demo

Required libraries:
  WINMM.lib, D3D9.LIB, D3DX9.LIB.
 **************************************************************************************
*/

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

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

#pragma warning(disable : 
4305 4244)

#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[] = "ParticleClass";
static char g_caption[]    = "Particle Demo";

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

// the particle vertex buffer and texture
IDirect3DVertexBuffer9* g_particle_vb = NULL;
IDirect3DTexture9
*      g_particle_texture = NULL;

// The particle vertex format and descriptor
typedef struct
{
    
float x, y, z;      // 3D coordinates    
    D3DCOLOR diffuse;   // color
    float u, v;         // texture coordinates
} VERTEX;

#define VERTEX_FVF   (D3DFVF_XYZ | D3DFVF_DIFFUSE | D3DFVF_TEX1)

// create a structure for tracking particles
struct PARTICLE
{
    
float x_pos, y_pos, z_pos;  // coordinate
    float x_add, y_add, z_add;  // movement values
    float red, green, blue;     // colors
    long  timer, counter;       // current and update counter

    PARTICLE()
    {
        
// position particle at origin
        x_pos = y_pos = z_pos = 0.0;

        
// get a random update counter
        counter = rand() % 50 + 10;
        timer 
= 0;

        
// get a random speed
        x_add = (float)(rand() % 11- 5.0;
        y_add 
= (float)(rand() % 11- 5.0;
        z_add 
= (float)(rand() % 11- 5.0;

        
// get a random color
        red   = (float)(rand() % 101/ 100.0;
        green 
= (float)(rand() % 101/ 100.0;
        blue  
= (float)(rand() % 101/ 100.0;
    }
};

PARTICLE
* g_particles = 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);
}

//--------------------------------------------------------------------------------
// Copy vertex data into vertex buffer, create texture from file.
//--------------------------------------------------------------------------------
BOOL Setup_Particles()
{
    BYTE
* vertex_ptr;

    VERTEX verts[] 
= {
        { 
-50.0f50.0f0.0f0xFFFFFFFF0.0f0.0f },
        {  
50.0f50.0f0.0f0xFFFFFFFF1.0f0.0f },
        { 
-50.0f,  0.0f0.0f0xFFFFFFFF0.0f1.0f },
        {  
50.0f,  0.0f0.0f0xFFFFFFFF1.0f1.0f }
    };    

    
// create vertex buffers and stuff in data       
    if(FAILED(g_d3d_device->CreateVertexBuffer(sizeof(verts), 0, VERTEX_FVF, D3DPOOL_DEFAULT, &g_particle_vb, NULL)))   
        
return FALSE;   

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

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

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

    
// get textures    
    D3DXCreateTextureFromFile(g_d3d_device, "Particle.bmp"&g_particle_texture);    
    
    
// create some particles
    g_particles = new PARTICLE[512];

    
return TRUE;
}

//--------------------------------------------------------------------------------
// Initialize d3d, d3d device, vertex buffer, texutre; set render state for d3d;
// set perspective matrix.
//--------------------------------------------------------------------------------
BOOL Do_Init()
{
    D3DPRESENT_PARAMETERS present_param;
    D3DDISPLAYMODE  display_mode;
    D3DXMATRIX mat_proj, mat_view;    

    
// 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;
    present_param.EnableAutoDepthStencil 
= TRUE;
    present_param.AutoDepthStencilFormat 
= D3DFMT_D16;

    
// 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;     

    
// set render state

    
// enable d3d lighting
    g_d3d_device->SetRenderState(D3DRS_LIGHTING, TRUE);
    
// enable z-buffer
    g_d3d_device->SetRenderState(D3DRS_ZENABLE, D3DZB_TRUE);
    
// set ambient light to highest level (to see particles)
    g_d3d_device->SetRenderState(D3DRS_AMBIENT, 0xFFFFFFFF);

    
// create and set the projection matrix

    
// builds a left-handed perspective projection matrix based on a field of view
    D3DXMatrixPerspectiveFovLH(&mat_proj, D3DX_PI/4.01.01.01000.0);

    
// sets a single device transformation-related state
    g_d3d_device->SetTransform(D3DTS_PROJECTION, &mat_proj);

    
// create and set the view transformation
    D3DXMatrixLookAtLH(&mat_view, &D3DXVECTOR3(0.0f0.0f-500.0f), &D3DXVECTOR3(0.0f0.0f0.0f), 
                       
&D3DXVECTOR3(0.0f1.0f0.0f));

    g_d3d_device
->SetTransform(D3DTS_VIEW, &mat_view);

    
// create the meshes
    Setup_Particles();    

    
return TRUE;
}

//--------------------------------------------------------------------------------
// Release all d3d resource.
//--------------------------------------------------------------------------------
BOOL Do_Shutdown()
{
    delete[] g_particles;

    Safe_Release(g_particle_vb);
    Safe_Release(g_particle_texture);    
    Safe_Release(g_d3d_device);
    Safe_Release(g_d3d);

    
return TRUE;
}

//--------------------------------------------------------------------------------
// Render a frame.
//--------------------------------------------------------------------------------
BOOL Do_Frame()
{
    D3DXMATRIX mat_view, mat_world, mat_transposed, mat_transform;
    
static D3DMATERIAL9 s_material;
    
static BOOL  s_is_mat_init = TRUE;
    
static DWORD s_counter = timeGetTime();

    
// limit to 30fps
    if(timeGetTime() < s_counter+33)
        
return TRUE;

    s_counter 
= timeGetTime();

    
// configure the material if first time called
    if(s_is_mat_init = TRUE)
    {
        s_is_mat_init 
= FALSE;
        ZeroMemory(
&s_material, sizeof(s_material));
        s_material.Diffuse.a 
= s_material.Ambient.a = 0.5f;
    }

    
// clear device back buffer
    g_d3d_device->Clear(0, NULL, D3DCLEAR_TARGET | D3DCLEAR_ZBUFFER, D3DCOLOR_RGBA(064128255), 1.0f0);    

    
// Begin scene
    if(SUCCEEDED(g_d3d_device->BeginScene()))
    {
        
// set the particle source, shader, texture.            
        g_d3d_device->SetStreamSource(0, g_particle_vb, 0sizeof(VERTEX));
        g_d3d_device
->SetFVF(VERTEX_FVF);
        g_d3d_device
->SetTexture(0, g_particle_texture);

        
// get and set the transposed view matrix (billboard technique)
        g_d3d_device->GetTransform(D3DTS_VIEW, &mat_view);
        D3DXMatrixTranspose(
&mat_transposed, &mat_view);

        
// enable alpha blending
        g_d3d_device->SetRenderState(D3DRS_ALPHABLENDENABLE, TRUE);
        g_d3d_device
->SetRenderState(D3DRS_SRCBLEND, D3DBLEND_SRCALPHA);
        g_d3d_device
->SetRenderState(D3DRS_DESTBLEND, D3DBLEND_ONE);    

        
// loop through all particles and draw them
        for(short i = 0; i < 512; i++)
        {
            
// move particle first
            g_particles[i].x_pos += g_particles[i].x_add;
            g_particles[i].y_pos 
+= g_particles[i].y_add;
            g_particles[i].z_pos 
+= g_particles[i].z_add;

            
// reverse movements if past counter
            if((g_particles[i].timer += 1>= g_particles[i].counter)
            {
                g_particles[i].timer 
= 0;
                g_particles[i].x_add 
*= -1.0f;
                g_particles[i].y_add 
*= -1.0f;
                g_particles[i].z_add 
*= -1.0f;
            }

            
// setup the particle's world transformation
            D3DXMatrixTranslation(&mat_transform, g_particles[i].x_pos, g_particles[i].y_pos, g_particles[i].z_pos);
            D3DXMatrixMultiply(
&mat_world, &mat_transform, &mat_transposed);
            g_d3d_device
->SetTransform(D3DTS_WORLD, &mat_world);

            
// set the particle's material
            s_material.Diffuse.r = s_material.Ambient.r = g_particles[i].red;
            s_material.Diffuse.g 
= s_material.Ambient.g = g_particles[i].green;
            s_material.Diffuse.b 
= s_material.Ambient.b = g_particles[i].blue;
                
            
// Sets the material properties for the device
            g_d3d_device->SetMaterial(&s_material);

            
// draw the particle
            g_d3d_device->DrawPrimitive(D3DPT_TRIANGLESTRIP, 02);
        }        

        
// release texture
        g_d3d_device->SetTexture(0, NULL);

        
// 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-04 14:52 lovedday 閱讀(1914) 評論(0)  編輯 收藏 引用 所屬分類: ■ DirectX 9 Program

公告

導航

統計

常用鏈接

隨筆分類(178)

3D游戲編程相關鏈接

搜索

最新評論

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美日韩国语| 亚洲一区二区三区午夜| 香港久久久电影| 欧美二区视频| 欧美激情第8页| 亚洲黄网站黄| 国产精品久久久久久亚洲毛片| 久久精品亚洲乱码伦伦中文 | 亚洲视频免费在线| 亚洲一级电影| 亚洲综合另类| 久久精品一区二区三区四区| 亚洲免费观看高清完整版在线观看| 欧美xx69| 99视频国产精品免费观看| 夜夜嗨av一区二区三区网站四季av | 一区一区视频| 亚洲精品在线视频| 小处雏高清一区二区三区| 久久久久成人精品| 亚洲黄色在线观看| 亚洲午夜激情网页| 欧美a级片网站| 国产精品theporn| 国产一区二区三区精品欧美日韩一区二区三区| 国产精品视频一| 日韩一区二区福利| 老巨人导航500精品| 在线亚洲伦理| 欧美日韩国产一区| 亚洲肉体裸体xxxx137| 国产婷婷一区二区| 国产精品国产三级国产| 精东粉嫩av免费一区二区三区| 亚洲电影免费观看高清完整版在线观看 | 亚洲激情视频在线播放| 亚洲日本欧美在线| 香蕉成人伊视频在线观看| 老司机午夜精品视频| 国内免费精品永久在线视频| 亚洲乱码国产乱码精品精天堂 | 久久综合久久久久88| 亚洲少妇在线| 国产区欧美区日韩区| 午夜精品视频在线观看| 亚洲一级网站| 国内精品久久国产| 免费久久99精品国产自在现线| 久久aⅴ乱码一区二区三区| 国产精品久久影院| 亚洲在线视频| 亚洲国产日韩一级| 亚洲欧洲日本在线| 欧美激情1区2区3区| 99re6热在线精品视频播放速度| 亚洲国产欧美一区二区三区丁香婷| 久久蜜桃香蕉精品一区二区三区| 国内精品嫩模av私拍在线观看| 欧美在线播放| 欧美成人一区二免费视频软件| 国产精品99久久久久久久女警| 亚洲精品一区二区三区四区高清 | 亚洲视屏一区| 国产欧美日韩麻豆91| 欧美不卡高清| 国产伦精品一区二区三区高清版 | 在线精品视频一区二区三四| 亚洲国产成人91精品| 国产裸体写真av一区二区| 欧美电影在线观看| 欧美日韩国产一中文字不卡| 亚洲激情电影在线| 久久国产主播| 亚洲小视频在线观看| 欧美a级一区二区| 欧美成年视频| 亚洲高清三级视频| 老牛嫩草一区二区三区日本| 欧美一区二区精美| 国产精品三区www17con| 午夜日韩在线| 国内精品久久久久影院 日本资源| 亚洲欧美日韩一区| 欧美黑人一区二区三区| 女人香蕉久久**毛片精品| 国产日韩欧美成人| 久久露脸国产精品| 亚洲欧洲一区二区三区| 亚洲欧洲日本国产| 欧美欧美午夜aⅴ在线观看| 最新中文字幕亚洲| 欧美亚洲视频一区二区| 欧美日韩一区二区在线观看视频| 玖玖综合伊人| 日韩视频免费| 亚洲另类黄色| 亚洲男人的天堂在线| 一区二区三区无毛| 欧美破处大片在线视频| 亚洲黄色成人| 久久亚洲影院| 亚洲欧美日韩天堂一区二区| 国产区精品在线观看| 欧美日韩免费高清| 久久国产主播| 99热这里只有精品8| 久久人人看视频| 校园激情久久| 亚洲一区在线播放| 亚洲国产精品99久久久久久久久| 欧美日韩精品综合在线| 老司机午夜精品视频在线观看| 亚洲制服少妇| 午夜欧美精品| 欧美一区二区三区免费观看| aa国产精品| 欧美在线综合| 国产精品一区二区在线| 欧美精品在线观看91| 亚洲国产精品va在看黑人| 亚洲福利av| 亚洲国产精品久久久久久女王| 国产一区二区三区四区| 国产精品免费一区二区三区在线观看 | 激情六月婷婷久久| 伊人久久综合97精品| 国产真实乱子伦精品视频| 国产日韩免费| 亚洲欧洲综合另类| 亚洲色图自拍| 久久男女视频| 欧美成人r级一区二区三区| 日韩视频第一页| 欧美激情导航| 午夜在线视频观看日韩17c| 欧美主播一区二区三区美女 久久精品人 | 欧美激情第8页| 一本大道久久a久久精二百| 午夜亚洲一区| 国产精品国产三级国产aⅴ9色| 国内精品视频在线观看| 亚洲精品美女久久久久| 欧美亚洲三区| 在线亚洲伦理| 欧美激情视频在线播放 | 欧美日本亚洲| 欧美一级理论片| 久久精品亚洲国产奇米99| 欧美日韩1234| 亚洲国产成人精品女人久久久 | 亚洲国语精品自产拍在线观看| 亚洲免费视频一区二区| 美国十次成人| 久久久国产一区二区| 国产精品美女久久久| 99国内精品久久| 亚洲欧洲一区二区三区在线观看| 亚洲午夜av在线| 欧美大成色www永久网站婷| 亚洲欧美视频在线观看| 国产精品国产三级国产专区53 | 亚洲欧洲一区二区三区久久| 久久人人九九| 在线观看亚洲视频| 蜜乳av另类精品一区二区| 久久精品99国产精品日本| 精品av久久久久电影| 欧美国产日韩一区二区三区| 久久综合一区| 一区二区三区精品视频在线观看| 亚洲国产日韩一区二区| 欧美视频一区二区三区四区| 亚久久调教视频| 久久久久免费| 国产精品人人爽人人做我的可爱| 国产午夜精品美女视频明星a级| 午夜精品福利视频| 久久九九久久九九| 亚洲专区在线视频| 久久久久这里只有精品| 日韩香蕉视频| 久久经典综合| 欧美亚洲视频一区二区| 欧美欧美天天天天操| 农夫在线精品视频免费观看| 欧美精品一区二| 欧美成人资源网| 国产午夜亚洲精品理论片色戒| 欧美多人爱爱视频网站| 国产三级欧美三级日产三级99| 亚洲国产成人av| 亚洲国产欧美国产综合一区| 亚洲欧美日韩视频一区| 亚洲午夜精品在线| 免费欧美高清视频| 亚洲国产精品久久久久婷婷老年 | 亚洲黄色av| 中文国产亚洲喷潮| 国产一区二区三区在线观看免费视频 | 欧美一区二区三区在线|