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

天行健 君子當(dāng)自強(qiáng)而不息

Direct3D中的霧化(3)

基于范圍霧化的示例程序

要使用基于范圍的霧化,首先需要檢查當(dāng)前硬件是否支持基于范圍的霧化:

	// check if hardware supports range fog
	D3DCAPS9 caps;
g_device->GetDeviceCaps(&caps);
	if(! (caps.RasterCaps & D3DPRASTERCAPS_FOGRANGE))
return false;

在設(shè)置霧的顏色時(shí),可將霧的顏色和背景顏色設(shè)置為一致,這樣遠(yuǎn)處的物體看起來就像逐漸融入到背景中,視覺效果比較逼真。

霧化參數(shù)中,霧的開始距離和結(jié)束距離只對線性霧化有效,霧的濃度只對指數(shù)霧化和指數(shù)平方霧化有效。

無論頂點(diǎn)霧化還是像素霧化,在程序中必須設(shè)置合適的投影變換矩陣確保霧化效果正確,這在為那些不使用頂點(diǎn)坐標(biāo)變換和光照流水線的程序中添加霧化效果造成了一定的困難,不過這種情況不多。

為了比較基于范圍的霧化和不基于范圍的霧化效果的不同,可以按下"R"鍵在基于范圍的霧化和不基于范圍的霧化之間進(jìn)行切換。

 

源程序:

#include <d3dx9.h>

#pragma warning(disable : 
4127)

#define CLASS_NAME    "GameApp"

#define release_com(p)    do { if(p) { (p)->Release(); (p) = NULL; } } while(0)

IDirect3D9
*                g_d3d;
IDirect3DDevice9
*        g_device;

ID3DXMesh
*                g_mesh;
D3DMATERIAL9
*            g_mesh_materials;
IDirect3DTexture9
**        g_mesh_textures;
DWORD                    g_num_materials;

struct sVertex 

    
float x, y, z;
    
float u, v;
};

inline 
float height_field(float x, float z)
{
    
float y = 0.0f;

    y 
+= 10.0f * cosf(0.051f * x) * sinf(0.055f * x);
    y 
+= 10.0f * cosf(0.053f * z) * sinf(0.057f * z);
    y 
+= 2.0f  * cosf(0.101f * x) * sinf(0.105f * x);
    y 
+= 2.0f  * cosf(0.103f * z) * sinf(0.107f * z);
    y 
+= 2.0f  * cosf(0.251f * x) * sinf(0.255f * x);
    y 
+= 2.0f  * cosf(0.253f * z) * sinf(0.257f * z);

    
return y;
}

void setup_matrices()
{
    
// setup world matrix
    D3DXMATRIX mat_world;    
    D3DXMatrixIdentity(
&mat_world);
    g_device
->SetTransform(D3DTS_WORLD, &mat_world);

    
// setup view matrix

    D3DXVECTOR3 eye(
0.0f30.0f-100.0f);
    D3DXVECTOR3 at(
0.0f,  0.0f,     0.0f);
    D3DXVECTOR3 up(
0.0f,  1.0f,     0.0f);

    D3DXMATRIX mat_view;
    D3DXMatrixLookAtLH(
&mat_view, &eye, &at, &up);
    g_device
->SetTransform(D3DTS_VIEW, &mat_view);

    
// setup projection matrix
    D3DXMATRIX mat_proj;
    D3DXMatrixPerspectiveFovLH(
&mat_proj, D3DX_PI/41.0f1.0f500.0f);
    g_device
->SetTransform(D3DTS_PROJECTION, &mat_proj);
}

