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

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

?? dxutil.cpp

?? Introduction to directx9 3d game programming 一書的源代碼
?? CPP
?? 第 1 頁 / 共 3 頁
字號:

    if( !bFound )
    {
        // Search in "%EXE_DIR%\"
        _tcscpy( strReadmePath, strExePath );
        lstrcat( strReadmePath, TEXT("\\readme.txt") );
        if( GetFileAttributes( strReadmePath ) != 0xFFFFFFFF )
            bFound = TRUE;
    }

    if( !bFound )
    {
        // Search in "%EXE_DIR%\.."
        _tcscpy( strReadmePath, strExePath );
        strLastSlash = _tcsrchr( strReadmePath, TEXT('\\') );
        if( strLastSlash )
            *strLastSlash = 0;
        lstrcat( strReadmePath, TEXT("\\readme.txt") );
        if( GetFileAttributes( strReadmePath ) != 0xFFFFFFFF )
            bFound = TRUE;
    }

    if( !bFound )
    {
        // Search in "%EXE_DIR%\..\.."
        _tcscpy( strReadmePath, strExePath );
        strLastSlash = _tcsrchr( strReadmePath, TEXT('\\') );
        if( strLastSlash )
            *strLastSlash = 0;
        strLastSlash = _tcsrchr( strReadmePath, TEXT('\\') );
        if( strLastSlash )
            *strLastSlash = 0;
        lstrcat( strReadmePath, TEXT("\\readme.txt") );
        if( GetFileAttributes( strReadmePath ) != 0xFFFFFFFF )
            bFound = TRUE;
    }

    if( bFound )
    {
        // GetProcAddress for ShellExecute, so we don't have to include shell32.lib 
        // in every project that uses dxutil.cpp
        LPShellExecute pShellExecute = NULL;
        HINSTANCE hInstShell32 = LoadLibrary(TEXT("shell32.dll"));
        if (hInstShell32 != NULL)
        {
#ifdef UNICODE
            pShellExecute = (LPShellExecute)GetProcAddress(hInstShell32, _TWINCE("ShellExecuteW"));
#else
            pShellExecute = (LPShellExecute)GetProcAddress(hInstShell32, _TWINCE("ShellExecuteA"));
#endif
            if( pShellExecute != NULL )
            {
                if( pShellExecute( hWnd, TEXT("open"), strReadmePath, NULL, NULL, SW_SHOW ) > (HINSTANCE) 32 )
                    bSuccess = true;
            }

            FreeLibrary(hInstShell32);
        }
    }

    if( !bSuccess )
    {
        // Tell the user that the readme couldn't be opened
        MessageBox( hWnd, TEXT("Could not find readme.txt"), 
                    TEXT("DirectX SDK Sample"), MB_ICONWARNING | MB_OK );
    }
}
#endif // !UNDER_CE




//-----------------------------------------------------------------------------
// Name: _DbgOut()
// Desc: Outputs a message to the debug stream
//-----------------------------------------------------------------------------
HRESULT _DbgOut( TCHAR* strFile, DWORD dwLine, HRESULT hr, TCHAR* strMsg )
{
    TCHAR buffer[256];
    _sntprintf( buffer, 256, _T("%s(%ld): "), strFile, dwLine );
    buffer[255] = 0;    
    OutputDebugString( buffer );
    OutputDebugString( strMsg );

    if( hr )
    {
        wsprintf( buffer, _T("(hr=%08lx)\n"), hr );
        OutputDebugString( buffer );
    }

    OutputDebugString( _T("\n") );

    return hr;
}




//-----------------------------------------------------------------------------
// Name: DXUtil_Trace()
// Desc: Outputs to the debug stream a formatted string with a variable-
//       argument list.
//-----------------------------------------------------------------------------
VOID DXUtil_Trace( TCHAR* strMsg, ... )
{
#if defined(DEBUG) | defined(_DEBUG)
    TCHAR strBuffer[512];
    
    va_list args;
    va_start(args, strMsg);
    _vsntprintf( strBuffer, 512, strMsg, args );
    va_end(args);

    OutputDebugString( strBuffer );
#else
    UNREFERENCED_PARAMETER(strMsg);
#endif
}




