亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? dxutmesh.cpp

?? VC中使用C#作為腳本引擎編程
?? CPP
?? 第 1 頁 / 共 3 頁
字號:
            if( aOldDecl[index].Usage == D3DDECLUSAGE_NORMAL )
            {
                bHadNormal = true;
            }
            if( aOldDecl[index].Usage == D3DDECLUSAGE_TANGENT )
            {
                bHadTangent = true;
            }
        }
    }

    // Check if the new declaration contains a normal.
    bool bHaveNormalNow = false;
    bool bHaveTangentNow = false;
    D3DVERTEXELEMENT9 aNewDecl[MAX_FVF_DECL_SIZE];
    if( pTempMesh && SUCCEEDED( pTempMesh->GetDeclaration( aNewDecl ) ) )
    {
        for( UINT index = 0; index < D3DXGetDeclLength( aNewDecl ); ++index )
        {
            if( aNewDecl[index].Usage == D3DDECLUSAGE_NORMAL )
            {
                bHaveNormalNow = true;
            }
            if( aNewDecl[index].Usage == D3DDECLUSAGE_TANGENT )
            {
                bHaveTangentNow = true;
            }
        }
    }

    SAFE_RELEASE( m_pMesh );

    if( pTempMesh )
    {
        m_pMesh = pTempMesh;

        if( !bHadNormal && bHaveNormalNow && bAutoComputeNormals )
        {
            // Compute normals in case the meshes have them
            D3DXComputeNormals( m_pMesh, NULL );
        }

        if( bHaveNormalNow && !bHadTangent && bHaveTangentNow && bAutoComputeTangents )
        {
            ID3DXMesh* pNewMesh;
            HRESULT hr;

            DWORD *rgdwAdjacency = NULL;
            rgdwAdjacency = new DWORD[m_pMesh->GetNumFaces() * 3];
            if( rgdwAdjacency == NULL )
                return E_OUTOFMEMORY;
            V( m_pMesh->GenerateAdjacency(1e-6f,rgdwAdjacency) );

            float fPartialEdgeThreshold;
            float fSingularPointThreshold;
            float fNormalEdgeThreshold;
            if( bSplitVertexForOptimalTangents )
            {
                fPartialEdgeThreshold = 0.01f;
                fSingularPointThreshold = 0.25f;
                fNormalEdgeThreshold = 0.01f;
            }
            else
            {
                fPartialEdgeThreshold = -1.01f;
                fSingularPointThreshold = 0.01f;
                fNormalEdgeThreshold = -1.01f;
            }

            // Compute tangents, which are required for normal mapping
            hr = D3DXComputeTangentFrameEx( m_pMesh, 
                                            D3DDECLUSAGE_TEXCOORD, 0, 
                                            D3DDECLUSAGE_TANGENT, 0,
                                            D3DX_DEFAULT, 0, 
                                            D3DDECLUSAGE_NORMAL, 0,
                                            0, rgdwAdjacency, 
                                            fPartialEdgeThreshold, fSingularPointThreshold, fNormalEdgeThreshold, 
                                            &pNewMesh, NULL );

            SAFE_DELETE_ARRAY( rgdwAdjacency );
            if( FAILED(hr) )
                return hr;

            SAFE_RELEASE( m_pMesh );
            m_pMesh = pNewMesh;
        }
    }

    return S_OK;
}




//-----------------------------------------------------------------------------
HRESULT CDXUTMesh::RestoreDeviceObjects( LPDIRECT3DDEVICE9 pd3dDevice )
{
    return S_OK;
}




//-----------------------------------------------------------------------------
HRESULT CDXUTMesh::InvalidateDeviceObjects()
{
    SAFE_RELEASE( m_pIB );
    SAFE_RELEASE( m_pVB );
    SAFE_RELEASE( m_pDecl );

    return S_OK;
}




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




//-----------------------------------------------------------------------------
HRESULT CDXUTMesh::Render( LPDIRECT3DDEVICE9 pd3dDevice, bool bDrawOpaqueSubsets,
                          bool bDrawAlphaSubsets )
{
    if( NULL == m_pMesh )
        return E_FAIL;

    // Frist, draw the subsets without alpha
    if( bDrawOpaqueSubsets )
    {
        for( DWORD i=0; i<m_dwNumMaterials; i++ )
        {
            if( m_bUseMaterials )
            {
                if( m_pMaterials[i].Diffuse.a < 1.0f )
                    continue;
                pd3dDevice->SetMaterial( &m_pMaterials[i] );
                pd3dDevice->SetTexture( 0, m_pTextures[i] );
            }
            m_pMesh->DrawSubset( i );
        }
    }

    // Then, draw the subsets with alpha
    if( bDrawAlphaSubsets && m_bUseMaterials )
    {
        for( DWORD i=0; i<m_dwNumMaterials; i++ )
        {
            if( m_pMaterials[i].Diffuse.a == 1.0f )
                continue;

            // Set the material and texture
            pd3dDevice->SetMaterial( &m_pMaterials[i] );
            pd3dDevice->SetTexture( 0, m_pTextures[i] );
            m_pMesh->DrawSubset( i );
        }
    }

    return S_OK;
}




