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

天行健 君子當自強而不息

DXUT源碼分析 ---- 類CDXUTMesh(3)

接下來的Create()函數從接口ID3DXFileData創建網格模型:

HRESULT CDXUTMesh::Create( LPDIRECT3DDEVICE9 pd3dDevice, LPD3DXFILEDATA pFileData )
{
    LPD3DXBUFFER pMtrlBuffer 
= NULL;
    LPD3DXBUFFER pAdjacencyBuffer 
= NULL;
    HRESULT      hr;

    
// Cleanup previous mesh if any
    Destroy();

    
// Load the mesh from the DXFILEDATA object
    if( FAILED( hr = D3DXLoadMeshFromXof( pFileData, D3DXMESH_MANAGED, pd3dDevice, &pAdjacencyBuffer, &pMtrlBuffer, 
                                          NULL, 
&m_dwNumMaterials, &m_pMesh ) ) )
    {
        
return hr;
    }

    
// Optimize the mesh for performance
    if( FAILED( hr = m_pMesh->OptimizeInplace(
                        D3DXMESHOPT_COMPACT 
| D3DXMESHOPT_ATTRSORT | D3DXMESHOPT_VERTEXCACHE,
                        (DWORD
*)pAdjacencyBuffer->GetBufferPointer(), NULL, NULL, NULL ) ) )
    {
        SAFE_RELEASE( pAdjacencyBuffer );
        SAFE_RELEASE( pMtrlBuffer );
        
return hr;
    }

    D3DXMATERIAL
* d3dxMtrls = (D3DXMATERIAL*)pMtrlBuffer->GetBufferPointer();
    hr 
= CreateMaterials( L"", pd3dDevice, d3dxMtrls, m_dwNumMaterials );

    SAFE_RELEASE( pAdjacencyBuffer );
    SAFE_RELEASE( pMtrlBuffer );

    
// Extract data from m_pMesh for easy access
    D3DVERTEXELEMENT9 decl[MAX_FVF_DECL_SIZE];

    m_dwNumVertices    
= m_pMesh->GetNumVertices();
    m_dwNumFaces       
= m_pMesh->GetNumFaces();
    m_dwBytesPerVertex 
= m_pMesh->GetNumBytesPerVertex();

    m_pMesh
->GetIndexBuffer( &m_pIB );
    m_pMesh
->GetVertexBuffer( &m_pVB );
    m_pMesh
->GetDeclaration( decl );

    pd3dDevice
->CreateVertexDeclaration( decl, &m_pDecl );

    
return hr;
}

 

該函數與上一個Create()函數并無太大區別,只是在加載網格模型時調用D3DXLoadMeshFromXof()而不是D3DXLoadMeshFromXW()。

 

最后一個Create()函數從輸入的網格模型中創建新的網格模型:

HRESULT CDXUTMesh::Create( LPDIRECT3DDEVICE9 pd3dDevice, ID3DXMesh* pInMesh, 
                           D3DXMATERIAL
* pd3dxMaterials, DWORD dwMaterials )
{
    
// Cleanup previous mesh if any
    Destroy();

    
// Optimize the mesh for performance

    DWORD 
*rgdwAdjacency = NULL;

    rgdwAdjacency 
= new DWORD[pInMesh->GetNumFaces() * 3];
    
if( rgdwAdjacency == NULL )
        
return E_OUTOFMEMORY;

    pInMesh
->GenerateAdjacency(1e-6f, rgdwAdjacency);

    D3DVERTEXELEMENT9 decl[MAX_FVF_DECL_SIZE];
    pInMesh
->GetDeclaration( decl );

    DWORD dwOptions 
= pInMesh->GetOptions();

    dwOptions 
&= ~(D3DXMESH_32BIT | D3DXMESH_SYSTEMMEM | D3DXMESH_WRITEONLY);
    dwOptions 
|= D3DXMESH_MANAGED;
    dwOptions 
|= D3DXMESHOPT_COMPACT | D3DXMESHOPT_ATTRSORT | D3DXMESHOPT_VERTEXCACHE;

    ID3DXMesh
* pTempMesh = NULL;

    
if( FAILED( pInMesh->Optimize( dwOptions, rgdwAdjacency, NULL, NULL, NULL, &pTempMesh ) ) )
    {
        SAFE_DELETE_ARRAY( rgdwAdjacency );
        
return E_FAIL;
    }

    SAFE_DELETE_ARRAY( rgdwAdjacency );
    SAFE_RELEASE( m_pMesh );

    m_pMesh 
= pTempMesh;

    HRESULT hr 
= CreateMaterials( L"", pd3dDevice, pd3dxMaterials, dwMaterials );;    

    
// Extract data from m_pMesh for easy access

    m_dwNumVertices    
= m_pMesh->GetNumVertices();
    m_dwNumFaces       
= m_pMesh->GetNumFaces();
    m_dwBytesPerVertex 
= m_pMesh->GetNumBytesPerVertex();

    m_pMesh
->GetIndexBuffer( &m_pIB );
    m_pMesh
->GetVertexBuffer( &m_pVB );
    m_pMesh
->GetDeclaration( decl );

    pd3dDevice
->CreateVertexDeclaration( decl, &m_pDecl );

    
return hr;
}

 

