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

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

?? input.cpp

?? 音頻編解碼器Codec: UCB1400 WinCE6.0音頻驅動WAVEDEV2
?? CPP
字號:
//
// Copyright (c) Microsoft Corporation.  All rights reserved.
//
//
// Use of this sample source code is subject to the terms of the Microsoft
// license agreement under which you licensed this sample source code. If
// you did not accept the terms of the license agreement, you are not
// authorized to use this sample source code. For the terms of the license,
// please see the license agreement between you and Microsoft or, if applicable,
// see the LICENSE.RTF on your install media or the root of your tools installation.
// THE SAMPLE SOURCE CODE IS PROVIDED "AS IS", WITH NO WARRANTIES.
//
/*
** Copyright 2000-2003 Intel Corporation All Rights Reserved.
**
** Portions of the source code contained or described herein and all documents
** related to such source code (Material) are owned by Intel Corporation
** or its suppliers or licensors and is licensed by Microsoft Corporation for distribution.
** Title to the Material remains with Intel Corporation or its suppliers and licensors.
** Use of the Materials is subject to the terms of the Microsoft license agreement which accompanied the Materials.
** No other license under any patent, copyright, trade secret or other intellectual
** property right is granted to or conferred upon you by disclosure or
** delivery of the Materials, either expressly, by implication, inducement,
** estoppel or otherwise
** Some portion of the Materials may be copyrighted by Microsoft Corporation.
*/
#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)
{
    UINT64 Delta;

    m_dwMultiplier = dwMultiplier;

    Delta = m_WaveFormat.nSamplesPerSec;
    Delta *= m_dwMultiplier;
    Delta >>= 16;
    Delta = ((UINT32)(((1i64<<32)/Delta)+1));
    Delta = (Delta * SAMPLERATE);
    Delta >>= DELTAINT;

    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)
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 >= DELTA_OVERFLOW)
        {
            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 -= DELTA_OVERFLOW;
        }

        InSamp0 = (PrevSamp0 + ((CurrT * (CurrSamp0 - PrevSamp0)) >> DELTAFRAC));
        InSamp1 = (PrevSamp1 + ((CurrT * (CurrSamp1 - PrevSamp1)) >> DELTAFRAC));
        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 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 >= DELTA_OVERFLOW)
        {
            if (pBuffer>=pBufferEnd)
            {
                goto Exit;
            }

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

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

            CurrT -= DELTA_OVERFLOW;
        }

        InSamp0 = (PrevSamp0 + ((CurrT * (CurrSamp0 - PrevSamp0)) >> DELTAFRAC));
        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一区二区三区免费野_久草精品视频
