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

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

紋理映射基礎(chǔ)(4)

最近點采樣

最近點采樣是4種過濾方式中速度最快但效果最差的過濾方式。Direct3D計算得到的紋理元素地址通常是一個浮點數(shù)值,而非整數(shù)的紋理下標(biāo)值,當(dāng)使用最近點采樣時,Direct3D會復(fù)制與這個浮點值地址最接近的整數(shù)地址的紋理元素的顏色。

設(shè)置最近點采樣的具體方法如下:調(diào)用IDirect3DDevice9::SetSamplerState(),可分別設(shè)置紋理過濾的放大過濾器和縮小過濾器。將第一個參數(shù)設(shè)置為紋理過濾器關(guān)聯(lián)的紋理層序號(0~7)。如果要設(shè)置放大過濾器,第二個參數(shù)設(shè)為D3DSAMP_MAGFILTER,如果要設(shè)置縮小過濾器,第二個參數(shù)設(shè)為D3DSAMP_MINFILTER。第三個參數(shù)可設(shè)為表示最近點采樣的枚舉常量D3DTEXF_POINT。下列代碼將紋理層0的紋理過濾方式設(shè)置為最近點采樣。

g_device->SetSamplerState(0, D3DSAMP_MAGFILTER, D3DTEXF_POINT);
g_device->SetSamplerState(0, D3DSAMP_MINFILTER, D3DTEXF_POINT);

如果紋理的大小和屏幕圖元的實際大小將近,那么采用最近點采樣方法對圖像質(zhì)量的影響不大。但是,如果大小相差太多,就會降低圖像精度,從而影響圖像質(zhì)量,出現(xiàn)色塊或閃爍的失真現(xiàn)象。

 

線性紋理過濾

線性紋理過濾是目前使用最廣泛的紋理過濾方法。它與最近點采樣相比,能有效地提高圖像的顯示質(zhì)量,并且對系統(tǒng)性能影響不大。線性紋理過濾取得與計算得到的紋理元素的浮點地址最接近的上、下、左、右4個紋理元素,對這4個紋理元素進行加權(quán)平均,得到最終顯示的顏色值。

與設(shè)置最近點采樣的方法相似,調(diào)用函數(shù)IDirect3DDevice9::SetSamplerState()設(shè)置線性紋理過濾,所不同的是第三個參數(shù)設(shè)置為D3DTEXF_LINEAR。下面的代碼將紋理層0的放大和縮小過濾器設(shè)置為線性紋理過濾。

g_device->SetSamplerState(0, D3DSAMP_MAGFILTER, D3DTEXF_LINEAR);
g_device->SetSamplerState(0, D3DSAMP_MINFILTER, D3DTEXF_LINEAR);

因為是在單一紋理層上的線性過濾,而且是x、y方向上的線性過濾,所以稱為雙線性紋理過濾。目前大多數(shù)顯卡都為線性紋理過濾進行了優(yōu)化,所以使用線性紋理過濾一方面可以獲得較好的圖形質(zhì)量,另一方面對程序性能影響不大。

 

各項異性紋理過濾

當(dāng)三維物體表面與投影平面不平行時,它在屏幕上的投影會有拉長或扭曲,這種現(xiàn)象稱為各項異性(anisotropy)。當(dāng)一個各向異性圖元的像素映射到紋理元素時,它的形狀發(fā)生扭曲。Direct3D根據(jù)屏幕像素反向轉(zhuǎn)換到紋理元素的延長度,決定各項異性程度。

要使用各項異性紋理過濾,還應(yīng)當(dāng)設(shè)置最大各項異性程度值。通過將函數(shù)IDirect3DDevive9::SetSamplerState()的第一個參數(shù)設(shè)為紋理層索引,第二個參數(shù)設(shè)為D3DSAMP_MAXANISOTOPY,第三個參數(shù)設(shè)為大于1的任何值,可以完成最大各項異性程度值的設(shè)置。下面的示例代碼指定了最大各項異性值為4。

