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

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

D3D中的紋理映射(3)

該例程演示了怎樣對(duì)一個(gè)立方體映射板條紋理。

截圖:

vertex.h:

#ifndef __VERTEX_H__
#define __VERTEX_H__

class cTextureVertex
{
public:
    
float m_x, m_y, m_z;
    
float m_nx, m_ny, m_nz;
    
float m_u, m_v; // texture coordinates

    cTextureVertex() { }

    cTextureVertex(
float x, float y, float z,
                   
float nx, float ny, float nz,
                   
float u, float v)
    {
        m_x  
= x;  m_y  = y;  m_z  = z;
        m_nx 
= nx; m_ny = ny; m_nz = nz;
        m_u  
= u;  m_v  = v;
    }    
};

#define TEXTURE_VERTEX_FVF (D3DFVF_XYZ | D3DFVF_NORMAL | D3DFVF_TEX1)

#endif

 


cube.h:

#ifndef __CUBE_H__
#define __CUBE_H__

#include 
<d3dx9.h>

class cCube
{
public:
    cCube(IDirect3DDevice9
* d3d_device);
    
~cCube();

    
void draw(const D3DMATRIX* world, const D3DMATERIAL9* material, IDirect3DTexture9* texture);

private:
    IDirect3DDevice9
*        m_d3d_device;
    IDirect3DVertexBuffer9
*    m_vertex_buffer;
    IDirect3DIndexBuffer9
*    m_index_buffer;
};

#endif

 


cube.cpp:

/****************************************************************************
  Provides an interface to create and render a cube.
 ***************************************************************************
*/

#include 
"cube.h"
#include 
"vertex.h"

