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

隨筆 - 505  文章 - 1034  trackbacks - 0
<2007年10月>
30123456
78910111213
14151617181920
21222324252627
28293031123
45678910


子曾經(jīng)曰過(guò):編程無(wú)他,唯手熟爾!

常用鏈接

留言簿(94)

隨筆分類(649)

隨筆檔案(505)

相冊(cè)

BCB

Crytek

  • crymod
  • Crytek's Offical Modding Portal

Game Industry

OGRE

other

Programmers

Qt

WOW Stuff

搜索

  •  

積分與排名

  • 積分 - 921250
  • 排名 - 14

最新隨筆

最新評(píng)論

閱讀排行榜

評(píng)論排行榜


通過(guò)四元數(shù)實(shí)現(xiàn)模型空間定位







//=============================================================================
// Desc: 文件網(wǎng)格模型的使用
//=============================================================================
#include <d3dx9.h>


//-----------------------------------------------------------------------------
// Desc: 全局變量
//-----------------------------------------------------------------------------
LPDIRECT3D9             g_pD3D           = NULL;  //Direct3D對(duì)象
LPDIRECT3DDEVICE9       g_pd3dDevice     = NULL;  //Direct3D設(shè)備對(duì)象

LPD3DXMESH              g_pMesh          
= NULL;  //網(wǎng)格模型對(duì)象
D3DMATERIAL9*           g_pMeshMaterials = NULL;  //網(wǎng)格模型材質(zhì)
LPDIRECT3DTEXTURE9*     g_pMeshTextures  = NULL;  //網(wǎng)格模型紋理
DWORD                   g_dwNumMaterials = 0L;    //網(wǎng)格模型材質(zhì)數(shù)量
D3DXVECTOR3             g_vCenter;                //網(wǎng)格模型中心點(diǎn) 

BYTE  m_bKey[
256];            // keyboard state buffer

D3DXMATRIX              g_matWorld;


//-----------------------------------------------------------------------------
// Desc: 設(shè)置世界矩陣
//-----------------------------------------------------------------------------
VOID SetWorldMatrix()
{
    
static long curTime=0;
    
static float elapsetime=0;
    elapsetime 
= (timeGetTime()-curTime)/1000.0f;
    curTime 
= timeGetTime();

    
//創(chuàng)建并設(shè)置世界矩陣  
    float fRoll, fPitch, fYaw;
    fRoll 
= fPitch = fYaw = 0.0f;

    
if (m_bKey['D']) fRoll  -= 3*elapsetime;
    
if (m_bKey['A']) fRoll  +=  3*elapsetime;
    
if (m_bKey['S']) fPitch -= 3*elapsetime;
    
if (m_bKey['W']) fPitch += 3*elapsetime;
    
if (m_bKey['Q']) fYaw   -= 3*elapsetime;
    
if (m_bKey['E']) fYaw   += 3*elapsetime;

    
//更新網(wǎng)格模型姿態(tài)
    D3DXQUATERNION qR;
    D3DXMATRIX matRot;
    D3DXQuaternionRotationYawPitchRoll (
&qR, fYaw, fPitch, fRoll);    
    D3DXMatrixRotationQuaternion (
&matRot, &qR);
    D3DXMatrixMultiply (
&g_matWorld, &matRot, &g_matWorld);

    
//獲取網(wǎng)格模型前向量
    static D3DXVECTOR3 vLook;
    vLook.x 
= g_matWorld._31;
    vLook.y 
= g_matWorld._32;
    vLook.z 
= g_matWorld._33;

    
//向前移動(dòng)
    if (m_bKey['F'])
    {
        g_matWorld._41 
+= 10*elapsetime * vLook.x;
        g_matWorld._42 
+= 10*elapsetime * vLook.y;
        g_matWorld._43 
+= 10*elapsetime * vLook.z;
    }

    
//向后移動(dòng)
    if (m_bKey['V']) 
    {
        g_matWorld._41 
-= 10*elapsetime * vLook.x;
        g_matWorld._42 
-= 10*elapsetime * vLook.y;
        g_matWorld._43 
-= 10*elapsetime * vLook.z;
    }

    g_pd3dDevice
->SetTransform( D3DTS_WORLD, &g_matWorld );
}