g_device->SetSamplerState(0, D3DSAMP_MAGFILTER, D3DTEXF_ANISOTROPIC);
g_device->SetSamplerState(0, D3DSAMP_MINFILTER, D3DTEXF_ANISOTROPIC);
g_device->SetSamplerState(0, D3DSAMP_MAXANISOTROPY, 4);

最大各項異性程度值D3DSAMP_MAXANISOTROPY為1時,表示禁用各項異性過濾。一般說來,其值越大,圖像效果越好,計算量越大,速度越慢。需要注意的是,在設(shè)置最大各項異性之前,應(yīng)調(diào)用IDirect3D9::GetDeviceCaps()函數(shù),查詢當(dāng)前設(shè)備支持的Direct3D特性,獲取當(dāng)前設(shè)備支持的最大各項異性度的取值范圍,具體代碼如下:

DWORD get_max_anisotropy(IDirect3DDevice9* device)
{
D3DCAPS9 caps;
device->GetDeviceCaps(&caps);
	return caps.MaxAnisotropy;
}

 

紋理過濾方式示例程序

按下數(shù)字鍵“1”使用最近點采樣紋理過濾方式,按下數(shù)字鍵“2”使用線性紋理過濾方式,按下數(shù)字鍵“3”使用各項異性紋理過濾方式。

 

源程序:

#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;
IDirect3DVertexBuffer9
* g_vertex_buffer;
IDirect3DTexture9
*        g_texture;

struct sCustomVertex
{
    
float x, y, z;
    
float u, v;
};

#define D3DFVF_CUSTOM_VERTEX (D3DFVF_XYZ | D3DFVF_TEX1) 

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

    
// setup view matrix

    D3DXVECTOR3 eye(
0.0f0.0f-8.0f);
    D3DXVECTOR3 at(
0.0f0.0f0.0f);
    D3DXVECTOR3 up(
0.0f1.0f0.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.0f100.0f);
    g_device
->SetTransform(D3DTS_PROJECTION, &mat_proj);
}

bool init_graphics()
{    
    
if(FAILED(D3DXCreateTextureFromFile(g_device, "texture.jpg"&g_texture)))
    {
        MessageBox(NULL, 
"Create texture failed!""ERROR", MB_OK);
        
return false;
    }

    sCustomVertex vertices[] 
=
    {
        { 
-3,   -3,  0.0f,  0.0f1.0f},   
        { 
-3,    3,  0.0f,  0.0f0.0f},    
        {  
3,   -3,  0.0f,  1.0f1.0f},    
        {  
3,    3,  0.0f,  1.0f0.0f }

    };

    g_device
->CreateVertexBuffer(sizeof(vertices), 0, D3DFVF_CUSTOM_VERTEX, D3DPOOL_MANAGED, &g_vertex_buffer, NULL);

    
void* ptr;

    g_vertex_buffer
->Lock(00, (void**)&ptr, 0);
    memcpy(ptr, vertices, 
sizeof(vertices));    
    g_vertex_buffer
->Unlock();

    
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;

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

    setup_matrices();

    g_device
->SetRenderState(D3DRS_LIGHTING, FALSE);    
    
    
return true;
}

void cleanup()
{
    release_com(g_texture);
    release_com(g_vertex_buffer);
    release_com(g_device);
    release_com(g_d3d);
}

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

    g_device
->BeginScene();

    g_device
->SetTexture(0, g_texture);

    g_device
->SetStreamSource(0, g_vertex_buffer, 0sizeof(sCustomVertex));
    g_device
->SetFVF(D3DFVF_CUSTOM_VERTEX);
    g_device
->DrawPrimitive(D3DPT_TRIANGLESTRIP, 02);

    g_device
->EndScene();

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