cCube::cCube(IDirect3DDevice9
* d3d_device)
{
    m_d3d_device 
= d3d_device;

    m_d3d_device
->CreateVertexBuffer(24 * sizeof(cTextureVertex), D3DUSAGE_WRITEONLY, TEXTURE_VERTEX_FVF,
        D3DPOOL_MANAGED, 
&m_vertex_buffer, NULL);

    cTextureVertex
* v;

    m_vertex_buffer
->Lock(00, (void**)&v, 0);

    
// build box

    
// fill in the front face vertex data
    v[0= cTextureVertex(-1.0f-1.0f-1.0f0.0f0.0f-1.0f0.0f0.0f);
    v[
1= cTextureVertex(-1.0f,  1.0f-1.0f0.0f0.0f-1.0f0.0f1.0f);
    v[
2= cTextureVertex( 1.0f,  1.0f-1.0f0.0f0.0f-1.0f1.0f1.0f);
    v[
3= cTextureVertex( 1.0f-1.0f-1.0f0.0f0.0f-1.0f1.0f0.0f);

    
// fill in the back face vertex data
    v[4= cTextureVertex(-1.0f-1.0f1.0f0.0f0.0f1.0f0.0f0.0f);
    v[
5= cTextureVertex( 1.0f-1.0f1.0f0.0f0.0f1.0f0.0f1.0f);
    v[
6= cTextureVertex( 1.0f,  1.0f1.0f0.0f0.0f1.0f1.0f1.0f);
    v[
7= cTextureVertex(-1.0f,  1.0f1.0f0.0f0.0f1.0f1.0f0.0f);

    
// fill in the top face vertex data
    v[8]  = cTextureVertex(-1.0f1.0f-1.0f0.0f1.0f0.0f0.0f0.0f);
    v[
9]  = cTextureVertex(-1.0f1.0f,  1.0f0.0f1.0f0.0f0.0f1.0f);
    v[
10= cTextureVertex( 1.0f1.0f,  1.0f0.0f1.0f0.0f1.0f1.0f);
    v[
11= cTextureVertex( 1.0f1.0f-1.0f0.0f1.0f0.0f1.0f0.0f);

    
// fill in the bottom face vertex data
    v[12= cTextureVertex(-1.0f-1.0f-1.0f0.0f-1.0f0.0f0.0f0.0f);
    v[
13= cTextureVertex( 1.0f-1.0f-1.0f0.0f-1.0f0.0f0.0f1.0f);
    v[
14= cTextureVertex( 1.0f-1.0f,  1.0f0.0f-1.0f0.0f1.0f1.0f);
    v[
15= cTextureVertex(-1.0f-1.0f,  1.0f0.0f-1.0f0.0f1.0f0.0f);

    
// fill in the left face vertex data
    v[16= cTextureVertex(-1.0f-1.0f,  1.0f-1.0f0.0f0.0f0.0f0.0f);
    v[
17= cTextureVertex(-1.0f,  1.0f,  1.0f-1.0f0.0f0.0f0.0f1.0f);
    v[
18= cTextureVertex(-1.0f,  1.0f-1.0f-1.0f0.0f0.0f1.0f1.0f);
    v[
19= cTextureVertex(-1.0f-1.0f-1.0f-1.0f0.0f0.0f1.0f0.0f);

    
// fill in the right face vertex data
    v[20= cTextureVertex( 1.0f-1.0f-1.0f1.0f0.0f0.0f0.0f0.0f);
    v[
21= cTextureVertex( 1.0f,  1.0f-1.0f1.0f0.0f0.0f0.0f1.0f);
    v[
22= cTextureVertex( 1.0f,  1.0f,  1.0f1.0f0.0f0.0f1.0f1.0f);
    v[
23= cTextureVertex( 1.0f-1.0f,  1.0f1.0f0.0f0.0f1.0f0.0f);

    m_vertex_buffer
->Unlock();

    m_d3d_device
->CreateIndexBuffer(36 * sizeof(WORD), D3DUSAGE_WRITEONLY, D3DFMT_INDEX16, D3DPOOL_MANAGED, 
        
&m_index_buffer, NULL);

    WORD
* index_ptr = NULL;
    m_index_buffer
->Lock(00, (void**)&index_ptr, 0);

    
// fill in the front face index data
    index_ptr[0= 0; index_ptr[1= 1; index_ptr[2= 2;
    index_ptr[
3= 0; index_ptr[4= 2; index_ptr[5= 3;

    
// fill in the back face index data
    index_ptr[6= 4; index_ptr[7]  = 5; index_ptr[8]  = 6;
    index_ptr[
9= 4; index_ptr[10= 6; index_ptr[11= 7;

    
// fill in the top face index data
    index_ptr[12= 8; index_ptr[13=  9; index_ptr[14= 10;
    index_ptr[
15= 8; index_ptr[16= 10; index_ptr[17= 11;

    
// fill in the bottom face index data
    index_ptr[18= 12; index_ptr[19= 13; index_ptr[20= 14;
    index_ptr[
21= 12; index_ptr[22= 14; index_ptr[23= 15;

    
// fill in the left face index data
    index_ptr[24= 16; index_ptr[25= 17; index_ptr[26= 18;
    index_ptr[
27= 16; index_ptr[28= 18; index_ptr[29= 19;

    
// fill in the right face index data
    index_ptr[30= 20; index_ptr[31= 21; index_ptr[32= 22;
    index_ptr[
33= 20; index_ptr[34= 22; index_ptr[35= 23;

    m_index_buffer
->Unlock();
}

cCube::
~cCube()
{
    
if(m_vertex_buffer)
    {
        m_vertex_buffer
->Release();
        m_vertex_buffer 
= NULL;
    }

    
if(m_index_buffer)
    {
        m_index_buffer
->Release();
        m_index_buffer 
= NULL;
    }
}

void cCube::draw(const D3DMATRIX* world, const D3DMATERIAL9* material, IDirect3DTexture9* texture)
{
    
if(world)
        m_d3d_device
->SetTransform(D3DTS_WORLD, world);

    
if(material)
        m_d3d_device
->SetMaterial(material);

    
if(texture)
        m_d3d_device
->SetTexture(0, texture);

    m_d3d_device
->SetStreamSource(0, m_vertex_buffer, 0sizeof(cTextureVertex));
    m_d3d_device
->SetIndices(m_index_buffer);
    m_d3d_device
->SetFVF(TEXTURE_VERTEX_FVF);

    m_d3d_device
->DrawIndexedPrimitive(D3DPT_TRIANGLELIST, 0024012);
}

 

TexCube.cpp:
/**************************************************************************************
  Renders a textured cube.  Demonstrates creating a texture, setting texture filters, 
  enabling a texture, and texture coordinates.  Use the arrow keys to orbit the scene. 
 *************************************************************************************
*/

#include 
"d3dUtility.h"
#include 
"cube.h"
#include 
"vertex.h"

#pragma warning(disable : 
4100)

const int WIDTH  = 640;
const int HEIGHT = 480;

IDirect3DDevice9
*        g_d3d_device;
cCube
*                    g_cube;
IDirect3DTexture9
*        g_d3d_texture;

////////////////////////////////////////////////////////////////////////////////////////////////////

bool setup()
{    
    g_cube 
= new cCube(g_d3d_device);

    
// set a directional light

    D3DLIGHT9 light;
    ZeroMemory(
&light, sizeof(light));

    light.Type        
= D3DLIGHT_DIRECTIONAL;
    light.Ambient   
= D3DXCOLOR(0.8f0.8f0.8f1.0f);
    light.Diffuse   
= D3DXCOLOR(1.0f1.0f1.0f1.0f);
    light.Specular  
= D3DXCOLOR(0.2f0.2f0.2f1.0f);
    light.Direction    
= D3DXVECTOR3(1.0f-1.0f0.0f);

    
// set and enable the light
    g_d3d_device->SetLight(0&light);
    g_d3d_device
->LightEnable(0, TRUE);

    
// turn off specular lighting and instruct Direct3D to renormalize normals
    g_d3d_device->SetRenderState(D3DRS_NORMALIZENORMALS, TRUE);
    g_d3d_device
->SetRenderState(D3DRS_SPECULARENABLE, TRUE);
    
    D3DXCreateTextureFromFile(g_d3d_device, 
"crate.jpg"&g_d3d_texture);

    
// set texture filter states
    g_d3d_device->SetSamplerState(0, D3DSAMP_MAGFILTER, D3DTEXF_LINEAR);
    g_d3d_device
->SetSamplerState(0, D3DSAMP_MINFILTER, D3DTEXF_LINEAR);
    g_d3d_device
->SetSamplerState(0, D3DSAMP_MIPFILTER, D3DTEXF_LINEAR);
    
    
// set the projection matrix
    D3DXMATRIX proj;
    D3DXMatrixPerspectiveFovLH(
&proj, D3DX_PI * 0.5f, (float)WIDTH/HEIGHT, 1.0f1000.0f);
    g_d3d_device
->SetTransform(D3DTS_PROJECTION, &proj);
    
    
return true;
}

void cleanup()
{
    safe_delete
<cCube*>(g_cube);
    safe_release
<IDirect3DTexture9*>(g_d3d_texture);
}

bool display(float time_delta)
{
    
// update the scene: update camera position

    
static float angle = (3.0f * D3DX_PI) / 2.0f;
    
static float height = 2.0f;

    
if(GetAsyncKeyState(VK_LEFT) & 0x8000f)
        angle 
-= 0.5f * time_delta;

    
if(GetAsyncKeyState(VK_RIGHT) & 0x8000f)
        angle 
+= 0.5f * time_delta;

    
if(GetAsyncKeyState(VK_UP) & 0x8000f)
        height 
+= 5.0f * time_delta;

    
if(GetAsyncKeyState(VK_DOWN) & 0x8000f)
        height 
-= 5.0f * time_delta;

    D3DXVECTOR3 position(cosf(angle) 
* 3.0f, height, sinf(angle) * 3.0f);
    D3DXVECTOR3 target(
0.0f0.0f0.0f);
    D3DXVECTOR3 up(
0.0f1.0f0.0f);

    D3DXMATRIX view_matrix;
    D3DXMatrixLookAtLH(
&view_matrix, &position, &target, &up);

    g_d3d_device
->SetTransform(D3DTS_VIEW, &view_matrix);

    
// draw the scene

    g_d3d_device
->Clear(0, NULL, D3DCLEAR_TARGET | D3DCLEAR_ZBUFFER, 0x000000001.0f0);

    g_d3d_device
->BeginScene();
    g_cube
->draw(NULL, &WHITE_MATERIAL, g_d3d_texture);        
    g_d3d_device
->EndScene();

    g_d3d_device
->Present(NULL, NULL, NULL, NULL);

    
return true;
}

LRESULT CALLBACK wnd_proc(HWND hwnd, UINT msg, WPARAM word_param, LPARAM long_param)
{
    
switch(msg)
    {
    
case WM_DESTROY:
        PostQuitMessage(
0);
        
break;

    
case WM_KEYDOWN:
        
if(word_param == VK_ESCAPE)
            DestroyWindow(hwnd);
        
break;
    }

    
return DefWindowProc(hwnd, msg, word_param, long_param);
}

int WINAPI WinMain(HINSTANCE inst, HINSTANCE, PSTR cmd_line, int cmd_show)
{
    
if(! init_d3d(inst, WIDTH, HEIGHT, true, D3DDEVTYPE_HAL, &g_d3d_device))
    {
        MessageBox(NULL, 
"init_d3d() - failed."0, MB_OK);
        
return 0;
    }

    
if(! setup())
    {
        MessageBox(NULL, 
"Steup() - failed."0, MB_OK);
        
return 0;
    }

    enter_msg_loop(display);

    cleanup();
    g_d3d_device
->Release();

    
return 0;
}


下載源程序


posted on 2008-03-17 17:20 lovedday 閱讀(721) 評(píng)論(0)  編輯 收藏 引用


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


公告

導(dǎo)航

統(tǒng)計(jì)

常用鏈接

隨筆分類(178)

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

搜索

最新評(píng)論

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久国产一区| 欧美色欧美亚洲另类二区 | 国产精品成人在线观看| 欧美福利一区二区| 欧美aaa级| 欧美日本在线一区| 欧美午夜视频一区二区| 国产精品三级久久久久久电影| 国产精品尤物| 久久亚洲春色中文字幕| 亚洲区第一页| 国产精品99久久久久久白浆小说 | 在线观看一区二区精品视频| 国语自产精品视频在线看| 极品日韩久久| 99国产精品久久久久久久成人热| 一区二区三区不卡视频在线观看 | 国产亚洲精品久久久久久| 国产一区二区中文| 91久久精品国产91性色| 亚洲调教视频在线观看| 久久电影一区| 亚洲精品极品| 亚洲天堂av在线免费| 久久九九99视频| 欧美日韩一区二区三区在线 | 亚洲视屏在线播放| 久久精品一区中文字幕| 欧美激情综合色| 国产日韩欧美日韩大片| 在线看成人片| 久久动漫亚洲| 中文国产亚洲喷潮| 免费av成人在线| 国产欧美日韩免费看aⅴ视频| 亚洲国产裸拍裸体视频在线观看乱了| 亚洲午夜国产成人av电影男同| 久久久久久有精品国产| 在线视频欧美精品| 欧美精品黄色| 在线精品国精品国产尤物884a| 亚洲综合999| 亚洲高清电影| 99这里有精品| 欧美成人精品不卡视频在线观看| 亚洲欧美电影院| 欧美日韩午夜剧场| 亚洲国产一区二区视频| 久久一区视频| 欧美一区在线视频| 国产精品麻豆va在线播放| 99在线精品视频| 亚洲欧洲精品成人久久奇米网| 久久国产免费看| 国产日韩欧美综合一区| 亚洲欧美国产另类| 亚洲精品少妇30p| 欧美极品在线视频| 亚洲精品亚洲人成人网| 欧美va天堂| 蜜桃久久精品乱码一区二区| 国产精品久久久久一区二区三区| 亚洲人成网站色ww在线| 久久亚洲精品伦理| 在线看不卡av| 欧美激情视频在线播放 | 久久久久久久久久看片| 国产一区二区三区精品久久久| 亚洲一区国产精品| 亚洲永久网站| 国产女精品视频网站免费| 欧美一区二区免费视频| 欧美一区二区视频网站| 激情校园亚洲| 欧美高清你懂得| 欧美激情国产日韩| 国产精品99久久不卡二区| 亚洲一区久久久| 黄色成人在线网址| 亚洲成人在线网| 欧美日韩在线视频观看| 欧美在线免费视屏| 美日韩精品视频| 亚洲一区二区影院| 欧美一级在线播放| 亚洲国产欧美一区二区三区同亚洲| 亚洲国产91| 国产精品久久久久久久久久久久久久| 午夜精品免费在线| 久久这里只有精品视频首页| 夜夜精品视频| 欧美一区日韩一区| 亚洲精品一区二区在线观看| 亚洲一区久久| 亚洲人成亚洲人成在线观看 | 欧美成人tv| 亚洲欧美日韩在线高清直播| 久久精品卡一| 亚洲一区三区视频在线观看| 欧美一区二区三区男人的天堂| 亚洲国产精彩中文乱码av在线播放| 亚洲精品女av网站| 国产精品免费看| 欧美激情亚洲| 国产日韩欧美精品在线| 亚洲欧洲另类| 国语自产偷拍精品视频偷| 亚洲欧洲美洲综合色网| 国产一区二区高清| 亚洲天天影视| 亚洲国产99精品国自产| 亚洲无线视频| 一区二区三区高清| 久久久久久有精品国产| 亚洲欧美日韩视频一区| 日韩手机在线导航| 欧美伊人久久大香线蕉综合69| 日韩一级视频免费观看在线| 欧美在线看片| 羞羞视频在线观看欧美| 最新亚洲视频| 亚洲精品久久7777| 亚洲国产第一| 久久久久久久999| 久久精品免费观看| 欧美性猛片xxxx免费看久爱| 亚洲国产女人aaa毛片在线| 国产麻豆精品theporn| 中文亚洲免费| 亚洲欧美日本日韩| 国产精品扒开腿做爽爽爽软件| 亚洲国产三级网| 亚洲精品免费一二三区| 免费亚洲电影在线| 免费在线视频一区| 亚洲大片免费看| 久久理论片午夜琪琪电影网| 久久一区二区三区四区五区| 经典三级久久| 久久亚洲综合色一区二区三区| 久久天天躁夜夜躁狠狠躁2022| 国产麻豆成人精品| 午夜精品一区二区三区电影天堂| 亚洲综合三区| 久久久福利视频| 一区二区三区在线视频免费观看| 久久久久99| 亚洲电影免费观看高清| 亚洲伦理网站| 欧美日韩美女一区二区| 中文高清一区| 久久国产福利国产秒拍| 精品成人乱色一区二区| 久久综合伊人77777尤物| 欧美高清视频www夜色资源网| 怡红院av一区二区三区| 你懂的国产精品| 亚洲精品日韩在线观看| 夜夜爽av福利精品导航| 国产精品视频久久| 久久精品国产免费| 亚洲国产一区二区三区在线播 | 久久精品久久99精品久久| 韩国精品主播一区二区在线观看| 久久美女性网| 一本色道久久综合亚洲91| 午夜精品免费在线| 尤物99国产成人精品视频| 欧美成人自拍| 亚洲欧美亚洲| 亚洲国产天堂久久综合网| 亚洲综合色丁香婷婷六月图片| 国产亚洲激情在线| 欧美韩国在线| 欧美资源在线| 99国产精品| 久久在线视频在线| 国产精品99久久久久久白浆小说 | 国产亚洲精品福利| 欧美高清在线| 午夜精品久久久久久久99热浪潮 | 亚洲综合欧美| 亚洲日韩成人| 在线观看日韩专区| 国产精品免费久久久久久| 亚洲第一精品久久忘忧草社区| 亚洲精品偷拍| 国产欧美日本| 欧美精品尤物在线| 欧美在线观看网站| 中文av一区特黄| 亚洲高清在线观看一区| 性欧美video另类hd性玩具| 亚洲国产一区二区三区青草影视| 欧美日韩在线影院| 狂野欧美一区| 久久成人免费电影| 亚洲神马久久| 亚洲国产精品久久久久秋霞蜜臀 | 在线观看成人av电影|