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

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

?? input.cpp

?? 6410BSP3
?? CPP
字號:
//
// Copyright (c) Microsoft Corporation.  All rights reserved.
//
//
// Use of this source code is subject to the terms of the Microsoft end-user
// license agreement (EULA) under which you licensed this SOFTWARE PRODUCT.
// If you did not accept the terms of the EULA, you are not authorized to use
// this source code. For a copy of the EULA, please see the LICENSE.RTF on your
// install media.
//
// -----------------------------------------------------------------------------
//
//      THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF
//      ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO
//      THE IMPLIED WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A
//      PARTICULAR PURPOSE.
//
// -----------------------------------------------------------------------------

#include "wavemain.h"

// Init input m_DeltaT with (HWSampleRate/SampleRate) calculated in 24.8 fixed point form
// Note that we need to hold the result in a 64-bit value until we're done shifting,
// since the result of the multiply will overflow 32 bits for sample rates greater than
// or equal to the hardware's sample rate.
DWORD InputStreamContext::SetRate(DWORD dwMultiplier)
{
    m_dwMultiplier = dwMultiplier;

    UINT64 Delta = (m_WaveFormat.nSamplesPerSec * m_dwMultiplier) >> 16;
    Delta = ((UINT32)(((1i64<<32)/Delta)+1));
    Delta = (Delta * SAMPLERATE) >> 24;
    m_DeltaT = (DWORD)Delta;
    return MMSYSERR_NOERROR;
}


DWORD InputStreamContext::Stop()
{
    // Stop the stream
    WaveStreamContext::Stop();

    // Return any partially filled buffers to the client
    if ((m_lpWaveHdrCurrent) && (m_lpWaveHdrCurrent->dwBytesRecorded>0))
    {
        GetNextBuffer();
    }

    return MMSYSERR_NOERROR;
}


//#if (OUTCHANNELS==2)
#if (INCHANNELS==2)
PBYTE InputStreamContext::Render2(PBYTE pBuffer, PBYTE pBufferEnd, PBYTE pBufferLast)
{
    PBYTE pCurrData = m_lpCurrData;
    PBYTE pCurrDataEnd = m_lpCurrDataEnd;
    LONG fxpGain = m_fxpGain;

    LONG CurrT = m_CurrT;
    LONG DeltaT = m_DeltaT;
    PCM_TYPE SampleType = m_SampleType;

    LONG CurrSamp0 = m_CurrSamp[0];
    LONG PrevSamp0 = m_PrevSamp[0];
    LONG CurrSamp1 = m_CurrSamp[1];
    LONG PrevSamp1 = m_PrevSamp[1];
    LONG InSamp0;
    LONG InSamp1;

    for (;;)
    {
        // Make sure we have a place to put the data
        if (pCurrData>=pCurrDataEnd)
        {
            goto Exit;
        }

        // Get the next sample
        while (CurrT >= 0x100)
        {
            if (pBuffer>=pBufferEnd)
            {
                goto Exit;
            }

            PrevSamp0 = CurrSamp0;
            PrevSamp1 = CurrSamp1;

            CurrSamp0 = ((HWSAMPLE *)pBuffer)[0];
            CurrSamp1 = ((HWSAMPLE *)pBuffer)[1];
            pBuffer += 2*sizeof(HWSAMPLE);

            // Apply input gain
            CurrSamp0 = (CurrSamp0 * fxpGain) >> 16;
            CurrSamp1 = (CurrSamp1 * fxpGain) >> 16;

            CurrT -= 0x100;
        }

        InSamp0 = (PrevSamp0 + ((CurrT * (CurrSamp0 - PrevSamp0)) >> 8));
        InSamp1 = (PrevSamp1 + ((CurrT * (CurrSamp1 - PrevSamp1)) >> 8));
        CurrT += DeltaT;

        PPCM_SAMPLE pSampleDest = (PPCM_SAMPLE)pCurrData;
        switch (m_SampleType)
        {
        case PCM_TYPE_M8:
        default:
            pSampleDest->m8.sample = (UINT8)( ((InSamp0+InSamp1) >> 9) + 128);
            pCurrData  += 1;
            break;

        case PCM_TYPE_S8:
            pSampleDest->s8.sample_left  = (UINT8)((InSamp0 >> 8) + 128);
            pSampleDest->s8.sample_right = (UINT8)((InSamp1 >> 8) + 128);
            pCurrData  += 2;
            break;

        case PCM_TYPE_M16:
            pSampleDest->m16.sample = (INT16)((InSamp0+InSamp1)>>1);
            pCurrData  += 2;
            break;

        case PCM_TYPE_S16:
            pSampleDest->s16.sample_left  = (INT16)InSamp0;
            pSampleDest->s16.sample_right = (INT16)InSamp1;
            pCurrData  += 4;
            break;
        }
    }

Exit:
    m_lpWaveHdrCurrent->dwBytesRecorded += (pCurrData-m_lpCurrData);
    m_dwByteCount += (pCurrData-m_lpCurrData);
    m_lpCurrData = pCurrData;
    m_CurrT = CurrT;
    m_PrevSamp[0] = PrevSamp0;
    m_CurrSamp[0] = CurrSamp0;
    m_PrevSamp[1] = PrevSamp1;
    m_CurrSamp[1] = CurrSamp1;
    return pBuffer;
}