為了優化網格的渲染,函數首先生成網格面鄰接信息緩存:
    DWORD *rgdwAdjacency = NULL;
    rgdwAdjacency = new DWORD[pInMesh->GetNumFaces() * 3];
    if( rgdwAdjacency == NULL )
        return E_OUTOFMEMORY;
    pInMesh->GenerateAdjacency(1e-6f, rgdwAdjacency);

GenerateAdjacency()的聲明如下:

Generate a list of mesh edges, as well as a list of faces that share each edge.

HRESULT GenerateAdjacency(
FLOAT Epsilon,
DWORD * pAdjacency
);

Parameters

Epsilon
[in] Specifies that vertices that differ in position by less than epsilon should be treated as coincident.
pAdjacency
[in] Pointer to an array of three DWORDs per face to be filled with the indices of adjacent faces. The number of bytes in this array must be at least 3 * ID3DXBaseMesh::GetNumFaces * sizeof(DWORD).

Return Values

If the method succeeds, the return value is D3D_OK. If the method fails, the return value can be one of the following: D3DERR_INVALIDCALL, E_OUTOFMEMORY.

Remarks

After an application generates adjacency information for a mesh, the mesh data can be optimized for better drawing performance.

The order of the entries in the adjacency buffer is determined by the order of the vertex indices in the index buffer. The adjacent triangle 0 always corresponds to the edge between the indices of the corners 0 and 1. The adjacent triangle 1 always corresponds to the edge between the indices of the corners 1 and 2 while the adjacent triangle 2 corresponds to the edge between the indices of the corners 2 and 0.

為了優化網格的渲染,函數去除了32位索引、系統內存的使用、只寫訪問,增加了托管內存的使用,以及去除了無用的頂點和索引項、根據屬性給三角形排序并調整屬性表,增加了頂點緩存的命中率,并調用Optimize()對網格模型進行優化,優化后的網格模型存儲在pTempMesh中:

    DWORD dwOptions = pInMesh->GetOptions();
    dwOptions &= ~(D3DXMESH_32BIT | D3DXMESH_SYSTEMMEM | D3DXMESH_WRITEONLY);
dwOptions |= D3DXMESH_MANAGED;
dwOptions |= D3DXMESHOPT_COMPACT | D3DXMESHOPT_ATTRSORT | D3DXMESHOPT_VERTEXCACHE;
    ID3DXMesh* pTempMesh = NULL;
    if( FAILED( pInMesh->Optimize( dwOptions, rgdwAdjacency, NULL, NULL, NULL, &pTempMesh ) ) )
{
SAFE_DELETE_ARRAY( rgdwAdjacency );
return E_FAIL;
}

接下來刪除了鄰接數組、網格指針,并將優化后的網格模型指針賦給m_pMesh,并調用CreateMaterials()創建材質和紋理資源:

    SAFE_DELETE_ARRAY( rgdwAdjacency );
SAFE_RELEASE( m_pMesh );
    m_pMesh = pTempMesh;
    HRESULT hr = CreateMaterials( L"", pd3dDevice, pd3dxMaterials, dwMaterials );

最后從優化后的網格模型中提取數據以方便日后訪問,并調用CreateVertexDeclaration()來創建頂點聲明:

   // Extract data from m_pMesh for easy access
    m_dwNumVertices    = m_pMesh->GetNumVertices();
