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

天行健 君子當自強而不息

設計一個靈活的Camera類(3)

12.3實例程序:攝像機

該實例程序是創建和渲染一個如圖12.8所示的場景。你能夠通過鍵盤輸入在場景中自由地飛行。下面是相應鍵盤設置:

W/S—向前/向后移動

A/D—向左/向右平移

R/F—向上/向下飛行

Up/Down方向鍵—傾斜

Left/Right方向鍵—偏航

N/M—滾轉

圖12.8

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

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

const DWORD TEXTURE_VERTEX_FVF = D3DFVF_XYZ | D3DFVF_NORMAL | D3DFVF_TEX1;

// function references "desert.bmp" internally, this file must be in the working directory.
bool draw_basic_scene(
    IDirect3DDevice9
* device,    // pass in NULL for cleanup
    float scale);                // uniform scale

bool draw_basic_scene(IDirect3DDevice9* device, float scale)
{
    
static IDirect3DVertexBuffer9*  floor_vb    = NULL;
    
static IDirect3DTexture9*        texture        = NULL;
    
static ID3DXMesh*                pillar_mesh = NULL;

    
if(device == NULL)
    {
        
if(floor_vb && texture && pillar_mesh)
        {
            
// they already exist, destroy them.
            safe_release<IDirect3DVertexBuffer9*>(floor_vb);
            safe_release
<IDirect3DTexture9*>(texture);
            safe_release
<ID3DXMesh*>(pillar_mesh);
        }
    }
    
else if(floor_vb == NULL && texture == NULL && pillar_mesh == NULL)
    {
        
// they don't exist, create them.

        device
->CreateVertexBuffer(6 * sizeof(cTextureVertex), 0, TEXTURE_VERTEX_FVF, D3DPOOL_MANAGED, &floor_vb, 0);

        cTextureVertex
* v;

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

        v[
0= cTextureVertex(-20.0f-2.5f-20.0f0.0f1.0f0.0f0.0f1.0f);
        v[
1= cTextureVertex(-20.0f-2.5f,  20.0f0.0f1.0f0.0f0.0f0.0f);
        v[
2= cTextureVertex( 20.0f-2.5f,  20.0f0.0f1.0f0.0f1.0f0.0f);

        v[
3= cTextureVertex(-20.0f-2.5f-20.0f0.0f1.0f0.0f0.0f1.0f);
        v[
4= cTextureVertex( 20.0f-2.5f,  20.0f0.0f1.0f0.0f1.0f0.0f);
        v[
5= cTextureVertex( 20.0f-2.5f-20.0f0.0f1.0f0.0f1.0f1.0f);

        floor_vb
->Unlock();

        D3DXCreateCylinder(device, 
0.5f0.5f5.0f2020&pillar_mesh, NULL);
        D3DXCreateTextureFromFile(device, 
"desert.bmp"&texture);
    }
    
else
    {
        
// pre-render setup

        device
->SetSamplerState(0, D3DSAMP_MAGFILTER, D3DTEXF_LINEAR);
        device
->SetSamplerState(0, D3DSAMP_MINFILTER, D3DTEXF_LINEAR);
        device
->SetSamplerState(0, D3DSAMP_MIPFILTER, D3DTEXF_POINT);

        D3DXVECTOR3 dir(
0.707f-0.707f0.707f);
        D3DXCOLOR    color(
1.0f1.0f1.0f1.0f);
        D3DLIGHT9    light 
= init_directional_light(&dir, &color);

        device
->SetLight(0&light);
        device
->LightEnable(0, TRUE);
        device
->SetRenderState(D3DRS_NORMALIZENORMALS, TRUE);
        device
->SetRenderState(D3DRS_SPECULARENABLE,   TRUE);

        
// render

        D3DXMATRIX transform_matrix, rotate_matrix, pillor_matrix, scale_matrix;
        D3DXMatrixScaling(
&scale_matrix, scale, scale, scale);

        
// used to rotate cylinders to be parallel with world's y-axis
        D3DXMatrixRotationX(&rotate_matrix, -D3DX_PI * 0.5f);

        
// draw floor

        D3DXMatrixIdentity(
&transform_matrix);
        transform_matrix 
*= scale_matrix;
        device
->SetTransform(D3DTS_WORLD, &transform_matrix);

        device
->SetMaterial(&WHITE_MATERIAL);
        device
->SetTexture(0, texture);
        device
->SetStreamSource(0, floor_vb, 0sizeof(cTextureVertex));
        device
->SetFVF(TEXTURE_VERTEX_FVF);

        device
->DrawPrimitive(D3DPT_TRIANGLELIST, 02);

        
// draw pillars

        device
->SetMaterial(&BLUE_MATERIAL);
        device
->SetTexture(0, NULL);

        
for(int i = 0; i < 5; i++)
        {
            
// left pillar
            D3DXMatrixTranslation(&transform_matrix, -5.0f0.0f-15.0f + (i * 7.5f));
            pillor_matrix 
= rotate_matrix * transform_matrix * scale_matrix;
            device
->SetTransform(D3DTS_WORLD, &pillor_matrix);

            pillar_mesh
->DrawSubset(0);

            
// right pillar
            D3DXMatrixTranslation(&transform_matrix, 5.0f0.0f-15.0f + (i * 7.5f));
            pillor_matrix 
= rotate_matrix * transform_matrix * scale_matrix;
            device
->SetTransform(D3DTS_WORLD, &pillor_matrix);

            pillar_mesh
->DrawSubset(0);
        }
    }

    
return true;
}

主程序:
/**************************************************************************************
  Demonstrates using the Camera class. 
 *************************************************************************************
*/

#include 
"d3dUtility.h"
#include 
"camera.h"

#pragma warning(disable : 
4100)

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

IDirect3DDevice9
*    g_device;
cCamera                g_camera(AIR_CRAFT);

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

bool setup()
{    
    
// setup a basic scnen, the scene will be created the first time this function is called.
    draw_basic_scene(g_device, 0.0f);

    
// set the projection matrix
    D3DXMATRIX proj;
    D3DXMatrixPerspectiveFovLH(
&proj, D3DX_PI/4.0f, (float)WIDTH/HEIGHT, 1.0f1000.0f);
    g_device
->SetTransform(D3DTS_PROJECTION, &proj);
    
    
return true;
}

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

void cleanup()
{    
    
// pass NULL for the first parameter to instruct cleanup
    draw_basic_scene(NULL, 0.0f);
}

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

bool display(float time_delta)
{
    
// update the camera

    
float change_value = 4.0f * time_delta;

    
if(GetAsyncKeyState('W'& 0x80000f)
        g_camera.walk(change_value);

    
if( GetAsyncKeyState('S'& 0x8000f )
        g_camera.walk(
-change_value);

    
if( GetAsyncKeyState('A'& 0x8000f )
        g_camera.strafe(
-change_value);

    
if( GetAsyncKeyState('D'& 0x8000f )
        g_camera.strafe(change_value);

    
if( GetAsyncKeyState('R'& 0x8000f )
        g_camera.fly(change_value);

    
if( GetAsyncKeyState('F'& 0x8000f )
        g_camera.fly(
-change_value);

    change_value 
= time_delta;

    
if( GetAsyncKeyState(VK_UP) & 0x8000f )
        g_camera.pitch(change_value);

    
if( GetAsyncKeyState(VK_DOWN) & 0x8000f )
        g_camera.pitch(
-change_value);

    
if( GetAsyncKeyState(VK_LEFT) & 0x8000f )
        g_camera.yaw(
-change_value);
        
    
if( GetAsyncKeyState(VK_RIGHT) & 0x8000f )
        g_camera.yaw(change_value);

    
if( GetAsyncKeyState('N'& 0x8000f )
        g_camera.roll(change_value);

    
if( GetAsyncKeyState('M'& 0x8000f )
        g_camera.roll(
-change_value);

    
// update the view matrix representing the camera's new position/orientation
    D3DXMATRIX view_matrix;
    g_camera.get_view_matrix(
&view_matrix);
    g_device
->SetTransform(D3DTS_VIEW, &view_matrix);

    
// render now

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

    g_device
->BeginScene();
    draw_basic_scene(g_device, 
1.0f);
    g_device
->EndScene();

    g_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_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_device
->Release();

    
return 0;
}


下載源程序

posted on 2008-03-30 15:15 lovedday 閱讀(1125) 評論(0)  編輯 收藏 引用


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


公告

導航

統計

常用鏈接

隨筆分類(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>
            久久久久国产精品一区三寸| 亚洲伊人久久综合| 亚洲大胆av| 欧美一级夜夜爽| 久久国产99| 在线精品视频免费观看| 国产网站欧美日韩免费精品在线观看| 久久本道综合色狠狠五月| 久久岛国电影| 久久精品亚洲一区二区| 在线成人www免费观看视频| 久久久蜜桃一区二区人| 亚洲福利免费| 亚洲免费小视频| 久久久蜜桃一区二区人| 亚洲精品免费网站| 国产午夜精品久久久久久久| 亚洲国产美女| 亚洲日本aⅴ片在线观看香蕉| 久久久国产精品一区二区三区| 国产欧美日韩亚洲| 亚洲影院在线| 一本色道久久88综合日韩精品 | 一区二区三区国产| 欧美新色视频| 麻豆亚洲精品| 香港久久久电影| 一区二区不卡在线视频 午夜欧美不卡在| 久久精品国产视频| 麻豆freexxxx性91精品| 欧美一区1区三区3区公司| 亚洲人体偷拍| 亚洲欧美视频在线观看| 老司机凹凸av亚洲导航| 欧美一区二区精品在线| 亚洲精品中文字幕女同| 亚洲美女黄色| 亚洲高清在线| 黑人巨大精品欧美一区二区小视频 | 久久先锋影音| 久久精品毛片| 欧美jizz19性欧美| 欧美一区二区三区喷汁尤物| 久久中文字幕导航| 欧美在线三区| 亚洲免费观看| 亚洲精品一区在线| 久久人体大胆视频| 亚洲香蕉在线观看| 中文在线一区| 亚洲午夜电影网| 欧美成人精品不卡视频在线观看| 欧美一区免费| 国产精品任我爽爆在线播放 | 亚洲人成高清| 蜜桃av一区| 久久亚洲综合色| 亚洲一区二区精品| 国产精品第一区| 国产日产欧美一区| 欧美一级久久久| 久久久久久亚洲精品中文字幕 | 欧美大片va欧美在线播放| 欧美成人在线网站| 久久久久在线观看| 亚洲国产精品久久91精品| 麻豆乱码国产一区二区三区| 久久激情网站| 好看不卡的中文字幕| 久久日韩粉嫩一区二区三区| 久久精品欧美日韩精品| 在线看欧美视频| 91久久精品国产91久久| 亚洲少妇一区| 国产精品一二三| 国产伦精品一区二区三区照片91| 亚洲在线日韩| 亚洲你懂的在线视频| 国产九色精品成人porny| 久久精品观看| 免费欧美电影| 国产色产综合产在线视频| 欧美一区二区三区在线| 久久精品国产第一区二区三区| 精品成人在线观看| 欧美在线播放一区二区| 午夜免费日韩视频| 亚洲天堂男人| 狠狠色狠狠色综合系列| 亚洲高清中文字幕| 国产精品国产自产拍高清av| 久久欧美中文字幕| 免费观看亚洲视频大全| 中文无字幕一区二区三区| 女女同性精品视频| 欧美精品少妇一区二区三区| 国产精品亚洲欧美| 欧美成人中文字幕| 国产精品v欧美精品v日本精品动漫| 欧美一区二区视频观看视频| 久色婷婷小香蕉久久| 亚洲一区日韩在线| 久久先锋资源| 欧美一区二区三区精品| 美女国内精品自产拍在线播放| 亚洲视频999| 久久综合色播五月| 小嫩嫩精品导航| 欧美日韩国产区一| 亚洲日本欧美| 国产精品99久久久久久人 | 欧美成人免费一级人片100| 欧美一区二区成人6969| 欧美精品在线观看一区二区| 在线精品视频一区二区三四| 亚洲免费成人av电影| 在线观看av一区| 欧美在线不卡视频| 亚洲影院高清在线| 欧美成年人网| 久久精品中文| 国产精品黄色| 亚洲精品在线免费观看视频| 在线成人欧美| 久久五月天婷婷| 毛片一区二区三区| 国产自产2019最新不卡| 久久字幕精品一区| 国产精品无码永久免费888| 最新日韩在线| 91久久精品久久国产性色也91| 久久精品日韩| 久热精品在线视频| 在线激情影院一区| 久久综合激情| 免费影视亚洲| 亚洲国内欧美| 亚洲九九九在线观看| 亚洲高清av| 久久综合伊人77777蜜臀| 久久婷婷国产综合国色天香| 国产在线精品自拍| 性色av一区二区三区红粉影视| 欧美在线观看视频| 国产偷久久久精品专区| 久久久99国产精品免费| 欧美激情欧美激情在线五月| 欧美日本高清视频| 欧美精彩视频一区二区三区| 亚洲一区制服诱惑| 久久精品国产2020观看福利| 欧美一区综合| 国内精品久久久久久久果冻传媒| 午夜精品在线观看| 老司机精品视频一区二区三区| 亚洲风情在线资源站| 欧美精品久久久久久| 一区二区三区日韩精品| 欧美在线视频观看| 狠狠色狠狠色综合日日91app| 久久夜色精品国产欧美乱| 欧美高清hd18日本| 一本色道久久99精品综合| 国产精品高清免费在线观看| 欧美一区二区精品在线| 亚洲国产精品精华液2区45| 在线一区观看| 国产欧美一区二区精品秋霞影院| 久久久噜久噜久久综合| 亚洲欧洲日产国产综合网| 亚洲欧美日韩精品久久亚洲区 | 久久精品亚洲乱码伦伦中文| 国产亚洲精品bt天堂精选| 亚洲视频在线观看网站| 久久久久久婷| 99视频热这里只有精品免费| 国产精品乱人伦中文| 亚洲国产中文字幕在线观看| 亚洲欧美日韩一区| 精品盗摄一区二区三区| 欧美日本亚洲| 久久九九精品99国产精品| 日韩午夜免费| 巨胸喷奶水www久久久免费动漫| 一本色道久久综合亚洲精品按摩| 国产丝袜一区二区| 欧美三级网页| 亚洲精品久久久久久久久久久久久 | 国产日韩一区二区三区在线| 久久综合狠狠综合久久综青草| 亚洲系列中文字幕| 欧美高清视频免费观看| 久久黄色影院| 亚洲综合日本| 9色精品在线| 亚洲美女色禁图| 亚洲高清av在线| 黄色成人av在线| 国内精品久久久久国产盗摄免费观看完整版| 欧美日韩在线精品|