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

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

?? input.cpp

?? s3c2440 WINCE 5.00 官方bsp
?? 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;
}

ULONG g_volshift = 3;

#if (OUTCHANNELS==2)
PBYTE InputStreamContext::Render2(PBYTE pBuffer, PBYTE pBufferEnd, PBYTE pBufferLast)
{
    PBYTE pCurrData = m_lpCurrData;
    PBYTE pCurrDataEnd = m_lpCurrDataEnd;
    LONG fxpGain = (m_fxpGain << g_volshift) ; // smdk2440 appears to have a dynamic range of ~12 bits. amp it up

    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 << g_volshift) ; // smdk2440 appears to have a dynamic range of ~12 bits. amp it up

    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人片在线观看中文| 91久久精品国产91性色tv| 亚洲欧美日韩系列| 91社区在线播放| 亚洲一区二区三区爽爽爽爽爽 | 日韩欧美国产不卡| 婷婷国产v国产偷v亚洲高清| 欧美精品粉嫩高潮一区二区| 日本欧美韩国一区三区| 日韩一区二区在线观看视频| 色综合色综合色综合| 日本高清视频一区二区| 亚洲欧美另类综合偷拍| 欧美三级三级三级| 麻豆国产欧美日韩综合精品二区| 欧美tickling挠脚心丨vk| 国产一区二区毛片| 亚洲黄色av一区| 日韩视频一区在线观看| 国产成人免费9x9x人网站视频| 亚洲色图在线视频| 日韩一区二区在线看片| 99精品偷自拍| 蜜桃精品视频在线| 国产精品传媒入口麻豆| 日韩欧美国产一二三区| av在线播放一区二区三区| 亚洲一二三四久久| 日本乱人伦一区| 一区二区三区 在线观看视频| 日韩欧美区一区二| 日本精品一区二区三区高清| 国产精品一区二区免费不卡 | 国产日产欧美一区二区视频| 日本精品一区二区三区高清| 日韩av午夜在线观看| 亚洲免费伊人电影| 国产精品免费视频观看| 久久久综合视频| 精品国产一区二区在线观看| 91精品国产色综合久久不卡电影| 91无套直看片红桃| 99久久精品情趣| 成人精品一区二区三区四区| 国产精品综合av一区二区国产馆| 日韩在线观看一区二区| 日韩高清国产一区在线| 午夜精品免费在线| 青青青爽久久午夜综合久久午夜 | 日韩一区二区三区av| 欧美三级日本三级少妇99| 欧美日韩精品综合在线| 欧美精品一二三区| 精品日韩在线一区| 26uuu久久天堂性欧美| 国产丝袜在线精品| 亚洲男人的天堂av| 亚洲午夜私人影院| 日韩精品91亚洲二区在线观看| 奇米四色…亚洲| 国产精品亚洲午夜一区二区三区 | 91麻豆精品国产91久久久| 欧美影视一区在线| www成人在线观看| 国产精品福利一区二区| 亚洲成人午夜影院| 国产在线播放一区| 91捆绑美女网站| 欧美一区二区三区视频在线观看| 95精品视频在线| 欧美高清精品3d| 中文字幕日韩欧美一区二区三区| 亚洲女同ⅹxx女同tv| 国产毛片精品视频| 欧美体内she精高潮| 国产精品视频线看| 免费成人av资源网| 91国偷自产一区二区使用方法| 精品久久久久香蕉网| 午夜精品一区二区三区三上悠亚| 大胆欧美人体老妇| 在线不卡的av| 亚洲午夜久久久久久久久电影院| 国产精品亚洲一区二区三区妖精| 欧美性色aⅴ视频一区日韩精品| 国产女主播在线一区二区| 经典三级一区二区| 欧美电影精品一区二区| 日韩黄色小视频| 在线亚洲高清视频| 亚洲综合色在线| 在线一区二区三区四区| 亚洲免费av高清| 在线观看一区二区视频| 亚洲免费资源在线播放| av高清久久久| 亚洲一区二区高清| 色琪琪一区二区三区亚洲区| 亚洲精品乱码久久久久久黑人 | 日韩欧美不卡一区| 青娱乐精品在线视频| 精品国产电影一区二区| 国产最新精品免费| 国产婷婷色一区二区三区在线| 国产91精品精华液一区二区三区| 久久久综合精品| 97久久精品人人澡人人爽| 亚洲一区中文日韩| 日韩欧美高清在线| 99久久99精品久久久久久| 国产精品毛片久久久久久久| 国产乱码字幕精品高清av| 亚洲欧美自拍偷拍色图| 欧美精品自拍偷拍| 国产精品小仙女| 亚洲精品久久7777| 日韩视频中午一区| 91麻豆精品一区二区三区| 日本伊人精品一区二区三区观看方式 | 亚洲欧美日韩在线| 精品国产乱码久久久久久免费 | 欧美精品在欧美一区二区少妇| 久久99国产精品免费网站| 一区二区三区在线观看欧美 | 91黄色在线观看| 久久疯狂做爰流白浆xx| 一区二区三国产精华液| 久久精品在线观看| 日韩区在线观看| 欧美日韩亚洲高清一区二区| 成人动漫在线一区| 国产精品自拍三区| 麻豆91精品91久久久的内涵| 亚洲综合色网站| 伊人开心综合网| 亚洲欧洲精品一区二区三区不卡 | 一本久久a久久精品亚洲| 国产不卡高清在线观看视频| 美腿丝袜在线亚洲一区| 国产精品第五页| 5566中文字幕一区二区电影| 色综合天天天天做夜夜夜夜做| 国产精选一区二区三区| 国产精品综合视频| 国产成人一区在线| 成人免费视频视频在线观看免费| 国产99久久久国产精品潘金 | 国产成人免费视频精品含羞草妖精| 婷婷中文字幕综合| 免费观看日韩电影| 麻豆成人免费电影| 麻豆国产欧美一区二区三区| 欧美激情在线观看视频免费| 欧美乱妇15p| 欧美xxxx在线观看| 日本一区免费视频| 一区二区三区精品视频在线| 亚洲色图视频网站| 视频一区欧美精品| 狠狠色伊人亚洲综合成人| 成人性视频免费网站| 91麻豆免费在线观看| 91麻豆精品国产91久久久久久久久| 欧美成人vr18sexvr| 综合在线观看色| 精品一二线国产| 欧美日韩国产高清一区| 在线不卡中文字幕| 一本大道av伊人久久综合| 欧美专区在线观看一区| 久久精品日韩一区二区三区| 一区二区三区免费在线观看| 麻豆成人久久精品二区三区红| 成人免费av在线| 久久青草欧美一区二区三区| 亚洲国产精品嫩草影院| 激情综合网天天干| 日韩一区二区三区四区| 一区二区在线观看视频| 丁香另类激情小说| 久久免费午夜影院| 国内精品免费在线观看| 制服视频三区第一页精品| 综合精品久久久| 成人国产电影网| 久久久另类综合| 成人在线一区二区三区| 久久久亚洲精品石原莉奈 | 亚洲综合一区二区三区| 成人精品免费网站| 国产精品美女一区二区| 国产乱人伦偷精品视频免下载 |