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

隨筆 - 505  文章 - 1034  trackbacks - 0
<2008年11月>
2627282930311
2345678
9101112131415
16171819202122
23242526272829
30123456


子曾經曰過:編程無他,唯手熟爾!

常用鏈接

留言簿(94)

隨筆分類(649)

隨筆檔案(505)

相冊

BCB

Crytek

  • crymod
  • Crytek's Offical Modding Portal

Game Industry

OGRE

other

Programmers

Qt

WOW Stuff

搜索

  •  

積分與排名

  • 積分 - 918549
  • 排名 - 14

最新隨筆

最新評論

閱讀排行榜

評論排行榜


通過四元數實現模型空間定位







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


//-----------------------------------------------------------------------------
// Desc: 全局變量
//-----------------------------------------------------------------------------
LPDIRECT3D9             g_pD3D           = NULL;  //Direct3D對象
LPDIRECT3DDEVICE9       g_pd3dDevice     = NULL;  //Direct3D設備對象

LPD3DXMESH              g_pMesh          
= NULL;  //網格模型對象
D3DMATERIAL9*           g_pMeshMaterials = NULL;  //網格模型材質
LPDIRECT3DTEXTURE9*     g_pMeshTextures  = NULL;  //網格模型紋理
DWORD                   g_dwNumMaterials = 0L;    //網格模型材質數量
D3DXVECTOR3             g_vCenter;                //網格模型中心點 

BYTE  m_bKey[
256];            // keyboard state buffer

D3DXMATRIX              g_matWorld;


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

    
//創建并設置世界矩陣  
    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;

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

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

    
//向前移動
    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;
    }

    
//向后移動
    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: 設置觀察矩陣和投影矩陣
//-----------------------------------------------------------------------------
VOID SetViewAndProjMatrix()
{
    
//創建并設置觀察矩陣
    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 );

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


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

    
//設置D3DPRESENT_PARAMETERS結構, 準備創建Direct3D設備對象
    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;

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

    
//設置紋理過濾狀態
    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 );

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

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


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

    WCHAR
* wszFullPath = wszBuf;

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



//-----------------------------------------------------------------------------
// Desc: 創建場景圖形
//-----------------------------------------------------------------------------
HRESULT InitGeometry()
{
    LPD3DXBUFFER pD3DXMtrlBuffer;  
//存儲網格模型材質的緩沖區對象

    
//從磁盤文件加載網格模型
    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;
    }

    
//從網格模型中提取材質屬性和紋理文件名 
    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;

    
//逐塊提取網格模型材質屬性和紋理文件名
    for( DWORD i=0; i<g_dwNumMaterials; i++ )
    {
        
//材料屬性
        g_pMeshMaterials[i] = d3dxMaterials[i].MatD3D;
        
//設置模型材料的環境光反射系數, 因為模型材料本身沒有設置環境光反射系數
        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);

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

    
//釋放在加載模型文件時創建的保存模型材質和紋理數據的緩沖區對象
    pD3DXMtrlBuffer->Release();

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

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

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

    
return S_OK;
}


//-----------------------------------------------------------------------------
// Desc: 釋放創建的對象
//-----------------------------------------------------------------------------
VOID Cleanup()
{
    
//釋放網格模型材質
    if( g_pMeshMaterials != NULL ) 
        delete[] g_pMeshMaterials;

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

    
//釋放網格模型對象
    if( g_pMesh != NULL )
        g_pMesh
->Release();
    
    
//釋放Direct3D設備對象
    if( g_pd3dDevice != NULL )
        g_pd3dDevice
->Release();

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


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

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

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

        
//場景渲染結束
        g_pd3dDevice->EndScene();
    }

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


//-----------------------------------------------------------------------------
// Desc: 窗口過程, 處理消息
//-----------------------------------------------------------------------------
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: 入口函數
//-----------------------------------------------------------------------------
INT WINAPI WinMain( HINSTANCE hInst, HINSTANCE, LPSTR, INT )
{
    
//注冊窗口類
    WNDCLASSEX wc = { sizeof(WNDCLASSEX), CS_CLASSDC, MsgProc, 0L0L
                      GetModuleHandle(NULL), NULL, NULL, NULL, NULL,
                      L
"ClassName", NULL };
    RegisterClassEx( 
&wc );

    
//創建窗口
    HWND hWnd = CreateWindow( L"ClassName", L"通過四元數實現模型空間定位"
                              WS_OVERLAPPEDWINDOW, 
200100500500,
                              GetDesktopWindow(), NULL, wc.hInstance, NULL );

    
//初始化Direct3D
    if( SUCCEEDED( InitD3D( hWnd ) ) )
    { 
        
//創建場景圖形
        if( SUCCEEDED( InitGeometry() ) )
        {
            
//顯示窗口
            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 );
                }
                
else
                {
                    Render();  
//渲染場景
                }
            }
        }
    }

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


















