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

隨筆 - 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少妇一区二区| 免费欧美日韩国产三级电影| 欧美激情亚洲另类| 亚洲一区二区三区四区在线观看 | 欧美在线综合| 亚洲国产1区| 亚洲精品视频在线观看免费| 国产精品视频免费在线观看| 六月婷婷一区| 欧美日韩一区二区精品| 亚洲一级电影| 久久久7777| 99视频一区| 午夜视频一区| 艳女tv在线观看国产一区| 亚洲一区二区三区在线| 在线成人av网站| 一本久久a久久免费精品不卡| 国产农村妇女精品一区二区| 亚洲二区精品| 国产精品久久波多野结衣| 久久综合色播五月| 国产精品乱码一区二区三区| 久久综合网络一区二区| 欧美丝袜一区二区三区| 久久在线精品| 国产九九视频一区二区三区| 亚洲国产精品视频一区| 亚洲福利视频专区| 亚洲日本一区二区| 国产午夜精品麻豆| 亚洲精品小视频| 国内成人在线| 亚洲一区日本| 中文在线资源观看网站视频免费不卡 | 在线观看日韩www视频免费| 一本大道久久a久久综合婷婷| 狠狠色狠狠色综合| 亚洲无玛一区| 中国亚洲黄色| 欧美aⅴ一区二区三区视频| 久久精品一区二区三区四区 | 免费成人毛片| 麻豆精品精华液| 国产日韩欧美电影在线观看| 一本色道久久综合一区| 日韩亚洲一区二区| 美女任你摸久久| 久久久久综合网| 国产一区二区三区高清在线观看| 一区二区冒白浆视频| 日韩亚洲国产精品| 欧美成人精精品一区二区频| 蜜桃伊人久久| 亚洲福利精品| 麻豆av福利av久久av| 美女视频黄免费的久久| 亚洲电影第1页| 久久久99爱| 免费成人你懂的| 在线观看91久久久久久| 另类人畜视频在线| 欧美国产国产综合| 亚洲精品视频在线| 欧美精品自拍偷拍动漫精品| 亚洲国产精品久久久久久女王| 亚洲激情国产精品| 欧美成人精品一区| 亚洲精品网址在线观看| 亚洲影视在线播放| 国产欧美日韩| 久久精品亚洲精品国产欧美kt∨| 麻豆成人在线| 亚洲精品在线观看视频| 欧美日韩你懂的| 亚洲小视频在线观看| 性色av香蕉一区二区| 国产一区二区剧情av在线| 久久国产精品72免费观看| 美女诱惑一区| 亚洲每日在线| 国产毛片精品视频| 久久综合久久综合久久综合| 亚洲激情一区二区| 欧美一区2区视频在线观看| 激情亚洲成人| 欧美日本乱大交xxxxx| 亚洲一区在线免费| 欧美韩日一区二区| 午夜免费日韩视频| 亚洲国产精品久久久久| 欧美三级在线视频| 久久久www成人免费精品| 欧美激情网站在线观看| 国产亚洲va综合人人澡精品| 牛夜精品久久久久久久99黑人 | 国产日韩欧美精品一区| 免费久久精品视频| 亚洲影音先锋| 亚洲激情视频在线播放| 久久精品99| 亚洲视频axxx| 亚洲黄色在线看| 国产精品一级| 欧美欧美午夜aⅴ在线观看| 欧美一区二区三区的| 亚洲日本aⅴ片在线观看香蕉| 亚洲欧美日韩系列| 亚洲开发第一视频在线播放| 国产女主播一区| 欧美日韩不卡视频| 久久综合久久久久88| 欧美亚洲三区| 在线一区欧美| 亚洲日本国产| 亚洲国产精品va在线看黑人| 久久久久亚洲综合| 久久成人免费电影| 亚洲视频 欧洲视频| 99热这里只有成人精品国产| 在线看片一区| 在线成人av.com| 国产深夜精品| 国产老女人精品毛片久久| 欧美日韩在线播放一区| 欧美成人激情在线| 欧美a一区二区| 久久综合伊人77777蜜臀| 久久免费高清视频| 久久久久国色av免费看影院| 香蕉精品999视频一区二区| 国产精品99久久久久久久久久久久 | 99综合电影在线视频| 亚洲精品色婷婷福利天堂| 亚洲国产婷婷| 亚洲精品三级| 一区二区三区精品视频| 99re热这里只有精品视频 | 亚洲国产高清一区二区三区| 一区二区三区在线免费视频| 国产一区二区三区黄| 国产自产女人91一区在线观看| 国产麻豆综合| 激情av一区| 亚洲国产天堂久久综合网| 亚洲免费观看高清完整版在线观看熊 | 国产精品久久久久久亚洲调教 | 日韩小视频在线观看| 日韩视频―中文字幕| 制服丝袜亚洲播放| 亚洲综合电影| 欧美一区二区三区在线观看视频 | 亚洲黄色小视频| 在线视频一区二区| 亚洲欧美国产va在线影院| 欧美电影美腿模特1979在线看| 伊人久久亚洲美女图片| 欧美久久久久| 午夜精品偷拍| 亚洲福利视频网| 国产主播喷水一区二区| 免费试看一区| 亚洲一区二区在线播放| 久久米奇亚洲| 亚洲资源在线观看| 在线国产精品播放| 国产精品免费一区二区三区在线观看| 亚洲欧美资源在线| 亚洲三级免费| 久久国产精品一区二区| 一本久久综合亚洲鲁鲁| 极品尤物av久久免费看| 国产真实乱偷精品视频免| 欧美日韩一二三区| 欧美成人免费va影院高清| 免费观看在线综合色| 久久久久久久91| 午夜精品一区二区在线观看| 99国产精品久久久| 模特精品裸拍一区| 男男成人高潮片免费网站| 久久久精品2019中文字幕神马| 亚洲网友自拍| 亚洲视频狠狠| 亚洲欧美成人在线| 99精品免费网| 亚洲男人的天堂在线| 99riav国产精品| 一区二区三区|亚洲午夜| 日韩视频中文| 亚洲欧美视频在线| 久久久国产一区二区| 美国十次了思思久久精品导航| 欧美中文字幕视频在线观看| 久久久久久亚洲精品杨幂换脸| 久久精品2019中文字幕|