m_dwNumFaces = m_pMesh->GetNumFaces();
m_dwBytesPerVertex = m_pMesh->GetNumBytesPerVertex();
    m_pMesh->GetIndexBuffer( &m_pIB );
m_pMesh->GetVertexBuffer( &m_pVB );
    D3DVERTEXELEMENT9 decl[MAX_FVF_DECL_SIZE];
m_pMesh->GetDeclaration( decl );
pd3dDevice->CreateVertexDeclaration( decl, &m_pDecl );
    return hr;

CreateVertexDeclaration()的聲明如下:

Create a vertex shader declaration from the device and the vertex elements.

HRESULT CreateVertexDeclaration(
CONST D3DVERTEXELEMENT9* pVertexElements,
IDirect3DVertexDeclaration9** ppDecl
);

Parameters

pVertexElements
[in] An array of D3DVERTEXELEMENT9 vertex elements.
ppDecl
[out, retval] Pointer to an IDirect3DVertexDeclaration9 pointer that returns the created vertex shader declaration.

Return Values

If the method succeeds, the return value is D3D_OK. If the method fails, the return value can be D3DERR_INVALIDCALL.

Remarks

See the Vertex Declaration (Direct3D 9) page for a detailed description of how to map vertex declarations between different versions of DirectX.

 

函數Destroy()用來在程序退出時銷毀指定的資源:

HRESULT CDXUTMesh::Destroy()
{
InvalidateDeviceObjects();
    for( UINT i=0; i<m_dwNumMaterials; i++ )
SAFE_RELEASE( m_pTextures[i] );
    SAFE_DELETE_ARRAY( m_pTextures );
SAFE_DELETE_ARRAY( m_pMaterials );
SAFE_DELETE_ARRAY( m_strMaterials );
    SAFE_RELEASE( m_pMesh );
    m_dwNumMaterials = 0L;
    return S_OK;
}