午夜精品久久久久久久99水蜜桃| av一区二区三区| 国产福利一区二区三区| 色婷婷狠狠综合| 久久午夜免费电影| 洋洋成人永久网站入口| 国产成人精品三级| 日韩限制级电影在线观看| 国产精品短视频| 国产精品一区二区在线观看不卡| 欧美日韩激情一区二区| 中文字幕一区在线| 国产酒店精品激情| 日韩欧美成人午夜| 午夜伦欧美伦电影理论片| 成人高清视频在线| 久久青草国产手机看片福利盒子| 亚洲成人免费电影| 色偷偷一区二区三区| 国产精品入口麻豆原神| 极品美女销魂一区二区三区免费| 欧美日韩国产精品成人| 一级做a爱片久久| 99国产精品一区| 国产精品成人免费在线| 国产成人午夜电影网| 久久婷婷成人综合色| 久久精品国产精品亚洲综合| 欧美日韩日日骚| 香蕉影视欧美成人| 欧美怡红院视频| 夜夜精品视频一区二区| 欧美午夜精品一区二区三区 | 亚洲一区二区四区蜜桃| 91在线国产福利| 亚洲男同1069视频| 色视频欧美一区二区三区| 一区二区三区在线播| 一本久久a久久精品亚洲| 亚洲精品视频观看| 在线看国产日韩| 亚洲风情在线资源站| 91精品国产美女浴室洗澡无遮挡| 亚洲第一福利视频在线| 欧美日韩国产一区二区三区地区| 亚洲国产综合人成综合网站| 欧美做爰猛烈大尺度电影无法无天| 亚洲精品日韩专区silk| 91高清视频在线| 亚洲v中文字幕| 91精品国产91久久久久久一区二区 | xnxx国产精品| 成人一区二区三区视频在线观看| 日本一区二区三级电影在线观看| 国产999精品久久久久久绿帽| 中文字幕av一区二区三区高| 色综合久久综合| 天天色综合天天| 久久免费的精品国产v∧| 国产91丝袜在线播放| 亚洲色图在线播放| 欧美日韩精品一区二区在线播放| 麻豆精品一区二区综合av| 亚洲国产岛国毛片在线| 色先锋aa成人| 久久国产精品色| 国产精品不卡在线| 欧美一卡二卡三卡四卡| 国产99久久久国产精品| 亚洲国产精品一区二区www在线| 日韩欧美国产午夜精品| 99久久精品国产精品久久| 午夜视频久久久久久| 久久精品人人做人人综合| 日本韩国欧美在线| 国产麻豆一精品一av一免费| 亚洲精品五月天| 久久伊人蜜桃av一区二区| 色综合天天综合网天天狠天天 | 亚洲第四色夜色| 日本一区二区三级电影在线观看 | 99riav一区二区三区| 丝瓜av网站精品一区二区| 国产精品美日韩| 欧美一二三在线| 91精品福利在线| 国产福利精品一区二区| 日韩和欧美的一区| 亚洲日韩欧美一区二区在线| 欧美成人欧美edvon| 欧美体内she精视频| 高清不卡一区二区| 久久精品国产第一区二区三区| 亚洲精品国产无天堂网2021 | 欧美xxx久久| 欧美色综合久久| 99久久伊人精品| 国产精品1区2区3区| 国产一区二区不卡| 日韩av一区二区三区| 一区二区三区四区在线免费观看 | 亚洲一区二区三区国产| 国产精品毛片无遮挡高清| 欧美变态口味重另类| 欧美精选一区二区| 在线亚洲人成电影网站色www| 国产成人精品一区二区三区四区| 精品一区二区三区免费播放 | 亚洲美女视频一区| 欧美韩国日本不卡| 久久九九影视网| 久久综合九色综合欧美就去吻| 51久久夜色精品国产麻豆| 欧美午夜精品一区| 欧美视频一区二区在线观看| 色综合久久中文字幕综合网| 99精品欧美一区二区三区小说| 成人做爰69片免费看网站| 国产99精品国产| a级高清视频欧美日韩| 99国产精品久久久久久久久久| 99免费精品在线| 色偷偷久久一区二区三区| 91久久精品一区二区三区| 91看片淫黄大片一级在线观看| 91麻豆成人久久精品二区三区| 国产精品久久久久久久久久免费看 | 成人午夜在线播放| 成人亚洲一区二区一| 国产凹凸在线观看一区二区| 成人毛片在线观看| 91同城在线观看| 欧美在线观看视频在线| 91精品国产色综合久久不卡电影 | 欧美国产精品v| 国产精品久久久久一区| 亚洲欧美综合色| 亚洲一区在线视频| 青娱乐精品在线视频| 精品在线你懂的| 粉嫩av一区二区三区| 色先锋资源久久综合| 精品视频一区 二区 三区| 日韩三级电影网址| 国产午夜亚洲精品理论片色戒| 国产精品久久777777| 一区二区免费在线播放| 蜜臀av亚洲一区中文字幕| 国产一区二区精品久久99| 色婷婷av一区二区三区软件| 91麻豆精品国产91久久久久| 久久色.com| 亚洲激情综合网| 精品亚洲aⅴ乱码一区二区三区| 激情av综合网| 欧美无乱码久久久免费午夜一区| 日韩欧美成人一区| 亚洲裸体xxx| 激情成人午夜视频| 欧美在线影院一区二区| 26uuu色噜噜精品一区| 亚洲欧美韩国综合色| 蜜桃一区二区三区在线| 91香蕉视频在线| 欧美不卡一区二区三区| 亚洲综合视频在线| 国产成人av电影在线播放| 7777精品久久久大香线蕉| 亚洲国产精品成人综合色在线婷婷| 亚洲国产成人av| www.欧美色图| 亚洲精品一区二区三区香蕉| 一区二区三区精品在线| 国产在线观看一区二区| 欧美日韩在线观看一区二区| 久久久久久亚洲综合影院红桃| 天天爽夜夜爽夜夜爽精品视频| 99久久精品国产毛片| 精品少妇一区二区三区日产乱码| 亚洲国产一区二区三区| 成人黄页毛片网站| 久久久久高清精品| 免费成人结看片| 欧美系列日韩一区| 一区二区三区四区不卡在线| 粉嫩绯色av一区二区在线观看| 日韩精品一区在线观看| 午夜激情一区二区三区| 色偷偷一区二区三区| 中文字幕一区二区不卡 | 紧缚捆绑精品一区二区| 欧美精品久久99| 亚洲成人第一页| 在线免费观看视频一区| 亚洲手机成人高清视频| 成人app在线| 一区精品在线播放| 91在线视频网址| 亚洲免费看黄网站| 一本久久综合亚洲鲁鲁五月天|