//-----------------------------------------------------------------------------
// Desc: 設(shè)置觀察矩陣和投影矩陣
//-----------------------------------------------------------------------------
VOID SetViewAndProjMatrix()
{
    
//創(chuàng)建并設(shè)置觀察矩陣
    D3DXVECTOR3 vEyePt( 0.0f0.0f,-20.0f );
    D3DXVECTOR3 vLookatPt( 
0.0f0.0f0.0f );
    D3DXVECTOR3 vUpVec( 
0.0f1.0f0.0f );
    D3DXMATRIXA16 matView;
    D3DXMatrixLookAtLH( 
&matView, &vEyePt, &vLookatPt, &vUpVec );
    g_pd3dDevice
->SetTransform( D3DTS_VIEW, &matView );

    
//創(chuàng)建并設(shè)置投影矩陣
    D3DXMATRIXA16 matProj;
    D3DXMatrixPerspectiveFovLH( 
&matProj, D3DX_PI/41.0f1.0f500.0f );
    g_pd3dDevice
->SetTransform( D3DTS_PROJECTION, &matProj );
}


//-----------------------------------------------------------------------------
// Desc: 初始化Direct3D
//-----------------------------------------------------------------------------
HRESULT InitD3D( HWND hWnd )
{
    
//創(chuàng)建Direct3D對(duì)象, 該對(duì)象用于創(chuàng)建Direct3D設(shè)備對(duì)象
    if( NULL == ( g_pD3D = Direct3DCreate9( D3D_SDK_VERSION ) ) )
        
return E_FAIL;

    
//設(shè)置D3DPRESENT_PARAMETERS結(jié)構(gòu), 準(zhǔn)備創(chuàng)建Direct3D設(shè)備對(duì)象
    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;

    
//創(chuàng)建Direct3D設(shè)備對(duì)象
    if( FAILED( g_pD3D->CreateDevice( D3DADAPTER_DEFAULT, D3DDEVTYPE_HAL, hWnd,
                                      D3DCREATE_SOFTWARE_VERTEXPROCESSING,
                                      
&d3dpp, &g_pd3dDevice ) ) )
    {
        
return E_FAIL;
    }

    
//設(shè)置紋理過(guò)濾狀態(tài)
    g_pd3dDevice->SetTextureStageState( 0, D3DTSS_COLORARG1, D3DTA_TEXTURE );
    g_pd3dDevice
->SetTextureStageState( 0, D3DTSS_COLOROP,   D3DTOP_SELECTARG1 );
    g_pd3dDevice
->SetSamplerState( 0, D3DSAMP_MINFILTER, D3DTEXF_LINEAR );
    g_pd3dDevice
->SetSamplerState( 0, D3DSAMP_MAGFILTER, D3DTEXF_LINEAR );

    
//設(shè)置觀察矩陣和投影矩陣
    SetViewAndProjMatrix();

    ZeroMemory( m_bKey, 
256 );
    D3DXMatrixIdentity(
&g_matWorld);
    
    
return S_OK;
}