posted on 2008-05-31 10:21 lovedday 閱讀(912) 評論(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>
            欧美电影在线观看| 亚洲一区精品视频| 91久久精品日日躁夜夜躁国产| 伊人久久综合97精品| 亚洲欧洲日韩在线| 午夜日韩电影| 91久久久久久久久久久久久| 欧美成人四级电影| 中文欧美在线视频| 亚洲承认在线| 欧美一区二区精美| 欧美调教视频| 99re视频这里只有精品| 美女视频黄a大片欧美| 亚洲综合国产| 欧美午夜性色大片在线观看| 亚洲精品一品区二品区三品区| 久久久久久夜精品精品免费| 亚洲一级免费视频| 欧美三级视频在线播放| 欧美在线一区二区三区| 亚洲一区二区三区国产| 精品不卡一区二区三区| 久久aⅴ国产紧身牛仔裤| 久久久久久免费| 国精品一区二区三区| 久久精品一区二区三区不卡牛牛| 亚洲自拍都市欧美小说| 在线观看一区视频| 欧美成人性生活| 老巨人导航500精品| 亚洲福利视频三区| 欧美激情aaaa| 欧美国产日本韩| 日韩视频二区| 亚洲毛片一区| 国产精品sss| 欧美国产一区二区| 国产欧美一区二区白浆黑人| 欧美一区激情视频在线观看| 小黄鸭精品密入口导航| 国产一区二区三区四区hd| 久久免费视频在线观看| 欧美日韩美女在线观看| 亚洲主播在线| 欧美在线在线| 91久久国产精品91久久性色| 亚洲国产专区| 国产精品久久网| 久久露脸国产精品| 国产精品私房写真福利视频| 久久精品日产第一区二区| 久久精品亚洲热| 日韩系列欧美系列| 美女啪啪无遮挡免费久久网站| 日韩视频在线观看免费| 久久最新视频| 免费欧美电影| 曰本成人黄色| 久久精品视频在线播放| 久久久激情视频| 国产亚洲午夜高清国产拍精品| 亚洲一区二区av电影| 亚洲网站视频福利| 亚洲欧美日韩在线综合| 亚洲国产高清在线观看视频| 久久黄色网页| 中文国产成人精品| 欧美日韩一区二区免费在线观看| 欧美福利在线| 91久久久久久久久久久久久| 欧美sm极限捆绑bd| 欧美在线一级视频| 国产日韩一级二级三级| 亚洲激情网站| 一区二区三区精品视频| 久久久久在线| 欧美大片91| 亚洲人成精品久久久久| 欧美人与禽性xxxxx杂性| 久久精品免费播放| 精品成人一区二区三区| 久久久天天操| 亚洲大片av| 黑人一区二区| 亚洲一区二区免费看| 久久国产精品亚洲va麻豆| 国产一区二区日韩| 久久综合导航| 亚洲伦理自拍| 欧美中文字幕视频| 亚洲电影免费观看高清完整版| 免费成人网www| 一区二区三区 在线观看视频| 亚洲人成网站在线播| 欧美午夜精品久久久久免费视| 亚洲一区免费观看| 免费在线看成人av| 国产视频一区二区在线观看| 久久久久成人网| 亚洲人午夜精品| 99国产精品一区| 国产视频精品va久久久久久| 久久这里只有| 亚洲一区二区免费视频| 欧美激情一区二区三区高清视频| 亚洲图片在线| 极品裸体白嫩激情啪啪国产精品| 欧美精品一区二区三区四区| 亚洲欧美日韩精品在线| 亚洲国产精品专区久久| 久久久精彩视频| 亚洲图片激情小说| 亚洲国产精品999| 国产欧美日韩精品a在线观看| 欧美高清在线| 久久久久九九视频| 亚洲在线免费观看| 亚洲精品国产精品久久清纯直播| 久久精品国产第一区二区三区最新章节 | 麻豆精品91| 国产一区二区三区网站| 久久亚洲综合色| 亚洲国产精品va在线观看黑人| 亚洲免费小视频| 国产农村妇女精品| 欧美久久久久久蜜桃| 久久综合五月| 久久电影一区| 午夜免费在线观看精品视频| 夜夜嗨av一区二区三区四季av | 亚洲福利视频三区| 国产欧美精品va在线观看| 欧美日本在线播放| 欧美 日韩 国产精品免费观看| 久久成人免费视频| 亚洲欧美日韩精品一区二区 | 老司机精品视频网站| 欧美一级黄色网| 狠狠88综合久久久久综合网| 国产精品女主播| 国产精品美女午夜av| 欧美日韩中文字幕在线视频| 欧美日产一区二区三区在线观看 | 久久青青草综合| 欧美一区亚洲二区| 欧美中文字幕视频在线观看| 亚洲欧美区自拍先锋| 亚洲欧美综合v| 香蕉免费一区二区三区在线观看| 亚洲一区二区毛片| 亚洲欧美日韩国产综合在线| 亚洲资源在线观看| 欧美亚洲日本国产| 欧美在线免费播放| 久久精品中文字幕一区| 老牛国产精品一区的观看方式| 美女视频网站黄色亚洲| 欧美激情a∨在线视频播放| 亚洲国产成人精品女人久久久 | 另类图片综合电影| 欧美韩日一区| 亚洲精品综合精品自拍| 夜夜嗨av一区二区三区| 亚洲尤物视频网| 久久精品日产第一区二区| 欧美xart系列高清| 欧美性大战久久久久| 国产一本一道久久香蕉| 亚洲福利视频一区二区| 日韩视频一区| 香蕉久久国产| 老色批av在线精品| 亚洲人成小说网站色在线 | 久久蜜桃资源一区二区老牛 | 欧美国产日本| 夜夜嗨一区二区三区| 亚洲欧美在线高清| 欧美va天堂va视频va在线| 国产精品久久久久91| 欧美日韩第一区日日骚| 国产欧美日韩一级| 亚洲电影免费在线观看| 亚洲一区二区在线免费观看| 久久久国产一区二区| 亚洲精品久久久蜜桃| 欧美专区福利在线| 欧美日韩中字| 亚洲电影有码| 欧美专区在线| 亚洲日本激情| 久久久久成人网| 国产精品露脸自拍| 亚洲精品一区二区三区福利| 久久国内精品视频| av成人免费| 欧美福利一区二区| 在线精品高清中文字幕| 性8sex亚洲区入口| 亚洲另类黄色|