//-----------------------------------------------------------------------------
HRESULT CDXUTMesh::Render( ID3DXEffect *pEffect,
                           D3DXHANDLE hTexture,
                           D3DXHANDLE hDiffuse,
                           D3DXHANDLE hAmbient,
                           D3DXHANDLE hSpecular,
                           D3DXHANDLE hEmissive,
                           D3DXHANDLE hPower,
                           bool bDrawOpaqueSubsets,
                           bool bDrawAlphaSubsets )
{
    if( NULL == m_pMesh )
        return E_FAIL;

    UINT cPasses;
    // Frist, draw the subsets without alpha
    if( bDrawOpaqueSubsets )
    {
        pEffect->Begin( &cPasses, 0 );
        for( UINT p = 0; p < cPasses; ++p )
        {
            pEffect->BeginPass( p );
            for( DWORD i=0; i<m_dwNumMaterials; i++ )
            {
                if( m_bUseMaterials )
                {
                    if( m_pMaterials[i].Diffuse.a < 1.0f )
                        continue;
                    if( hTexture )
                        pEffect->SetTexture( hTexture, m_pTextures[i] );
                    // D3DCOLORVALUE and D3DXVECTOR4 are data-wise identical.
                    // No conversion is needed.
                    if( hDiffuse )
                        pEffect->SetVector( hDiffuse, (D3DXVECTOR4*)&m_pMaterials[i].Diffuse );
                    if( hAmbient )
                        pEffect->SetVector( hAmbient, (D3DXVECTOR4*)&m_pMaterials[i].Ambient );
                    if( hSpecular )
                        pEffect->SetVector( hSpecular, (D3DXVECTOR4*)&m_pMaterials[i].Specular );
                    if( hEmissive )
                        pEffect->SetVector( hEmissive, (D3DXVECTOR4*)&m_pMaterials[i].Emissive );
                    if( hPower )
                        pEffect->SetFloat( hPower, m_pMaterials[i].Power );
                    pEffect->CommitChanges();
                }
                m_pMesh->DrawSubset( i );
            }
            pEffect->EndPass();
        }
        pEffect->End();
    }

    // Then, draw the subsets with alpha
    if( bDrawAlphaSubsets && m_bUseMaterials )
    {
        pEffect->Begin( &cPasses, 0 );
        for( UINT p = 0; p < cPasses; ++p )
        {
            pEffect->BeginPass( p );
            for( DWORD i=0; i<m_dwNumMaterials; i++ )
            {
                if( m_bUseMaterials )
                {
                    if( m_pMaterials[i].Diffuse.a == 1.0f )
                        continue;
                    if( hTexture )
                        pEffect->SetTexture( hTexture, m_pTextures[i] );
                    // D3DCOLORVALUE and D3DXVECTOR4 are data-wise identical.
                    // No conversion is needed.
                    if( hDiffuse )
                        pEffect->SetVector( hDiffuse, (D3DXVECTOR4*)&m_pMaterials[i].Diffuse );
                    if( hAmbient )
                        pEffect->SetVector( hAmbient, (D3DXVECTOR4*)&m_pMaterials[i].Ambient );
                    if( hSpecular )
                        pEffect->SetVector( hSpecular, (D3DXVECTOR4*)&m_pMaterials[i].Specular );
                    if( hEmissive )
                        pEffect->SetVector( hEmissive, (D3DXVECTOR4*)&m_pMaterials[i].Emissive );
                    if( hPower )
                        pEffect->SetFloat( hPower, m_pMaterials[i].Power );
                    pEffect->CommitChanges();
                }
                m_pMesh->DrawSubset( i );
            }
            pEffect->EndPass();
        }
        pEffect->End();
    }

    return S_OK;
}