//-----------------------------------------------------------------------------
// Desc: 從絕對(duì)路徑中提取紋理文件名
//-----------------------------------------------------------------------------
void RemovePathFromFileName(LPSTR fullPath, LPWSTR fileName)
{
    
//先將fullPath的類型變換為L(zhǎng)PWSTR
    WCHAR wszBuf[MAX_PATH];
    MultiByteToWideChar( CP_ACP, 
0, fullPath, -1, wszBuf, MAX_PATH );
    wszBuf[MAX_PATH
-1= L'\0';

    WCHAR
* wszFullPath = wszBuf;

    
//從絕對(duì)路徑中提取文件名
    LPWSTR pch=wcsrchr(wszFullPath,'\\');
    
if (pch)
        lstrcpy(fileName, 
++pch);
    
else
        lstrcpy(fileName, wszFullPath);
}



//-----------------------------------------------------------------------------
// Desc: 創(chuàng)建場(chǎng)景圖形
//-----------------------------------------------------------------------------
HRESULT InitGeometry()
{
    LPD3DXBUFFER pD3DXMtrlBuffer;  
//存儲(chǔ)網(wǎng)格模型材質(zhì)的緩沖區(qū)對(duì)象

    
//從磁盤文件加載網(wǎng)格模型
    if( FAILED( D3DXLoadMeshFromX( L"airplane.x", D3DXMESH_MANAGED, 
                                   g_pd3dDevice, NULL, 
                                   
&pD3DXMtrlBuffer, NULL, &g_dwNumMaterials, 
                                   
&g_pMesh ) ) )
    {
        MessageBox(NULL, L
"Could not find airplane.x", L"Mesh", MB_OK);
        
return E_FAIL;
    }

    
//從網(wǎng)格模型中提取材質(zhì)屬性和紋理文件名 
    D3DXMATERIAL* d3dxMaterials = (D3DXMATERIAL*)pD3DXMtrlBuffer->GetBufferPointer();
    g_pMeshMaterials 
= new D3DMATERIAL9[g_dwNumMaterials];

    
if( g_pMeshMaterials == NULL )
        
return E_OUTOFMEMORY;

    g_pMeshTextures  
= new LPDIRECT3DTEXTURE9[g_dwNumMaterials];
    
if( g_pMeshTextures == NULL )
        
return E_OUTOFMEMORY;

    
//逐塊提取網(wǎng)格模型材質(zhì)屬性和紋理文件名
    for( DWORD i=0; i<g_dwNumMaterials; i++ )
    {
        
//材料屬性
        g_pMeshMaterials[i] = d3dxMaterials[i].MatD3D;
        
//設(shè)置模型材料的環(huán)境光反射系數(shù), 因?yàn)槟P筒牧媳旧頉]有設(shè)置環(huán)境光反射系數(shù)
        g_pMeshMaterials[i].Ambient = g_pMeshMaterials[i].Diffuse;

        g_pMeshTextures[i] 
= NULL;
        
if( d3dxMaterials[i].pTextureFilename != NULL && 
            strlen(d3dxMaterials[i].pTextureFilename) 
> 0 )
        {
            
//獲取紋理文件名
            WCHAR filename[256];
            RemovePathFromFileName(d3dxMaterials[i].pTextureFilename, filename);

            
//創(chuàng)建紋理
            if( FAILED( D3DXCreateTextureFromFile( g_pd3dDevice, filename, 
                                                  
&g_pMeshTextures[i] ) ) )
            {
                MessageBox(NULL, L
"Could not find texture file", L"Mesh", MB_OK);
            }
        }
    }

    
//釋放在加載模型文件時(shí)創(chuàng)建的保存模型材質(zhì)和紋理數(shù)據(jù)的緩沖區(qū)對(duì)象
    pD3DXMtrlBuffer->Release();

    
//計(jì)算網(wǎng)格模型邊界球中心
    LPDIRECT3DVERTEXBUFFER9 pVB; //網(wǎng)格對(duì)象頂點(diǎn)緩沖區(qū)接口
    if( SUCCEEDED( g_pMesh->GetVertexBuffer( &pVB ) ) )
    {
        
struct VERTEX { FLOAT x,y,z,tu,tv; };
        VERTEX
*      pVertices; //頂點(diǎn)緩沖區(qū)指針
        float        fRadius;

        pVB
->Lock( 00, (void**)&pVertices, 0 ); 

        
//計(jì)算網(wǎng)格對(duì)象的邊界球中心和半徑
        D3DXComputeBoundingSphere( (D3DXVECTOR3*)pVertices, g_pMesh->GetNumVertices(),
                                    D3DXGetFVFVertexSize(g_pMesh
->GetFVF()),
                                    
&g_vCenter, &fRadius );
        pVB
->Unlock();
        pVB
->Release();
    }

    
return S_OK;
}


//-----------------------------------------------------------------------------
// Desc: 釋放創(chuàng)建的對(duì)象
//-----------------------------------------------------------------------------
VOID Cleanup()
{
    
//釋放網(wǎng)格模型材質(zhì)
    if( g_pMeshMaterials != NULL ) 
        delete[] g_pMeshMaterials;

    
//釋放網(wǎng)格模型紋理
    if( g_pMeshTextures )
    {
        
for( DWORD i = 0; i < g_dwNumMaterials; i++ )
        {
            
if( g_pMeshTextures[i] )
                g_pMeshTextures[i]
->Release();
        }
        delete[] g_pMeshTextures;
    }

    
//釋放網(wǎng)格模型對(duì)象
    if( g_pMesh != NULL )
        g_pMesh
->Release();
    
    
//釋放Direct3D設(shè)備對(duì)象
    if( g_pd3dDevice != NULL )
        g_pd3dDevice
->Release();

    
//釋放Direct3D對(duì)象
    if( g_pD3D != NULL )
        g_pD3D
->Release();
}


//-----------------------------------------------------------------------------
// Desc: 渲染場(chǎng)景
//-----------------------------------------------------------------------------
VOID Render()
{
    
// 清除緩沖區(qū)
    g_pd3dDevice->Clear( 0, NULL, D3DCLEAR_TARGET|D3DCLEAR_ZBUFFER, 
                         D3DCOLOR_XRGB(
0,0,255), 1.0f0 );
    
    
//開始渲染場(chǎng)景
    if( SUCCEEDED( g_pd3dDevice->BeginScene() ) )
    {
        SetWorldMatrix();  
//設(shè)置世界矩陣

        
//逐塊渲染網(wǎng)格模型
        for( DWORD i=0; i<g_dwNumMaterials; i++ )
        {
            
//設(shè)置材料和紋理
            g_pd3dDevice->SetMaterial( &g_pMeshMaterials[i] );
            g_pd3dDevice
->SetTexture( 0, g_pMeshTextures[i] );

            
//渲染模型
            g_pMesh->DrawSubset( i );
        }

        
//場(chǎng)景渲染結(jié)束
        g_pd3dDevice->EndScene();
    }

    
//在屏幕上顯示場(chǎng)景
    g_pd3dDevice->Present( NULL, NULL, NULL, NULL );
}


//-----------------------------------------------------------------------------
// Desc: 窗口過(guò)程, 處理消息
//-----------------------------------------------------------------------------
LRESULT WINAPI MsgProc( HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam )
{
    
switch( msg )
    {
    
case WM_DESTROY:
        Cleanup();
        PostQuitMessage( 
0 );
        
return 0;

    
case WM_KEYDOWN:
        m_bKey[wParam] 
= 1;
        
return 0;

    
case WM_KEYUP:
        m_bKey[wParam] 
= 0;
        
return 0;
    }

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


//-----------------------------------------------------------------------------
// Desc: 入口函數(shù)
//-----------------------------------------------------------------------------
INT WINAPI WinMain( HINSTANCE hInst, HINSTANCE, LPSTR, INT )
{
    
//注冊(cè)窗口類
    WNDCLASSEX wc = { sizeof(WNDCLASSEX), CS_CLASSDC, MsgProc, 0L0L
                      GetModuleHandle(NULL), NULL, NULL, NULL, NULL,
                      L
"ClassName", NULL };
    RegisterClassEx( 
&wc );

    
//創(chuàng)建窗口
    HWND hWnd = CreateWindow( L"ClassName", L"通過(guò)四元數(shù)實(shí)現(xiàn)模型空間定位"
                              WS_OVERLAPPEDWINDOW, 
200100500500,
                              GetDesktopWindow(), NULL, wc.hInstance, NULL );

    
//初始化Direct3D
    if( SUCCEEDED( InitD3D( hWnd ) ) )
    { 
        
//創(chuàng)建場(chǎng)景圖形
        if( SUCCEEDED( InitGeometry() ) )
        {
            
//顯示窗口
            ShowWindow( hWnd, SW_SHOWDEFAULT );
            UpdateWindow( hWnd );

            
//進(jìn)入消息循環(huán)
            MSG msg; 
            ZeroMemory( 
&msg, sizeof(msg) );
            
while( msg.message!=WM_QUIT )
            {
                
if( PeekMessage( &msg, NULL, 00, PM_REMOVE ) )
                {
                    TranslateMessage( 
&msg );
                    DispatchMessage( 
&msg );
                }
                
else
                {
                    Render();  
//渲染場(chǎng)景
                }
            }
        }
    }

    UnregisterClass( L
"ClassName", wc.hInstance );
    
return 0;
}


















posted on 2008-03-25 20:03 七星重劍 閱讀(418) 評(píng)論(0)  編輯 收藏 引用 所屬分類: Game Graphics
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            你懂的国产精品永久在线| 国产精品久久久久久久久久免费看| 麻豆精品精华液| 亚洲欧美中文日韩v在线观看| 亚洲精品影视| 亚洲精品孕妇| 亚洲免费高清视频| 日韩亚洲一区二区| 日韩视频精品在线| 亚洲午夜在线视频| 亚洲女人天堂成人av在线| 亚洲欧美日韩国产成人精品影院| 亚洲欧美日韩区| 久久精品视频网| 久热精品视频在线| 欧美国产日韩xxxxx| 最近看过的日韩成人| 久久天堂精品| 久久免费高清视频| 欧美日本不卡| 国产女优一区| 在线精品一区二区| 亚洲精品一品区二品区三品区| 日韩一级大片| 性欧美18~19sex高清播放| 久久久久久久成人| 亚洲国产乱码最新视频| 一区二区三区不卡视频在线观看 | 欧美日韩国产综合视频在线观看中文 | 欧美精品一区二区三区在线看午夜| 欧美日本视频在线| 国产精品自拍一区| 亚洲国内在线| 午夜亚洲福利在线老司机| 免费在线观看一区二区| 9人人澡人人爽人人精品| 久久精品二区三区| 欧美在线精品一区| 欧美极品在线观看| 黑人极品videos精品欧美裸| av不卡在线| 免费在线观看日韩欧美| 亚洲专区在线视频| 欧美激情亚洲自拍| 国产亚洲网站| 久久精品噜噜噜成人av农村| 欧美高清在线观看| 亚洲一区国产视频| 欧美日韩国产成人在线| 永久免费精品影视网站| 亚洲欧美另类综合偷拍| 亚洲精品欧美| 午夜伦欧美伦电影理论片| 欧美日韩精品中文字幕| 久久综合给合| 国产日韩免费| 亚洲免费人成在线视频观看| 亚洲欧洲三级| 欧美成人精品h版在线观看| 欧美激情一二区| 亚洲高清影视| 欧美3dxxxxhd| 久久免费高清| 伊人春色精品| 另类尿喷潮videofree| 一区二区三区在线高清| 国产精品99久久久久久人| 亚洲国产一成人久久精品| 久久尤物视频| 亚洲国产一区在线观看| 亚洲大片av| 欧美承认网站| 洋洋av久久久久久久一区| 亚洲激情影视| 欧美日韩国产黄| 亚洲在线观看免费视频| 亚洲无毛电影| 国产欧美一区二区视频| 欧美在线视频一区二区| 亚洲欧美日韩精品一区二区| 国产精品一区二区女厕厕| 欧美永久精品| 久久久999成人| 亚洲黄网站黄| 日韩小视频在线观看专区| 国产精品sss| 久久精品人人做人人爽| 久久这里有精品视频| 在线播放中文一区| 91久久线看在观草草青青| 欧美日韩综合精品| 欧美专区福利在线| 久久亚洲综合色| 亚洲校园激情| 欧美一区观看| 亚洲精品美女91| 一区二区欧美国产| 国产在线观看91精品一区| 亚洲成色精品| 国产精品一区二区久久| 欧美激情第一页xxx| 国产精品久久久久久久久婷婷| 久久性天堂网| 欧美日韩亚洲高清| 久久影院午夜论| 欧美日韩精品中文字幕| 日韩一区二区精品| 欧美伊人影院| 久久综合一区| 亚洲欧美国产日韩中文字幕| 美女黄网久久| 欧美一区二区三区啪啪| 欧美大尺度在线| 久久久噜噜噜| 国产精品毛片在线看| 最新国产精品拍自在线播放| 国产一区久久久| 亚洲性av在线| 夜夜嗨网站十八久久| 久久色中文字幕| 久久国产精品久久精品国产| 欧美美女福利视频| 美女网站在线免费欧美精品| 国产精品永久在线| 亚洲深夜福利在线| 99天天综合性| 欧美成人激情在线| 欧美国产日本| 亚洲国产成人在线| 久久精品五月| 久久久国产一区二区| 国产欧美高清| 亚洲一区亚洲二区| 亚洲伊人伊色伊影伊综合网| 欧美精品v国产精品v日韩精品| 免费不卡在线观看| 国产日本欧美一区二区三区| 亚洲天堂成人在线视频| 亚洲影院色在线观看免费| 欧美日韩大片一区二区三区| 欧美激情女人20p| 在线日韩av片| 久久er精品视频| 久久精品国产69国产精品亚洲 | 欧美成人中文| 国产欧美日韩视频| 日韩午夜免费视频| 亚洲国产一区二区三区青草影视| 久久亚洲欧美| 久久一区亚洲| 国产亚洲综合性久久久影院| 亚洲视频电影图片偷拍一区| 午夜欧美不卡精品aaaaa| 欧美母乳在线| 亚洲黄色天堂| 亚洲人成网站在线播| 亚洲精品免费在线| 亚洲一区二区三区视频播放| 欧美日本精品一区二区三区| 亚洲精品久久| 99视频精品在线| 国产精品乱看| 亚洲一区二区少妇| 性欧美办公室18xxxxhd| 国产精品日韩欧美一区二区| 久久人人97超碰国产公开结果| 国产精品久久久久国产a级| 日韩视频在线你懂得| 一区二区三区精品视频| 国产精品尤物福利片在线观看| 亚洲欧美国产日韩天堂区| 欧美一级大片在线免费观看| 亚洲欧美视频一区| 国产精品任我爽爆在线播放| 在线中文字幕日韩| 亚洲自拍偷拍麻豆| 欧美激情精品久久久久| 久久黄色级2电影| 国产主播精品| 老司机67194精品线观看| 亚洲福利视频免费观看| 午夜视频精品| 女生裸体视频一区二区三区| 亚洲一区二区精品在线| 欧美一区国产二区| 91久久国产综合久久91精品网站| 麻豆精品传媒视频| 亚洲人成网站色ww在线| 亚洲影院免费| 欧美视频在线一区二区三区| 久久久蜜桃精品| 亚洲精品视频在线| 欧美影片第一页| 国产伦精品一区二区三区| 免费亚洲视频| 亚洲在线一区二区| 久久亚洲一区二区| 夜夜嗨av一区二区三区中文字幕 | 亚洲三级电影全部在线观看高清| 一本高清dvd不卡在线观看|