//-----------------------------------------------------------------------------
// Name: DXUtil_ConvertStringToGUID()
// Desc: Converts a string to a GUID
//-----------------------------------------------------------------------------
HRESULT DXUtil_ConvertStringToGUID( const TCHAR* strSrc, GUID* pGuidDest )
{
    UINT aiTmp[10];

    if( _stscanf( strSrc, TEXT("{%8X-%4X-%4X-%2X%2X-%2X%2X%2X%2X%2X%2X}"),
                    &pGuidDest->Data1, 
                    &aiTmp[0], &aiTmp[1], 
                    &aiTmp[2], &aiTmp[3],
                    &aiTmp[4], &aiTmp[5],
                    &aiTmp[6], &aiTmp[7],
                    &aiTmp[8], &aiTmp[9] ) != 11 )
    {
        ZeroMemory( pGuidDest, sizeof(GUID) );
        return E_FAIL;
    }
    else
    {
        pGuidDest->Data2       = (USHORT) aiTmp[0];
        pGuidDest->Data3       = (USHORT) aiTmp[1];
        pGuidDest->Data4[0]    = (BYTE) aiTmp[2];
        pGuidDest->Data4[1]    = (BYTE) aiTmp[3];
        pGuidDest->Data4[2]    = (BYTE) aiTmp[4];
        pGuidDest->Data4[3]    = (BYTE) aiTmp[5];
        pGuidDest->Data4[4]    = (BYTE) aiTmp[6];
        pGuidDest->Data4[5]    = (BYTE) aiTmp[7];
        pGuidDest->Data4[6]    = (BYTE) aiTmp[8];
        pGuidDest->Data4[7]    = (BYTE) aiTmp[9];
        return S_OK;
    }
}




//-----------------------------------------------------------------------------
// Name: DXUtil_ConvertGUIDToStringCch()
// Desc: Converts a GUID to a string 
//       cchDestChar is the size in TCHARs of strDest.  Be careful not to 
//       pass in sizeof(strDest) on UNICODE builds
//-----------------------------------------------------------------------------
HRESULT DXUtil_ConvertGUIDToStringCch( const GUID* pGuidSrc, TCHAR* strDest, int cchDestChar )
{
    int nResult = _sntprintf( strDest, cchDestChar, TEXT("{%0.8X-%0.4X-%0.4X-%0.2X%0.2X-%0.2X%0.2X%0.2X%0.2X%0.2X%0.2X}"),
               pGuidSrc->Data1, pGuidSrc->Data2, pGuidSrc->Data3,
               pGuidSrc->Data4[0], pGuidSrc->Data4[1],
               pGuidSrc->Data4[2], pGuidSrc->Data4[3],
               pGuidSrc->Data4[4], pGuidSrc->Data4[5],
               pGuidSrc->Data4[6], pGuidSrc->Data4[7] );

    if( nResult < 0 )
        return E_FAIL;
    return S_OK;
}




//-----------------------------------------------------------------------------
// Name: CArrayList constructor
// Desc: 
//-----------------------------------------------------------------------------
CArrayList::CArrayList( ArrayListType Type, UINT BytesPerEntry )
{
    if( Type == AL_REFERENCE )
        BytesPerEntry = sizeof(void*);
    m_ArrayListType = Type;
    m_pData = NULL;
    m_BytesPerEntry = BytesPerEntry;
    m_NumEntries = 0;
    m_NumEntriesAllocated = 0;
}



//-----------------------------------------------------------------------------
// Name: CArrayList destructor
// Desc: 
//-----------------------------------------------------------------------------
CArrayList::~CArrayList( void )
{
    if( m_pData != NULL )
        delete[] m_pData;
}