LRESULT WINAPI WinProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam)
{
    
switch(msg)
    {
    
case WM_KEYDOWN:
        
switch(wParam)
        {
        
case VK_ESCAPE:
            DestroyWindow(hwnd);
            
break;

        
case 49:    // press key "1", use nearest point texture filter mode
            g_device->SetSamplerState(0, D3DSAMP_MAGFILTER, D3DTEXF_POINT);
            g_device
->SetSamplerState(0, D3DSAMP_MINFILTER, D3DTEXF_POINT);
            
break;

        
case 50:    // press key "2", use linear texture filter mode
            g_device->SetSamplerState(0, D3DSAMP_MAGFILTER, D3DTEXF_LINEAR);
            g_device
->SetSamplerState(0, D3DSAMP_MINFILTER, D3DTEXF_LINEAR);
            
break;

        
case 51:    // press key "3", use anisotropy texture filter mode            
            g_device->SetSamplerState(0, D3DSAMP_MAGFILTER, D3DTEXF_ANISOTROPIC);
            g_device
->SetSamplerState(0, D3DSAMP_MINFILTER, D3DTEXF_ANISOTROPIC);
            g_device
->SetSamplerState(0, D3DSAMP_MAXANISOTROPY, 8);
            
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, 200100800600,
                             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-07 09:05 lovedday 閱讀(2955) 評論(1)  編輯 收藏 引用

評論

# re: 紋理映射基礎(chǔ)(4) 2009-12-22 12:58 dujid

LZ這篇文章寫得非常好!像這么條理清晰格式優(yōu)雅的文章太少了,內(nèi)容講述也很到位,對我有很大幫助。謝謝,加油!  回復(fù)  更多評論   


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


公告

導(dǎo)航

統(tǒng)計

常用鏈接

隨筆分類(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>
            国产精品亚洲一区| 亚洲国产精品免费| 国产精品视频午夜| 欧美日韩国产综合新一区| 久久琪琪电影院| 久久一区二区精品| 欧美激情欧美狂野欧美精品| 欧美精品在线极品| 国产精品国码视频| 国产农村妇女毛片精品久久麻豆| 国产精品人成在线观看免费| 狠久久av成人天堂| 日韩午夜精品视频| 欧美一区三区二区在线观看| 久久久久国产一区二区三区四区| 女人色偷偷aa久久天堂| 亚洲蜜桃精久久久久久久| 亚洲性感激情| 久久久视频精品| 欧美国产免费| 国产精品午夜久久| 亚洲国产天堂久久国产91| 亚洲一区免费| 老巨人导航500精品| 91久久中文| 亚洲综合欧美| 欧美激情1区| 韩日欧美一区二区三区| 亚洲午夜一区二区| 欧美高清在线视频| 久久av老司机精品网站导航| 欧美视频专区一二在线观看| 亚洲国产精品久久久久久女王| 亚洲欧美日韩中文视频| 亚洲狠狠婷婷| 久久久国产91| 国产日韩欧美综合| 一区二区三区视频在线看| 蜜桃久久av| 欧美一区二区三区在线| 国产精品免费看久久久香蕉| 99热这里只有精品8| 欧美成人有码| 久久精品人人做人人爽电影蜜月| 国产精品99免费看| 中文精品在线| 亚洲经典一区| 你懂的成人av| 亚洲成人在线网站| 久久久久国产一区二区三区四区| 一区二区三区日韩精品视频| 欧美激情黄色片| 亚洲激情成人| 欧美国产免费| 老司机午夜精品视频| 激情六月婷婷久久| 久久亚洲不卡| 久久婷婷蜜乳一本欲蜜臀| 国产亚洲a∨片在线观看| 午夜在线a亚洲v天堂网2018| 一本一本a久久| 国产精品久久久久久久久久ktv| 在线性视频日韩欧美| 亚洲精品国产精品久久清纯直播| 欧美大片专区| 99av国产精品欲麻豆| 亚洲欧洲另类国产综合| 欧美精品一区二区三区蜜臀| 夜夜嗨一区二区| 亚洲午夜精品久久| 国产精品日韩欧美一区二区| 欧美一区日本一区韩国一区| 欧美在线综合视频| 亚洲高清激情| 亚洲美女91| 国产精品一区二区视频| 亚洲欧洲视频在线| 久久精品成人一区二区三区| 国模大胆一区二区三区| 欧美777四色影视在线| 免费在线国产精品| 一本大道av伊人久久综合| 亚洲人成绝费网站色www| 欧美日韩一区三区| 性做久久久久久久久| 久久成人一区二区| 亚洲精品四区| 亚洲在线一区| 亚洲第一视频网站| 在线亚洲一区| 国产在线精品自拍| 亚洲精品欧美极品| 国产日韩欧美一区二区三区在线观看 | 国产一区欧美| 欧美激情2020午夜免费观看| 欧美视频一区在线观看| 久久婷婷av| 欧美调教vk| 男同欧美伦乱| 国产精品午夜久久| 亚洲国产美女久久久久| 国产精品综合久久久| 亚洲第一精品久久忘忧草社区| 欧美涩涩网站| 亚洲二区免费| 国产一区二区三区四区五区美女| 亚洲国内自拍| 亚洲电影欧美电影有声小说| 亚洲在线视频网站| 亚洲午夜精品久久久久久app| 欧美一区二区在线播放| 亚洲图片在区色| 欧美成人蜜桃| 久久久久久久久久看片| 欧美亚洲第一页| 亚洲韩国青草视频| 亚洲高清不卡av| 久久成人在线| 久久精品视频在线| 国产精品毛片一区二区三区| 亚洲精品护士| 亚洲精品欧美极品| 男男成人高潮片免费网站| 久久嫩草精品久久久精品一| 国产精品久久久久久久久搜平片 | 久久久噜噜噜久久人人看| 欧美三级网址| 日韩小视频在线观看| 日韩亚洲一区二区| 欧美成人免费在线观看| 欧美激情视频免费观看| 亚洲大胆av| 久久欧美中文字幕| 欧美国产另类| 一区二区国产日产| 国产日本亚洲高清| 亚洲欧美视频一区| 欧美在线视频日韩| 国产亚洲精品美女| 久久久精品五月天| 欧美91大片| 日韩视频在线观看国产| 欧美国产日韩精品| 亚洲精品视频中文字幕| 99riav国产精品| 欧美色精品天天在线观看视频| 99精品福利视频| 亚洲免费一级电影| 国产情侣一区| 久久综合九色99| 亚洲国语精品自产拍在线观看| 亚洲理论在线观看| 欧美四级电影网站| 亚洲欧美日韩精品久久奇米色影视| 久久久精品日韩欧美| 永久域名在线精品| 欧美精品免费在线| 亚洲欧美另类久久久精品2019| 久久天天狠狠| 99精品国产福利在线观看免费 | 最新中文字幕亚洲| 亚洲欧美日韩一区二区在线 | 久久久久久网址| 最近中文字幕日韩精品 | 免费视频最近日韩| 亚洲美女一区| 久久九九电影| 亚洲欧洲日本一区二区三区| 欧美性一区二区| 久久久久久**毛片大全| 亚洲九九九在线观看| 久久久99爱| 一区二区日韩伦理片| 国产午夜亚洲精品理论片色戒| 欧美3dxxxxhd| 午夜宅男欧美| 亚洲精品乱码视频| 久久精品国产一区二区三| 亚洲日本无吗高清不卡| 国产欧美日韩免费看aⅴ视频| 欧美99在线视频观看| 亚洲欧美影院| 亚洲精品一区二区三区av| 久久久久综合| 亚洲欧美日本在线| 亚洲精品色婷婷福利天堂| 国产精品一区免费视频| 欧美激情中文字幕乱码免费| 久久不见久久见免费视频1| 日韩视频免费在线| 美女脱光内衣内裤视频久久影院| 亚洲欧美日韩在线高清直播| 亚洲毛片在线观看.| 一区二区三区在线看| 国产精品羞羞答答| 欧美日韩国产综合视频在线观看| 久久综合激情| 久久精品一区四区| 国产欧美日韩视频一区二区三区| 欧美午夜不卡在线观看免费 |