bool init_geometry()
{
    ID3DXBuffer
* material_buffer;

    
/*
     D3DXLoadMeshFromXA(
        LPCSTR pFilename, 
        DWORD Options, 
        LPDIRECT3DDEVICE9 pD3DDevice, 
        LPD3DXBUFFER *ppAdjacency,
        LPD3DXBUFFER *ppMaterials, 
        LPD3DXBUFFER *ppEffectInstances, 
        DWORD *pNumMaterials,
        LPD3DXMESH *ppMesh);
    
*/

    
if(FAILED(D3DXLoadMeshFromX("seafloor.x", D3DXMESH_SYSTEMMEM, g_device, NULL, &material_buffer, NULL,
                                
&g_num_materials, &g_mesh)))
    {
        MessageBox(NULL, 
"Could not find seafloor.x""ERROR", MB_OK);
        
return false;
    }

    D3DXMATERIAL
* xmaterials = (D3DXMATERIAL*) material_buffer->GetBufferPointer();

    g_mesh_materials 
= new D3DMATERIAL9[g_num_materials];
    g_mesh_textures     
= new IDirect3DTexture9*[g_num_materials];

    
for(DWORD i = 0; i < g_num_materials; i++)
    {
        g_mesh_materials[i] 
= xmaterials[i].MatD3D;

        
// set ambient reflected coefficient, because .x file do not set it.
        g_mesh_materials[i].Ambient = g_mesh_materials[i].Diffuse;

        g_mesh_textures[i] 
= NULL;

        
if(xmaterials[i].pTextureFilename != NULL && strlen(xmaterials[i].pTextureFilename) > 0)    
            D3DXCreateTextureFromFile(g_device, xmaterials[i].pTextureFilename, 
&g_mesh_textures[i]);    
    }

    material_buffer
->Release();

    
// change model's height

    IDirect3DVertexBuffer9
* vertex_buffer;
    g_mesh
->GetVertexBuffer(&vertex_buffer);

    sVertex
* vertices;
    vertex_buffer
->Lock(00, (void**)&vertices, 0);
    
    DWORD num_vertices 
= g_mesh->GetNumVertices();

    
for(DWORD i = 0; i < num_vertices; i++)
        vertices[i].y 
= height_field(vertices[i].x, vertices[i].z);

    vertex_buffer
->Unlock();
    vertex_buffer
->Release();

    
return true;
}

bool init_d3d(HWND hwnd)
{
    g_d3d 
= Direct3DCreate9(D3D_SDK_VERSION);

    
if(g_d3d == NULL)
        
return false;

    D3DPRESENT_PARAMETERS d3dpp;
    ZeroMemory(
&d3dpp, sizeof(d3dpp));

    d3dpp.Windowed                    
= TRUE;
    d3dpp.SwapEffect                
= D3DSWAPEFFECT_DISCARD;
    d3dpp.BackBufferFormat            
= D3DFMT_UNKNOWN;
    d3dpp.EnableAutoDepthStencil    
= TRUE;
    d3dpp.AutoDepthStencilFormat    
= D3DFMT_D16;

    
if(FAILED(g_d3d->CreateDevice(D3DADAPTER_DEFAULT, D3DDEVTYPE_HAL, hwnd, D3DCREATE_SOFTWARE_VERTEXPROCESSING,
                                  
&d3dpp, &g_device)))
    {
        
return false;
    }

    
// check if hardware supports range fog

    D3DCAPS9 caps;
    g_device
->GetDeviceCaps(&caps);

    
if(! (caps.RasterCaps & D3DPRASTERCAPS_FOGRANGE))
        
return false;
    
    
if(! init_geometry())
        
return false;

    setup_matrices();        

    g_device
->SetTextureStageState(0, D3DTSS_COLORARG1,        D3DTA_TEXTURE);
    g_device
->SetTextureStageState(0, D3DTSS_COLOROP,        D3DTOP_SELECTARG1);    
    g_device
->SetSamplerState(0, D3DSAMP_MINFILTER,    D3DTEXF_LINEAR);
    g_device
->SetSamplerState(0, D3DSAMP_MAGFILTER,    D3DTEXF_LINEAR);

    g_device
->SetRenderState(D3DRS_RANGEFOGENABLE,    TRUE);
    g_device
->SetRenderState(D3DRS_FOGCOLOR,        0xFF101010);    
    g_device
->SetRenderState(D3DRS_AMBIENT,            0xFF00BB55);
    
    
return true;
}