//-----------------------------------------------------------------------------
// Name: CArrayList::Add
// Desc: Adds pEntry to the list.
//-----------------------------------------------------------------------------
HRESULT CArrayList::Add( void* pEntry )
{
    if( m_BytesPerEntry == 0 )
        return E_FAIL;
    if( m_pData == NULL || m_NumEntries + 1 > m_NumEntriesAllocated )
    {
        void* pDataNew;
        UINT NumEntriesAllocatedNew;
        if( m_NumEntriesAllocated == 0 )
            NumEntriesAllocatedNew = 16;
        else
            NumEntriesAllocatedNew = m_NumEntriesAllocated * 2;
        pDataNew = new BYTE[NumEntriesAllocatedNew * m_BytesPerEntry];
        if( pDataNew == NULL )
            return E_OUTOFMEMORY;
        if( m_pData != NULL )
        {
            CopyMemory( pDataNew, m_pData, m_NumEntries * m_BytesPerEntry );
            delete[] m_pData;
        }
        m_pData = pDataNew;
        m_NumEntriesAllocated = NumEntriesAllocatedNew;
    }

    if( m_ArrayListType == AL_VALUE )
        CopyMemory( (BYTE*)m_pData + (m_NumEntries * m_BytesPerEntry), pEntry, m_BytesPerEntry );
    else
        *(((void**)m_pData) + m_NumEntries) = pEntry;
    m_NumEntries++;

    return S_OK;
}




//-----------------------------------------------------------------------------
// Name: CArrayList::GetPtr
// Desc: Returns a pointer to the Entry'th entry in the list.
//-----------------------------------------------------------------------------
void* CArrayList::GetPtr( UINT Entry )
{
    if( m_ArrayListType == AL_VALUE )
        return (BYTE*)m_pData + (Entry * m_BytesPerEntry);
    else
        return *(((void**)m_pData) + Entry);
}




//-----------------------------------------------------------------------------
// Name: CArrayList::Contains
// Desc: Returns whether the list contains an entry identical to the 
//       specified entry data.
//-----------------------------------------------------------------------------
bool CArrayList::Contains( void* pEntryData )
{
    for( UINT iEntry = 0; iEntry < m_NumEntries; iEntry++ )
    {
        if( m_ArrayListType == AL_VALUE )
        {
            if( memcmp( GetPtr(iEntry), pEntryData, m_BytesPerEntry ) == 0 )
                return true;
        }
        else
        {
            if( GetPtr(iEntry) == pEntryData )
                return true;
        }
    }
    return false;
}




//-----------------------------------------------------------------------------
// Name: BYTE helper functions
// Desc: cchDestChar is the size in BYTEs of strDest.  Be careful not to 
//       pass use sizeof() if the strDest is a string pointer.  
//       eg.
//       TCHAR* sz = new TCHAR[100]; // sizeof(sz)  == 4
//       TCHAR sz2[100];             // sizeof(sz2) == 200
//-----------------------------------------------------------------------------
HRESULT DXUtil_ConvertAnsiStringToWideCb( WCHAR* wstrDestination, const CHAR* strSource, int cbDestChar )
{
    return DXUtil_ConvertAnsiStringToWideCch( wstrDestination, strSource, cbDestChar / sizeof(WCHAR) );
}

HRESULT DXUtil_ConvertWideStringToAnsiCb( CHAR* strDestination, const WCHAR* wstrSource, int cbDestChar )
{
    return DXUtil_ConvertWideStringToAnsiCch( strDestination, wstrSource, cbDestChar / sizeof(CHAR) );
}

HRESULT DXUtil_ConvertGenericStringToAnsiCb( CHAR* strDestination, const TCHAR* tstrSource, int cbDestChar )
{
    return DXUtil_ConvertGenericStringToAnsiCch( strDestination, tstrSource, cbDestChar / sizeof(CHAR) );
}

HRESULT DXUtil_ConvertGenericStringToWideCb( WCHAR* wstrDestination, const TCHAR* tstrSource, int cbDestChar )
{
    return DXUtil_ConvertGenericStringToWideCch( wstrDestination, tstrSource, cbDestChar / sizeof(WCHAR) );
}

HRESULT DXUtil_ConvertAnsiStringToGenericCb( TCHAR* tstrDestination, const CHAR* strSource, int cbDestChar )
{
    return DXUtil_ConvertAnsiStringToGenericCch( tstrDestination, strSource, cbDestChar / sizeof(TCHAR) );
}