posted on 2008-03-25 20:03 七星重劍 閱讀(416) 評論(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>
            国内久久精品视频| 欧美精品久久一区| 久久天天综合| 久久久久久免费| 久久久综合网| 蜜桃久久av| 91久久精品国产91久久性色| 玖玖国产精品视频| 欧美www视频在线观看| 亚洲国产精品激情在线观看| 亚洲区一区二| 亚洲欧美日韩人成在线播放| 久久亚洲捆绑美女| 欧美三级午夜理伦三级中视频| 国产精品海角社区在线观看| 欧美大片在线观看| 亚洲精品视频免费在线观看| 亚洲另类在线视频| 亚洲欧美日韩国产中文| 久久久xxx| 亚洲精品日韩综合观看成人91 | 亚洲砖区区免费| 欧美一区二区三区视频| 欧美大片专区| 亚久久调教视频| 欧美日韩另类一区| 在线日韩视频| 亚洲欧美日韩国产中文| 亚洲国产精品va在线观看黑人| 亚洲综合精品四区| 欧美欧美天天天天操| 一区二区三区中文在线观看| 亚洲欧美国内爽妇网| 亚洲风情在线资源站| 亚洲午夜视频| 欧美成ee人免费视频| 亚洲亚洲精品在线观看| 欧美激情精品久久久久久| 国产日韩一区二区三区在线播放| 99ri日韩精品视频| 欧美v亚洲v综合ⅴ国产v| 欧美诱惑福利视频| 国产精品毛片高清在线完整版| 亚洲精品国产系列| 欧美第一黄网免费网站| 久久久国产午夜精品| 国产精品视频一二三| 一区二区三区国产精品| 亚洲成在线观看| 久久午夜羞羞影院免费观看| 激情婷婷久久| 免费成人网www| 久久久综合视频| 亚洲国产欧美日韩| 欧美大片va欧美在线播放| 久久精品国产2020观看福利| 国产日韩一区二区| 久久精品国产综合| 欧美在线free| 在线不卡免费欧美| 欧美成人一区二区三区在线观看| 久久成人免费电影| 红杏aⅴ成人免费视频| 久久久久久久999| 欧美一区二区三区四区夜夜大片 | 久久人91精品久久久久久不卡| 国产亚洲人成a一在线v站| 久久成人18免费观看| 午夜国产精品视频免费体验区| 国产精品久久久久久久久久ktv| 亚洲香蕉成视频在线观看| 国产精品99久久久久久www| 国产精品久久久久久模特| 香蕉久久夜色| 欧美一区激情视频在线观看| 1769国产精品| 亚洲精品系列| 国产日韩精品一区| 欧美高清视频| 国产精品视频yy9099| 免费欧美电影| 欧美日韩中文在线| 久久国产精品亚洲va麻豆| 久久久久久伊人| 中文一区二区| 久久久综合视频| 亚洲深夜激情| 欧美专区在线观看| 一二三区精品福利视频| 亚洲欧美日韩一区在线| 亚洲欧洲一区二区三区在线观看| 夜夜嗨av一区二区三区| 国内精品国语自产拍在线观看| 欧美激情va永久在线播放| 欧美视频一区| 亚洲成在线观看| 亚洲无线视频| 亚洲毛片av| 欧美在线精品免播放器视频| 亚洲精品视频二区| 欧美在线观看视频| 亚洲一区3d动漫同人无遮挡| 久久九九久精品国产免费直播| 一卡二卡3卡四卡高清精品视频| 香蕉久久夜色精品国产| 亚洲天堂偷拍| 老司机凹凸av亚洲导航| 欧美影院在线| 欧美体内she精视频在线观看| 欧美mv日韩mv亚洲| 国产日韩精品视频一区二区三区| 亚洲美洲欧洲综合国产一区| 在线国产精品播放| 午夜视频一区在线观看| 一区二区三区四区五区精品视频| 久久久一区二区三区| 久久国产黑丝| 国产精品综合色区在线观看| 亚洲精品久久久久中文字幕欢迎你 | 欧美在线视频日韩| 在线精品国产成人综合| 亚洲综合国产| 香蕉久久国产| 国产精品视频内| 中文在线资源观看网站视频免费不卡 | 在线不卡中文字幕| 在线一区日本视频| 亚洲视频欧美在线| 欧美日韩国产精品成人| 亚洲黄色在线看| 亚洲精品国产日韩| 欧美成人精品在线观看| 亚洲第一毛片| 亚洲欧洲一区二区在线播放| 久久国产精品久久精品国产| 久久国产婷婷国产香蕉| 国产欧美日韩亚洲一区二区三区| 亚洲午夜激情| 欧美一区二区| 国内外成人免费视频| 欧美一区二区三区在线看| 久久国产精品亚洲77777| 国产一区白浆| 久久深夜福利| 亚洲精品免费在线观看| 亚洲一卡二卡三卡四卡五卡| 国产精品夜色7777狼人| 欧美中文字幕在线播放| 欧美成人精品激情在线观看| 91久久精品美女| 欧美三级资源在线| 亚洲欧美日韩精品久久亚洲区 | 麻豆成人综合网| 亚洲国产一区二区a毛片| 欧美韩日精品| 国产精品99久久久久久久vr | 国产精品一区二区女厕厕| 99热这里只有成人精品国产| 亚洲综合电影| 国产亚洲欧美中文| 美女啪啪无遮挡免费久久网站| 亚洲高清免费| 亚洲欧美日韩国产中文| 激情五月婷婷综合| 欧美日本在线视频| 亚洲欧美日韩另类精品一区二区三区| 亚洲人成人77777线观看| 欧美日韩成人在线观看| 亚洲影院免费观看| 欧美不卡激情三级在线观看| 一本久久综合亚洲鲁鲁五月天| 国产精品一卡二| 狂野欧美性猛交xxxx巴西| 99综合视频| 免费成人av资源网| 亚洲一区精品在线| 一区二区在线免费观看| 国产精品啊v在线| 另类综合日韩欧美亚洲| 一区二区久久| 欧美大片在线看| 欧美一区综合| 夜夜爽www精品| 精品福利免费观看| 国产精品国产三级国产普通话蜜臀 | 激情综合中文娱乐网| 欧美激情久久久久久| 欧美一区不卡| 夜色激情一区二区| 欧美国产在线电影| 午夜精品久久久久久久| 亚洲精品视频在线播放| 韩国精品久久久999| 国产精品99一区| 欧美国产视频在线| 久久伊伊香蕉| 久久综合伊人| 久久久夜精品| 久久免费视频一区| 久久aⅴ乱码一区二区三区|