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

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

?? input.cpp

?? wince 下的bsp測試wince_bspSMDK2440_L35T32.rar
?? 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一区二区三区免费野_久草精品视频
成人禁用看黄a在线| 国产午夜精品一区二区| 日韩欧美的一区二区| 日本一区二区免费在线| 日本va欧美va瓶| 成人app在线观看| 精品黑人一区二区三区久久 | 日本特黄久久久高潮| 国产一区二区美女| 欧美精品第1页| 亚洲欧美aⅴ...| 国产iv一区二区三区| 91.麻豆视频| 亚洲女人的天堂| 成人免费毛片app| 日韩免费电影网站| 天天色天天操综合| 91免费在线视频观看| 久久久综合激的五月天| 日本特黄久久久高潮| 欧美三级视频在线| 亚洲免费av高清| 91在线云播放| 国产精品国产三级国产aⅴ入口| 久久精品国产一区二区| 884aa四虎影成人精品一区| 亚洲美女免费在线| 99麻豆久久久国产精品免费| 久久久www免费人成精品| 久久精品99国产国产精| 日韩一级免费观看| 蜜桃免费网站一区二区三区| 欧美丰满少妇xxxbbb| 亚洲一区二区三区美女| 色国产精品一区在线观看| 亚洲欧美色综合| 91玉足脚交白嫩脚丫在线播放| 国产清纯白嫩初高生在线观看91| 国产在线精品国自产拍免费| 26uuu欧美| 国产一区二区三区久久久 | 日本不卡一区二区三区高清视频| 欧美这里有精品| 亚洲成a人v欧美综合天堂下载 | 懂色av一区二区三区蜜臀| 久久伊99综合婷婷久久伊| 精品在线亚洲视频| 欧美国产1区2区| aaa欧美大片| 亚洲一区二区黄色| 欧美一级在线视频| 激情久久五月天| 国产免费久久精品| 日本道精品一区二区三区| 午夜a成v人精品| 精品久久久久一区| 99精品热视频| 亚洲大片一区二区三区| 精品入口麻豆88视频| 国产sm精品调教视频网站| 亚洲精品久久久蜜桃| 在线91免费看| 国产成人综合自拍| 亚洲第一二三四区| 久久久久久久久久久久久久久99| 成人av在线播放网址| 亚洲成精国产精品女| 欧美精品一区二区精品网| 成人av动漫网站| 丝袜脚交一区二区| 亚洲国产精品高清| 欧美精品自拍偷拍| 成+人+亚洲+综合天堂| 视频一区二区三区中文字幕| 久久久综合激的五月天| 欧美专区在线观看一区| 国产伦精品一区二区三区在线观看| 亚洲欧洲美洲综合色网| 日韩欧美在线网站| 91在线码无精品| 久久99久久99| 亚洲va欧美va人人爽| 国产色综合久久| 日韩一区二区三区在线观看| 成人理论电影网| 免费成人在线影院| 一区二区三区毛片| 国产情人综合久久777777| 91麻豆精品国产91久久久久久 | 在线视频中文字幕一区二区| 狠狠狠色丁香婷婷综合激情| 亚洲综合激情另类小说区| 国产欧美精品日韩区二区麻豆天美| 欧美久久久久久久久久| 色综合久久综合网欧美综合网| 国产专区欧美精品| 日本aⅴ免费视频一区二区三区| 中文字幕一区二区三区精华液 | 欧美猛男男办公室激情| 国产激情一区二区三区桃花岛亚洲| 日日夜夜一区二区| 夜夜操天天操亚洲| 亚洲丝袜制服诱惑| 一区在线观看免费| 欧美激情综合在线| 国产日韩av一区| 国产午夜精品一区二区三区视频| 日韩免费视频一区二区| 91 com成人网| 欧美肥大bbwbbw高潮| 欧美精品久久一区| 欧美另类久久久品| 欧美日韩精品是欧美日韩精品| 91老司机福利 在线| 91丝袜美女网| 色综合久久中文综合久久97| 色综合视频在线观看| 日本国产一区二区| 欧美日韩一区二区三区不卡| 欧美色大人视频| 欧美巨大另类极品videosbest | 国产精品一区二区在线看| 激情另类小说区图片区视频区| 另类小说视频一区二区| 美女看a上一区| 久久99日本精品| 精品亚洲porn| 国产成人午夜视频| 色综合视频一区二区三区高清| 91麻豆产精品久久久久久| 在线播放/欧美激情| 在线综合视频播放| 精品成a人在线观看| 国产天堂亚洲国产碰碰| 成人欧美一区二区三区1314 | 日韩av一级电影| 麻豆精品久久久| 国产精品一区二区你懂的| 成人免费视频视频| 精品国产乱码久久久久久久久| 精品国产一区二区亚洲人成毛片| 国产欧美精品一区二区色综合朱莉| 国产精品超碰97尤物18| 亚洲一二三四久久| 久久精品999| 99精品桃花视频在线观看| 欧美日韩成人一区| 久久综合精品国产一区二区三区| 国产欧美精品一区二区色综合| 一区二区高清在线| 国产精品一线二线三线| 欧美最猛性xxxxx直播| 欧美电影免费观看高清完整版在| 欧美国产日韩在线观看| 亚洲国产美国国产综合一区二区| 六月婷婷色综合| 91在线一区二区| 欧美电影免费观看完整版| 亚洲日本一区二区三区| 老司机一区二区| 色婷婷精品大在线视频| 精品欧美一区二区在线观看| 亚洲激情男女视频| 国产成人午夜99999| 欧美一区二区在线免费观看| 亚洲国产成人在线| 免费观看在线综合色| 色欧美片视频在线观看| 久久伊99综合婷婷久久伊| 日韩精品每日更新| 91影院在线观看| 中文字幕成人在线观看| 久久福利资源站| 欧美在线视频全部完| 国产精品蜜臀av| 国产一区二区三区最好精华液| 欧美日韩在线免费视频| 国产成人精品影视| 欧美一级理论片| 亚洲第一福利视频在线| 99国产精品99久久久久久| 久久婷婷成人综合色| 免费在线观看精品| 欧美精三区欧美精三区| 夜夜夜精品看看| 色综合一区二区三区| 国产目拍亚洲精品99久久精品| 九色|91porny| 91精品久久久久久久久99蜜臂| 洋洋成人永久网站入口| 91性感美女视频| 亚洲国产精品99久久久久久久久| 国内精品伊人久久久久av影院| 91精品国产高清一区二区三区蜜臀| 亚洲激情一二三区| 日本精品免费观看高清观看| 亚洲码国产岛国毛片在线| 一本色道久久综合亚洲aⅴ蜜桃 | 91精品麻豆日日躁夜夜躁| 香蕉成人啪国产精品视频综合网|