HRESULT DXUtil_ConvertWideStringToGenericCb( TCHAR* tstrDestination, const WCHAR* wstrSource, int cbDestChar )
{
    return DXUtil_ConvertWideStringToGenericCch( tstrDestination, wstrSource, cbDestChar / sizeof(TCHAR) );
}

HRESULT DXUtil_ReadStringRegKeyCb( HKEY hKey, TCHAR* strRegName, TCHAR* strDest, DWORD cbDest, TCHAR* strDefault )
{
    return DXUtil_ReadStringRegKeyCch( hKey, strRegName, strDest, cbDest / sizeof(TCHAR), strDefault );
}

HRESULT DXUtil_ConvertGUIDToStringCb( const GUID* pGuidSrc, TCHAR* strDest, int cbDestChar )
{
    return DXUtil_ConvertGUIDToStringCch( pGuidSrc, strDest, cbDestChar / sizeof(TCHAR) );
}

#ifndef UNDER_CE
HRESULT DXUtil_GetDXSDKMediaPathCb( TCHAR* szDest, int cbDest )
{
    return DXUtil_GetDXSDKMediaPathCch( szDest, cbDest / sizeof(TCHAR) );
}

HRESULT DXUtil_FindMediaFileCb( TCHAR* szDestPath, int cbDest, TCHAR* strFilename )
{
    return DXUtil_FindMediaFileCch( szDestPath, cbDest / sizeof(TCHAR), strFilename );
}
#endif // !UNDER_CE

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本大香伊一区二区三区| 国产日韩欧美电影| 国产日韩精品一区二区三区 | 成人福利电影精品一区二区在线观看| 在线视频你懂得一区| 欧美精品一区二区三区很污很色的 | 91在线你懂得| 久久只精品国产| 日韩和欧美的一区| 99久久久久免费精品国产| 欧美大尺度电影在线| 亚洲超碰97人人做人人爱| 成人18精品视频| 久久久99免费| 国产精品一区二区在线观看不卡| 欧美日韩免费观看一区三区| 亚洲欧美一区二区在线观看| 国产传媒久久文化传媒| 精品欧美一区二区三区精品久久| 亚洲国产视频一区| 色综合久久久久综合体| 国产精品乱子久久久久| 国产精品538一区二区在线| 日韩精品一区二区三区在线播放 | 久久精品国产99国产精品| 欧美猛男男办公室激情| 一区二区三区精品在线观看| 91在线免费视频观看| 亚洲欧美在线另类| 色婷婷综合久久久久中文一区二区| 国产精品美女久久久久av爽李琼| 国产精品一区二区视频| 国产亚洲精品aa午夜观看| 国产揄拍国内精品对白| 国产亚洲精品aa| 成人小视频在线| 中文字幕亚洲成人| 成人污污视频在线观看| 国产精品久久久久毛片软件| eeuss鲁片一区二区三区在线看| 中文字幕精品综合| 99麻豆久久久国产精品免费优播| 亚洲色图欧美激情| 欧美色老头old∨ideo| 日本va欧美va瓶| 26uuu国产一区二区三区| 国产一区二三区好的| 国产欧美精品一区aⅴ影院| 不卡的电视剧免费网站有什么| 亚洲女与黑人做爰| 8x福利精品第一导航| 精品一区二区免费在线观看| 久久久综合视频| 91视频国产观看| 日韩国产精品大片| 国产亚洲制服色| 91视频免费播放| 蜜臀av一区二区| 亚洲欧洲精品天堂一级| 777色狠狠一区二区三区| 国产一区二区三区在线观看精品| 中文字幕一区av| 日韩亚洲欧美成人一区| 国产高清精品久久久久| 亚洲男女一区二区三区| 91麻豆精品国产91久久久资源速度| 国产精品亚洲综合一区在线观看| 亚洲欧美激情在线| 精品国产免费一区二区三区四区 | 手机精品视频在线观看| 久久日一线二线三线suv| 色综合激情五月| 精品一区二区三区免费| 一区二区三区精品视频| 久久久久亚洲综合| 欧美丰满嫩嫩电影| 成人aa视频在线观看| 久久99精品久久久久久国产越南| 最新不卡av在线| 精品奇米国产一区二区三区| 91国产成人在线| 成人免费高清视频在线观看| 日本不卡一二三| 一级精品视频在线观看宜春院 | 欧美精品一区二区三| 欧美日韩在线电影| aaa欧美日韩| 狠狠色综合日日| 日本vs亚洲vs韩国一区三区 | 国产精品污网站| 26uuu亚洲| 91精品婷婷国产综合久久性色| 成人av在线资源网| 国产乱码精品一品二品| 日韩电影在线观看一区| 亚洲综合清纯丝袜自拍| 中文字幕一区二区日韩精品绯色| 久久一日本道色综合| 日韩一卡二卡三卡国产欧美| 欧美日韩一区二区三区免费看| 97超碰欧美中文字幕| 国产精品综合视频| 免费观看日韩av| 日韩精品一级二级| 亚洲第一福利视频在线| 亚洲高清不卡在线| 亚洲一二三专区| 亚洲一区免费观看| 午夜精品久久久久影视| 一区二区三区中文在线观看| 综合在线观看色| 亚洲欧美另类小说| 亚洲宅男天堂在线观看无病毒| 亚洲精品欧美在线| 亚洲综合精品自拍| 亚洲一二三四区不卡| 爽爽淫人综合网网站| 美日韩一级片在线观看| 久久成人18免费观看| 国产精品影音先锋| 国产不卡视频在线播放| 国产成人精品亚洲777人妖| 成人精品gif动图一区| 成人高清视频在线| 97久久人人超碰| 欧美午夜一区二区三区 | 日本特黄久久久高潮| 精久久久久久久久久久| 国产在线精品一区在线观看麻豆| 国产一区美女在线| 91在线视频观看| 欧美三区在线视频| 欧美一区二区在线免费观看| 亚洲精品一区二区三区影院| 欧美国产综合一区二区| 最近中文字幕一区二区三区| 亚洲chinese男男1069| 欧美aⅴ一区二区三区视频| 国产夫妻精品视频| 91精彩视频在线观看| 日韩三级免费观看| 国产精品久久久久久亚洲毛片 | 成人国产一区二区三区精品| 欧美系列一区二区| 久久综合久久综合亚洲| 综合久久久久久久| 麻豆91免费看| 色综合激情五月| 精品国产一区二区三区四区四 | 亚洲女同ⅹxx女同tv| 美女网站色91| 97久久人人超碰| 欧美一区二区视频在线观看| 国产日产亚洲精品系列| 亚洲大片在线观看| 成人永久aaa| 91精品国产91综合久久蜜臀| 国产精品毛片a∨一区二区三区| 五月激情综合婷婷| av男人天堂一区| 精品日韩欧美在线| 亚洲妇女屁股眼交7| 懂色一区二区三区免费观看| 91精品国产福利| 亚洲综合色视频| 成人一区在线观看| 精品精品国产高清a毛片牛牛| 亚洲欧美日韩中文播放| 国产九色精品成人porny| 欧美日韩国产免费| 亚洲欧美国产高清| 成人丝袜视频网| 久久久久国产一区二区三区四区 | 成人国产精品免费网站| 精品福利在线导航| 视频精品一区二区| 在线观看日韩毛片| 国产精品久久久久天堂| 国产精品1区2区3区| 日韩三级视频在线观看| 日韩专区在线视频| 欧美性大战久久久| 亚洲免费观看高清完整版在线观看熊 | 久草精品在线观看| 欧美一区二区三区视频免费播放| 亚洲精品国产成人久久av盗摄| 国产成人av在线影院| 2020国产精品久久精品美国| 免费成人在线观看| 欧美丰满高潮xxxx喷水动漫| 亚洲成a人片在线不卡一二三区| 91久久精品日日躁夜夜躁欧美| 成人免费在线播放视频| 99久久精品国产麻豆演员表| 中文字幕av资源一区| 成人高清伦理免费影院在线观看| 中文无字幕一区二区三区| 丁香一区二区三区| 国产精品你懂的在线| 波多野结衣在线一区|