#else
PBYTE InputStreamContext::Render2(PBYTE pBuffer, PBYTE pBufferEnd, PBYTE pBufferLast)
{
    PBYTE pCurrData = m_lpCurrData;
    PBYTE pCurrDataEnd = m_lpCurrDataEnd;
    LONG fxpGain = m_fxpGain;

    LONG CurrT = m_CurrT;
    LONG DeltaT = m_DeltaT;

    LONG CurrSamp0 = m_CurrSamp[0];
    LONG PrevSamp0 = m_PrevSamp[0];
    LONG InSamp0;

    PCM_TYPE SampleType = m_SampleType;

    for (;;)
    {
        // Make sure we have a place to put the data
        if (pCurrData>=pCurrDataEnd)
        {
            goto Exit;
        }

        // Get the next sample
        while (CurrT >= 0x100)
        {
            if (pBuffer>=pBufferEnd)
            {
                goto Exit;
            }

            PrevSamp0 = CurrSamp0;
            CurrSamp0 = *(HWSAMPLE *)pBuffer;
            pBuffer += sizeof(HWSAMPLE);

            // Apply input gain?
            CurrSamp0 = (CurrSamp0 * fxpGain) >> 16;

            CurrT -= 0x100;
        }

        InSamp0 = (PrevSamp0 + ((CurrT * (CurrSamp0 - PrevSamp0)) >> 8));
        CurrT += DeltaT;

        PPCM_SAMPLE pSampleDest = (PPCM_SAMPLE)pCurrData;
        switch (m_SampleType)
        {
        case PCM_TYPE_M8:
        default:
            pSampleDest->m8.sample = (UINT8)((InSamp0 >> 8) + 128);
            pCurrData  += 1;
            break;

        case PCM_TYPE_S8:
            pSampleDest->s8.sample_left  = (UINT8)((InSamp0 >> 8) + 128);
            pSampleDest->s8.sample_right = (UINT8)((InSamp0 >> 8) + 128);
            pCurrData  += 2;
            break;

        case PCM_TYPE_M16:
            pSampleDest->m16.sample = (INT16)InSamp0;
            pCurrData  += 2;
            break;

        case PCM_TYPE_S16:
            pSampleDest->s16.sample_left  = (INT16)InSamp0;
            pSampleDest->s16.sample_right = (INT16)InSamp0;
            pCurrData  += 4;
            break;
        }
    }

Exit:
    m_lpWaveHdrCurrent->dwBytesRecorded += (pCurrData-m_lpCurrData);
    m_dwByteCount += (pCurrData-m_lpCurrData);
    m_lpCurrData = pCurrData;
    m_CurrT = CurrT;
    m_PrevSamp[0] = PrevSamp0;
    m_CurrSamp[0] = CurrSamp0;
    return pBuffer;
}
#endif

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久精品国产亚洲aⅴ| 亚洲国产aⅴ天堂久久| 日韩久久免费av| 9191成人精品久久| 欧美欧美欧美欧美| 国产无人区一区二区三区| 日韩免费看的电影| 精品三级av在线| 久久久影院官网| 国产午夜精品一区二区| 欧美激情一区二区三区蜜桃视频| 国产日韩欧美麻豆| 亚洲欧洲一区二区三区| 亚洲精品视频一区二区| 亚洲综合一二三区| 另类中文字幕网| 国产一区二区三区免费观看 | 色综合久久综合| 色拍拍在线精品视频8848| 欧美日免费三级在线| 91精品国产欧美一区二区| 亚洲精品一区在线观看| 国产精品乱码一区二三区小蝌蚪| 亚洲综合久久久久| 久久精品二区亚洲w码| 国产v日产∨综合v精品视频| 91美女视频网站| 欧美一区二区在线不卡| 国产精品污www在线观看| 亚洲男女毛片无遮挡| 麻豆免费看一区二区三区| 国产成人av电影在线| 91极品美女在线| 精品嫩草影院久久| 亚洲美女电影在线| 韩国欧美国产1区| 91老师片黄在线观看| 日韩欧美在线影院| 综合电影一区二区三区| 麻豆精品国产传媒mv男同| 99久久婷婷国产综合精品| 日韩三级高清在线| 亚洲欧美偷拍三级| 国产精品77777竹菊影视小说| 在线中文字幕不卡| 国产精品高清亚洲| 美国十次综合导航| 欧美日韩国产免费| 中文字幕一区在线观看| 久久66热偷产精品| 欧美日韩午夜影院| 亚洲欧洲无码一区二区三区| 麻豆精品新av中文字幕| 欧美日韩一级视频| 亚洲女性喷水在线观看一区| 国产精品原创巨作av| 欧美精品一级二级| 亚洲一区二区三区四区在线 | 久久99在线观看| 在线观看中文字幕不卡| 国产精品久久影院| 国产精品一区二区久久不卡| 日韩一区二区在线免费观看| 亚洲一区二区三区在线播放| 99vv1com这只有精品| 国产精品―色哟哟| 国产成人在线电影| 国产三级精品三级| 久久99久久久久| 日韩欧美亚洲国产精品字幕久久久| 亚洲sss视频在线视频| 欧美三级日韩三级| 亚洲一区在线观看视频| 在线精品视频一区二区三四| 又紧又大又爽精品一区二区| 99国产精品一区| 精品一区二区成人精品| 精品少妇一区二区三区| 九九精品视频在线看| xnxx国产精品| 国产成人在线视频网站| 国产精品麻豆一区二区| 99国产麻豆精品| 亚洲无人区一区| 91精品国产91久久综合桃花 | 在线视频你懂得一区| 亚洲丝袜精品丝袜在线| 成人午夜电影网站| 亚洲天堂免费在线观看视频| 91香蕉视频污| 日韩国产欧美在线播放| 精品福利一二区| 99久久国产综合色|国产精品| 尤物av一区二区| 欧美va日韩va| 亚洲一区在线免费观看| 欧美一区二区福利视频| 极品美女销魂一区二区三区免费| 欧美国产一区在线| 日本久久一区二区三区| 日本欧美一区二区三区| 久久久影视传媒| 在线视频观看一区| 麻豆精品在线播放| 日韩一区在线播放| 欧美精品在线视频| 国产成人在线观看免费网站| 一区二区三区加勒比av| 精品国产乱码久久久久久影片| 国产成人av影院| 香蕉乱码成人久久天堂爱免费| 日韩欧美国产综合| 91在线视频免费观看| 日韩成人伦理电影在线观看| 国产亚洲一本大道中文在线| 欧美在线不卡视频| 国产伦精品一区二区三区在线观看| 综合久久久久综合| 337p日本欧洲亚洲大胆精品 | 亚洲国产精品精华液网站| 精品国产区一区| 欧美日韩综合不卡| 99国产精品国产精品久久| 免费日韩伦理电影| 亚洲精品美腿丝袜| 欧美精彩视频一区二区三区| 欧美一区午夜精品| 色综合天天综合网天天狠天天| 韩国av一区二区三区在线观看| 一区二区三区欧美久久| 中文字幕高清一区| 欧美精品一区二区三| 欧美日韩国产乱码电影| 91原创在线视频| 豆国产96在线|亚洲| 久久精品国产澳门| 日韩精品电影一区亚洲| 一个色妞综合视频在线观看| 中文字幕在线不卡一区二区三区| 欧美mv日韩mv国产网站app| 欧美日韩和欧美的一区二区| 91丝袜美腿高跟国产极品老师 | 91 com成人网| 欧美性色综合网| 色香色香欲天天天影视综合网| 成人手机电影网| 丰满岳乱妇一区二区三区| 久久66热偷产精品| 紧缚捆绑精品一区二区| 奇米精品一区二区三区四区| 婷婷国产v国产偷v亚洲高清| 亚洲成人精品一区二区| 亚洲精品中文在线观看| 一个色在线综合| 午夜视频在线观看一区| 午夜久久福利影院| 日韩精品免费专区| 看片网站欧美日韩| 久久99国产精品久久| 国内一区二区在线| 国内久久精品视频| 成人开心网精品视频| fc2成人免费人成在线观看播放 | 久久69国产一区二区蜜臀| 狠狠久久亚洲欧美| 懂色av一区二区在线播放| 国产成人午夜视频| 91美女片黄在线| 欧美日韩精品一二三区| 欧美一级日韩免费不卡| 精品久久久久久久久久久院品网| 久久久综合视频| 综合久久综合久久| 日韩主播视频在线| 国产一区二区三区在线看麻豆| 成人一级黄色片| 欧美自拍丝袜亚洲| 26uuu久久天堂性欧美| 国产精品久久久久久久久久免费看| 亚洲免费观看高清| 美国十次综合导航| 色综合天天综合色综合av| 欧美一区二区三区公司| 亚洲国产成人在线| 亚洲国产精品久久不卡毛片| 紧缚奴在线一区二区三区| 91美女片黄在线观看91美女| 欧美精品色一区二区三区| 久久久国产精品午夜一区ai换脸| 一区二区三区毛片| 国产一区二区三区电影在线观看| 色视频成人在线观看免| 欧美精品一区二区不卡| 亚洲国产精品一区二区www在线| 国产一区二区电影| 欧美亚洲另类激情小说| 国产精品网站在线观看| 日韩av电影天堂| 欧洲精品视频在线观看| 国产女人18水真多18精品一级做|