void cleanup()
{
    delete[] g_mesh_materials;

    
if(g_mesh_textures)
    {
        
for(DWORD i = 0; i < g_num_materials; i++)
            release_com(g_mesh_textures[i]);

        delete[] g_mesh_textures;
    }
    
    release_com(g_mesh);
    release_com(g_device);
    release_com(g_d3d);
}

void render()
{
    g_device
->Clear(0, NULL, D3DCLEAR_TARGET | D3DCLEAR_ZBUFFER, D3DCOLOR_XRGB(555), 1.0f0);

    g_device
->BeginScene();

    
for(DWORD i = 0; i < g_num_materials; i++)
    {
        g_device
->SetMaterial(&g_mesh_materials[i]);
        g_device
->SetTexture(0, g_mesh_textures[i]);

        g_mesh
->DrawSubset(i);    
    }
    
    g_device
->EndScene();

    g_device
->Present(NULL, NULL, NULL, NULL);
}

LRESULT WINAPI WinProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam)
{
    
static float fog_start   = 50;
    
static float fog_end     = 200;
    
static float fog_density = 0.01f;

    
static bool use_range_fog = true;

    
switch(msg)
    {
    
case WM_KEYDOWN:
        
switch(wParam)
        {
        
case 48// press key "0", disable fog.
            g_device->SetRenderState(D3DRS_FOGENABLE, FALSE);
            
break;

        
case 49// press key "1", enable linear fog.
            g_device->SetRenderState(D3DRS_FOGENABLE,        TRUE);
            g_device
->SetRenderState(D3DRS_FOGVERTEXMODE,    D3DFOG_LINEAR);
            g_device
->SetRenderState(D3DRS_FOGSTART,        *(DWORD*)&fog_start);
            g_device
->SetRenderState(D3DRS_FOGEND,            *(DWORD*)&fog_end);
            
break;

        
case 50// press key "2", enable exp fog.
            g_device->SetRenderState(D3DRS_FOGENABLE,        TRUE);
            g_device
->SetRenderState(D3DRS_FOGVERTEXMODE,    D3DFOG_EXP);
            g_device
->SetRenderState(D3DRS_FOGDENSITY,        *(DWORD*)&fog_density);            
            
break;

        
case 51// press key "3", enable exp2 fog.
            g_device->SetRenderState(D3DRS_FOGENABLE,        TRUE);
            g_device
->SetRenderState(D3DRS_FOGVERTEXMODE,    D3DFOG_EXP2);
            g_device
->SetRenderState(D3DRS_FOGDENSITY,        *(DWORD*)&fog_density);            
            
break;

        
case 65 + 'R' - 'A':
            use_range_fog 
= !use_range_fog;
            g_device
->SetRenderState(D3DRS_RANGEFOGENABLE, use_range_fog);
            
break;

        
case VK_ESCAPE:
            DestroyWindow(hwnd);
            
break;
        }    

        
break;

    
case WM_DESTROY:
        PostQuitMessage(
0);
        
return 0;
    }

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

int WINAPI WinMain(HINSTANCE inst, HINSTANCE, LPSTR, INT)
{
    WNDCLASSEX wc;

    wc.cbSize            
= sizeof(WNDCLASSEX);
    wc.style            
= CS_CLASSDC;
    wc.lpfnWndProc        
= WinProc;
    wc.cbClsExtra        
= 0;
    wc.cbWndExtra        
= 0;
    wc.hInstance        
= inst;
    wc.hIcon            
= NULL;
    wc.hCursor            
= NULL;
    wc.hbrBackground    
= NULL;
    wc.lpszMenuName        
= NULL;
    wc.lpszClassName    
= CLASS_NAME;
    wc.hIconSm            
= NULL;

    
if(! RegisterClassEx(&wc))
        
return -1;

    HWND hwnd 
= CreateWindow(CLASS_NAME, "Direct3D App", WS_OVERLAPPEDWINDOW, 200100640480,
                             NULL, NULL, wc.hInstance, NULL);    

    
if(hwnd == NULL)
        
return -1;

    
if(init_d3d(hwnd))
    {
        ShowWindow(hwnd, SW_SHOWDEFAULT);
        UpdateWindow(hwnd);

        MSG msg;
        ZeroMemory(
&msg, sizeof(msg));

        
while(msg.message != WM_QUIT)
        {
            
if(PeekMessage(&msg, NULL, 00, PM_REMOVE))
            {
                TranslateMessage(
&msg);
                DispatchMessage(
&msg);
            }
                
            render();
            Sleep(
10);
        }
    }

    cleanup();
    UnregisterClass(CLASS_NAME, wc.hInstance);    

    
return 0;
}

 

下載示例工程


posted on 2008-05-11 18:20 lovedday 閱讀(800) 評論(0)  編輯 收藏 引用


只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


公告

導(dǎo)航

統(tǒng)計(jì)

常用鏈接

隨筆分類(178)

3D游戲編程相關(guān)鏈接

搜索

最新評論

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲黄色在线看| 91久久精品国产91久久| 午夜精品亚洲一区二区三区嫩草| 欧美黄色一区二区| 亚洲国产欧美另类丝袜| 亚洲精品护士| 亚洲欧美在线网| 久久久精品欧美丰满| 老鸭窝91久久精品色噜噜导演| 免费观看日韩av| 欧美日韩美女| 国内伊人久久久久久网站视频| 亚洲大片av| 亚洲一区免费在线观看| 久久蜜臀精品av| 亚洲国产乱码最新视频| 亚洲一级片在线看| 美女黄毛**国产精品啪啪| 欧美视频在线视频| 一区在线视频| 亚洲影院色无极综合| 欧美成人dvd在线视频| 在线亚洲精品| 狼人社综合社区| 国产精品婷婷| 在线高清一区| 久久精品99国产精品酒店日本| 久久精品国产99国产精品澳门| 免费成人在线视频网站| 一区二区三区精品视频| 久久影院午夜片一区| 国产精品稀缺呦系列在线| 亚洲福利在线视频| 午夜日韩av| 亚洲精品四区| 麻豆久久久9性大片| 国产免费观看久久黄| 在线亚洲一区观看| 亚洲第一色在线| 欧美自拍偷拍午夜视频| 欧美亚日韩国产aⅴ精品中极品| 亚洲国产福利在线| 久久久久久夜精品精品免费| 亚洲香蕉在线观看| 欧美日韩精品一本二本三本| 亚洲精品综合精品自拍| 免费在线欧美视频| 久久国产乱子精品免费女 | 亚洲免费观看高清完整版在线观看熊| 午夜亚洲福利在线老司机| 欧美日韩精品一区二区三区四区| 最近中文字幕mv在线一区二区三区四区 | 久久久成人网| 国产亚洲va综合人人澡精品| 亚洲在线成人精品| 日韩视频在线播放| 欧美日韩美女在线观看| 一本一本a久久| 亚洲国产精品久久久久秋霞蜜臀 | 久久久999成人| 国精品一区二区三区| 欧美中文在线视频| 亚洲欧美日韩在线不卡| 国产欧美日韩激情| 久久精品日韩| 久久影院亚洲| 99精品欧美一区二区三区综合在线| 欧美国产日本| 欧美激情第1页| 亚洲视频视频在线| 午夜精品免费| 一区二区视频欧美| 亚洲国产精品va在线看黑人动漫| 欧美激情一区二区久久久| 夜夜嗨av一区二区三区四区| 99re66热这里只有精品3直播 | 久久偷窥视频| 欧美亚洲午夜视频在线观看| 亚洲免费观看| 久久精品亚洲一区| 亚洲国产91| 日韩亚洲欧美一区| 国产精品亚洲欧美| 免费在线欧美视频| 欧美日韩免费在线观看| 欧美在现视频| 卡一卡二国产精品| 亚洲一区在线看| 久久久中精品2020中文| 六月丁香综合| 久久久久在线| 国内成人在线| 亚洲高清毛片| 亚洲精华国产欧美| 国产精品久久久久999| 久久精品夜色噜噜亚洲a∨ | 国产在线观看精品一区二区三区| 久久午夜精品| 欧美日韩精品高清| 快射av在线播放一区| 欧美日韩不卡在线| 久久免费国产| 国产精品毛片在线| 欧美激情精品久久久久久蜜臀| 欧美揉bbbbb揉bbbbb| 噜噜噜噜噜久久久久久91| 欧美色大人视频| 欧美激情第六页| 韩国av一区| 亚洲一区二区三区在线看| 亚洲精品一区二区三区av| 欧美在线播放视频| 亚洲欧美国产日韩天堂区| 蜜月aⅴ免费一区二区三区| 欧美一激情一区二区三区| 欧美日韩免费一区二区三区视频 | 99re8这里有精品热视频免费 | 久久亚洲私人国产精品va| 欧美无砖砖区免费| 亚洲精品国产精品国自产在线| 国产一区二区三区久久| 亚洲欧美一区二区在线观看| 亚洲午夜影视影院在线观看| 快she精品国产999| 免费精品视频| 精品动漫3d一区二区三区免费| 亚洲影院色在线观看免费| 在线亚洲精品福利网址导航| 欧美福利视频在线| 亚洲国产日本| 日韩网站在线| 欧美日韩免费在线| 一本色道久久加勒比88综合| 一本久久综合亚洲鲁鲁| 亚洲曰本av电影| 国产麻豆精品在线观看| 亚洲人成网站在线播| 91久久香蕉国产日韩欧美9色| 欧美在线观看你懂的| 欧美一区二区在线免费播放| 国产精品狼人久久影院观看方式| 一本在线高清不卡dvd| 这里是久久伊人| 欧美日韩综合视频网址| 一本色道久久| 欧美综合国产| 激情成人av| 免费欧美在线视频| 亚洲精品国产精品乱码不99| 日韩一级免费观看| 欧美日韩国产一区| 宅男噜噜噜66一区二区 | 在线日韩av永久免费观看| 久久一区欧美| 亚洲欧洲一区二区天堂久久| 99在线热播精品免费99热| 国产精品成人在线| 欧美亚洲自偷自偷| 欧美激情小视频| 亚洲天天影视| 激情六月婷婷久久| 欧美精品一区二区三区久久久竹菊| 日韩视频欧美视频| 久久欧美肥婆一二区| 亚洲免费观看| 国产亚洲精品高潮| 欧美精品一区二区在线播放| 亚洲一区三区在线观看| 免费在线一区二区| 午夜精品久久久久久久白皮肤| 国模 一区 二区 三区| 欧美韩国在线| 欧美在线视频免费观看| 最新日韩在线视频| 久久婷婷激情| 中文在线不卡视频| 一色屋精品视频免费看| 国产精品国产三级国产aⅴ无密码 国产精品国产三级国产aⅴ入口 | 这里只有精品视频| 欧美 日韩 国产在线| 午夜精品视频在线观看一区二区 | 久久国产主播| 夜夜夜精品看看| 亚洲成人在线视频网站| 国产精品久久久久高潮| 欧美大胆成人| 久久综合九色综合网站| 亚洲你懂的在线视频| 91久久久一线二线三线品牌| 久久精品视频在线| 亚洲女人天堂成人av在线| 亚洲精品日韩在线观看| 一区二区视频欧美| 国产婷婷色一区二区三区四区| 欧美高清视频一区| 欧美一区二区高清| 久久精品国产99国产精品澳门 | 亚洲精品一级| 一区二区三区在线观看国产| 国产酒店精品激情|