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

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

?? input.cpp

?? SMDK2440 友善之臂MINI2440使用
?? CPP
字號:
// -----------------------------------------------------------------------------
//
//      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.
//      Copyright (c) 1995-2000 Microsoft Corporation.  All rights reserved.
//
// -----------------------------------------------------------------------------
#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 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);
            pSampleDest->m8.sample = (UINT8)( ((InSamp0+InSamp0) >> 9) + 128);
            pCurrData  += 1;
            break;

        case PCM_TYPE_S8:
            //pSampleDest->s8.sample_left  = (UINT8)((InSamp0 >> 8) + 128);
            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+InSamp1)>>1);
            pSampleDest->m16.sample = (INT16)((InSamp0+InSamp0)>>1);
            pCurrData  += 2;
            break;

        case PCM_TYPE_S16:
            //pSampleDest->s16.sample_left  = (INT16)InSamp0;
            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;
    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 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一区二区三区免费野_久草精品视频
色婷婷av一区二区三区大白胸| 成人在线视频一区| 久久免费午夜影院| www.日本不卡| 天天爽夜夜爽夜夜爽精品视频| 欧美精品一卡二卡| 极品美女销魂一区二区三区 | 91国产视频在线观看| 亚洲国产cao| 色综合夜色一区| 欧美日韩国产123区| 中文字幕在线不卡| 成人激情小说网站| 日韩高清在线不卡| 欧美日韩成人一区| 色琪琪一区二区三区亚洲区| 激情欧美一区二区三区在线观看| 一本久道久久综合中文字幕| 国产一区 二区| 亚洲国产一二三| 最新不卡av在线| 久久亚洲二区三区| 欧美性欧美巨大黑白大战| 国产精品综合在线视频| 亚洲成av人片一区二区梦乃| 国产精品不卡一区二区三区| 久久久蜜桃精品| 欧美一区二区福利在线| aaa欧美色吧激情视频| 综合欧美一区二区三区| 欧美精品一区二区高清在线观看| 色一情一乱一乱一91av| 国产裸体歌舞团一区二区| 五月婷婷激情综合网| 亚洲人成伊人成综合网小说| 国产拍揄自揄精品视频麻豆| 欧美午夜不卡视频| 亚洲精品乱码久久久久久黑人| 久久精品视频网| 国产视频在线观看一区二区三区| 久久久欧美精品sm网站| 国产日韩欧美精品综合| 欧美国产日韩在线观看| 国产精品麻豆视频| 亚洲人成电影网站色mp4| 亚洲三级在线看| 亚洲一区二区三区中文字幕在线| 亚洲精品精品亚洲| 夜夜精品视频一区二区| 亚洲精品欧美专区| 亚洲电影视频在线| 美腿丝袜在线亚洲一区| 久久精品免费观看| 免费在线欧美视频| 91首页免费视频| 99精品久久只有精品| 亚洲午夜一区二区三区| 日本视频免费一区| 欧美成人video| 日韩一区二区三区视频| 日韩精品一区二区三区视频 | 日本系列欧美系列| 久久99精品久久久久久动态图| 精品一区二区三区免费| 成人免费黄色大片| 欧美日韩中文字幕精品| 精品福利一二区| 国产精品大尺度| 视频一区在线播放| 国产一区二区久久| 一本久久精品一区二区| 日韩一区二区电影在线| 中文久久乱码一区二区| 亚洲第一激情av| 国产精品一二二区| 欧美三级视频在线观看| 精品第一国产综合精品aⅴ| 国产精品卡一卡二卡三| 日本亚洲视频在线| 不卡av免费在线观看| 欧美久久一区二区| 国产精品麻豆一区二区| 日本系列欧美系列| 91麻豆国产精品久久| 精品欧美乱码久久久久久1区2区| ●精品国产综合乱码久久久久| 日韩黄色一级片| 成人午夜激情视频| 欧美一区二区三区免费观看视频| 国产精品福利一区二区三区| 奇米色一区二区| 色呦呦一区二区三区| 久久人人爽人人爽| 亚洲成人久久影院| 不卡一区在线观看| 久久天堂av综合合色蜜桃网| 亚洲成av人综合在线观看| 国产不卡在线播放| 欧美成人福利视频| 午夜国产不卡在线观看视频| 99久久精品久久久久久清纯| 精品免费国产一区二区三区四区| 亚洲一区二区av电影| 成人黄页毛片网站| 精品国产乱码久久久久久免费| 亚洲国产精品久久人人爱蜜臀| 成人免费高清在线| 奇米影视一区二区三区小说| 国产真实精品久久二三区| 国产精品久久久久久久久果冻传媒| 欧美日韩aaaaa| 在线观看欧美精品| 国产精品久久久久婷婷二区次| 久久精品国产一区二区三区免费看| 色综合久久中文字幕| 中文文精品字幕一区二区| 久久66热偷产精品| 555www色欧美视频| 午夜伊人狠狠久久| 在线免费av一区| 亚洲欧美日韩一区二区三区在线观看| 高清成人在线观看| 久久这里只有精品首页| 蜜臀av亚洲一区中文字幕| 欧美老肥妇做.爰bbww| 一区二区三区四区亚洲| 色综合色综合色综合色综合色综合| 国产亚洲制服色| 理论电影国产精品| eeuss影院一区二区三区| 色婷婷国产精品| 欧美一区二区三区在| 日韩中文字幕不卡| 欧美视频日韩视频在线观看| 亚洲精品乱码久久久久久| 99久久久久久| 一区二区三区在线视频观看| 91成人国产精品| 亚洲一区在线观看网站| 欧美视频在线播放| 午夜精品久久久久久久99樱桃| 欧美吻胸吃奶大尺度电影| 午夜av一区二区三区| 91麻豆精品国产91| 久久66热偷产精品| 国产欧美日韩中文久久| 丁香一区二区三区| 亚洲视频一二三| 91国在线观看| 毛片不卡一区二区| 在线免费观看成人短视频| 亚洲综合视频在线观看| 欧美系列一区二区| 日韩影院免费视频| 欧美不卡激情三级在线观看| 国产一区二区三区最好精华液| 久久精品欧美日韩| 91蝌蚪国产九色| 天天操天天综合网| 欧美精品一区二区久久婷婷| 成人高清伦理免费影院在线观看| 一区二区三区免费在线观看| 9191国产精品| 国产成人精品一区二区三区网站观看| 国产精品亲子伦对白| 91久久线看在观草草青青 | 久久影院午夜片一区| av电影在线观看一区| 性感美女极品91精品| 精品久久久久久亚洲综合网| 成人免费视频免费观看| 亚洲精品视频一区二区| 欧美大胆人体bbbb| 成人激情小说乱人伦| 午夜精品久久久久影视| 国产欧美日韩综合精品一区二区| 91极品美女在线| 国内精品视频一区二区三区八戒| 国产精品福利影院| 日韩欧美国产一区二区三区 | 日韩精品一区在线观看| 99精品热视频| 麻豆国产精品一区二区三区| 亚洲三级在线免费| 亚洲精品一区二区三区99| 色婷婷av一区二区三区大白胸| 久久精品国产**网站演员| 尤物视频一区二区| 国产亚洲欧美中文| 午夜一区二区三区视频| 欧洲国产伦久久久久久久| 亚洲成人资源在线| 国产精品欧美极品| 欧美一区二区三区视频在线观看| 国产成人在线视频网站| 日韩电影网1区2区| 欧美成人激情免费网| 韩国视频一区二区| 亚洲综合色区另类av| 日韩一级完整毛片|