//-----------------------------------------------------------------------------
CDXUTMeshFrame::CDXUTMeshFrame( LPCWSTR strName )
{
    StringCchCopy( m_strName, 512, strName );
    D3DXMatrixIdentity( &m_mat );
    m_pMesh  = NULL;

    m_pChild = NULL;
    m_pNext  = NULL;
}




//-----------------------------------------------------------------------------
CDXUTMeshFrame::~CDXUTMeshFrame()
{
    SAFE_DELETE( m_pChild );
    SAFE_DELETE( m_pNext );
}




//-----------------------------------------------------------------------------
bool CDXUTMeshFrame::EnumMeshes( bool (*EnumMeshCB)(CDXUTMesh*,void*),
                            void* pContext )
{
    if( m_pMesh )
        EnumMeshCB( m_pMesh, pContext );
    if( m_pChild )
        m_pChild->EnumMeshes( EnumMeshCB, pContext );
    if( m_pNext )
        m_pNext->EnumMeshes( EnumMeshCB, pContext );

    return TRUE;
}




//-----------------------------------------------------------------------------
CDXUTMesh* CDXUTMeshFrame::FindMesh( LPCWSTR strMeshName )
{
    CDXUTMesh* pMesh;

    if( m_pMesh )
        if( !lstrcmpi( m_pMesh->m_strName, strMeshName ) )
            return m_pMesh;

    if( m_pChild )
        if( NULL != ( pMesh = m_pChild->FindMesh( strMeshName ) ) )
            return pMesh;

    if( m_pNext )
        if( NULL != ( pMesh = m_pNext->FindMesh( strMeshName ) ) )
            return pMesh;

    return NULL;
}




//-----------------------------------------------------------------------------
CDXUTMeshFrame* CDXUTMeshFrame::FindFrame( LPCWSTR strFrameName )
{
    CDXUTMeshFrame* pFrame;

    if( !lstrcmpi( m_strName, strFrameName ) )
        return this;

    if( m_pChild )
        if( NULL != ( pFrame = m_pChild->FindFrame( strFrameName ) ) )
            return pFrame;

    if( m_pNext )
        if( NULL != ( pFrame = m_pNext->FindFrame( strFrameName ) ) )
            return pFrame;

    return NULL;
}




//-----------------------------------------------------------------------------
HRESULT CDXUTMeshFrame::Destroy()
{

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩成人精品在线观看| 免费在线看一区| 久久久久久久综合色一本| 在线成人小视频| 91精品国产高清一区二区三区蜜臀| 在线观看亚洲a| 欧美日韩中文另类| 91超碰这里只有精品国产| 欧美日韩国产乱码电影| 69久久99精品久久久久婷婷| 91精品国产免费久久综合| 精品国产乱码久久久久久久久| 欧美tk—视频vk| 日本一区二区不卡视频| 亚洲丝袜制服诱惑| 亚洲一区视频在线观看视频| 丝瓜av网站精品一区二区| 另类中文字幕网| 成人毛片在线观看| 色婷婷综合视频在线观看| 欧美精品久久久久久久多人混战 | 麻豆精品在线看| 国内精品视频666| 99久久免费精品高清特色大片| 欧美性色欧美a在线播放| 日韩欧美亚洲国产精品字幕久久久| 久久亚洲精品国产精品紫薇| 欧美韩国日本一区| 亚洲成av人片| 成人精品视频.| 欧美日韩成人在线一区| 欧美经典一区二区| 亚洲成人激情自拍| 国产91精品欧美| 欧美疯狂性受xxxxx喷水图片| 久久久三级国产网站| 亚洲一区在线观看免费 | 日韩欧美国产一区在线观看| 欧美激情综合五月色丁香小说| 亚洲图片欧美一区| 国产99久久精品| 日韩区在线观看| 亚洲视频在线观看一区| 国产精一品亚洲二区在线视频| 色综合久久99| 国产精品麻豆久久久| 男女男精品视频网| 欧美在线观看视频一区二区| 国产精品你懂的在线| 黄一区二区三区| 欧美日韩国产高清一区二区 | 欧美日韩在线精品一区二区三区激情| 欧美va亚洲va香蕉在线| 丝袜美腿亚洲一区| 在线亚洲免费视频| 亚洲日本在线天堂| 成人永久aaa| 国产欧美日韩激情| 国产精品综合av一区二区国产馆| 91精品啪在线观看国产60岁| 亚洲男人天堂av网| www.激情成人| 国产精品大尺度| 大尺度一区二区| 日本一区二区综合亚洲| 国产精品一区二区三区网站| 欧美精品乱人伦久久久久久| 午夜视频在线观看一区| 在线观看日韩毛片| 亚洲一区二区三区爽爽爽爽爽| 色老头久久综合| 亚洲一区二区三区中文字幕在线| 色噜噜狠狠色综合中国| 亚洲国产视频网站| 在线播放中文一区| 美女视频一区二区三区| 日韩欧美国产不卡| 国产精品一区二区你懂的| 国产视频一区在线播放| 国产精品夜夜爽| 国产精品不卡在线| 日本韩国欧美一区二区三区| 亚洲va国产va欧美va观看| 欧美日韩和欧美的一区二区| 手机精品视频在线观看| 欧美一级二级三级乱码| 国产精品自拍一区| 亚洲日本丝袜连裤袜办公室| 色老汉一区二区三区| 日韩精品亚洲专区| 日韩一级黄色大片| 成人蜜臀av电影| 亚洲国产日韩精品| 日韩一级在线观看| 国产iv一区二区三区| 亚洲精品大片www| 日韩欧美成人一区二区| 国产黄色精品网站| 一区二区三区在线视频免费观看| 欧美日韩高清一区| 国产传媒久久文化传媒| 亚洲专区一二三| xnxx国产精品| 色拍拍在线精品视频8848| 五月天激情综合| 国产亚洲美州欧州综合国| 色噜噜狠狠色综合中国| 精品制服美女丁香| 18成人在线视频| 日韩欧美激情在线| 色天天综合久久久久综合片| 激情小说亚洲一区| 亚洲一区自拍偷拍| 国产精品―色哟哟| 日韩欧美国产精品| 在线观看视频一区二区| 国产成人精品一区二区三区四区 | 亚洲精品国久久99热| 日韩欧美三级在线| 在线观看日韩电影| 丰满岳乱妇一区二区三区| 天堂一区二区在线免费观看| 国产精品久久久久久久久免费桃花 | 免费日本视频一区| 亚洲日本电影在线| 2024国产精品| 6080日韩午夜伦伦午夜伦| 91女人视频在线观看| 韩国成人在线视频| 偷拍与自拍一区| 亚洲免费毛片网站| 中文字幕二三区不卡| 欧美大片在线观看一区二区| 欧美无乱码久久久免费午夜一区 | 天天色综合成人网| 亚洲亚洲人成综合网络| 亚洲人成精品久久久久| 日本一区二区三区在线观看| 精品久久久久一区| 精品欧美乱码久久久久久 | 久久久久久久综合狠狠综合| 777xxx欧美| 欧美精品在线视频| 777色狠狠一区二区三区| 在线日韩av片| 色综合天天综合在线视频| 高清国产一区二区| 成人永久看片免费视频天堂| 国产剧情一区二区三区| 国产精品亚洲一区二区三区妖精| 麻豆91精品视频| 麻豆传媒一区二区三区| 经典三级视频一区| 国产麻豆精品在线观看| 国产一区二区三区香蕉| 高清不卡一区二区| 99久久久久免费精品国产| 色综合久久中文字幕综合网| 色婷婷综合久久久久中文一区二区| 色欧美片视频在线观看在线视频| 色乱码一区二区三区88| 欧美日韩色一区| 日韩一区二区三区在线| 久久综合久色欧美综合狠狠| 中文一区二区完整视频在线观看| 欧美国产一区视频在线观看| 亚洲人妖av一区二区| 洋洋成人永久网站入口| 日韩影院在线观看| 国产一区视频在线看| 暴力调教一区二区三区| 欧美在线短视频| 欧美tickling网站挠脚心| 国产欧美精品一区二区色综合| 中文字幕亚洲成人| 日韩制服丝袜先锋影音| 国产一区二区伦理片| 色综合久久中文综合久久97| 欧美一区二区三区小说| 国产亚洲综合av| 夜夜嗨av一区二区三区四季av | 亚洲成人资源在线| 韩国成人精品a∨在线观看| 99久久久久久99| 精品久久久久香蕉网| 亚洲欧美国产77777| 日韩中文字幕区一区有砖一区| 国产精品亚洲视频| 欧美日韩一区二区三区视频| 精品99一区二区三区| 亚洲欧美日韩成人高清在线一区| 日本欧美一区二区在线观看| 99久久精品国产麻豆演员表| 91麻豆精品国产91久久久| 国产精品免费久久| 久草中文综合在线| 欧美性videosxxxxx| 国产精品久久久久影院色老大 | 天堂午夜影视日韩欧美一区二区| 成人午夜伦理影院|