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

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

?? input.cpp

?? realtek562x系列驅動源碼。wince
?? 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一区二区三区免费野_久草精品视频
国产精品不卡一区二区三区| 91久久精品一区二区二区| 亚洲一区二区精品3399| 亚洲视频每日更新| 欧美高清精品3d| 国产一区999| 日韩专区欧美专区| 亚洲成人久久影院| 天天影视涩香欲综合网 | 国产喂奶挤奶一区二区三区| 丰满白嫩尤物一区二区| 成人免费高清在线| 日本色综合中文字幕| 色婷婷综合久久久中文字幕| 豆国产96在线|亚洲| 成人av在线播放网站| av一二三不卡影片| 欧美亚洲丝袜传媒另类| 91麻豆精品91久久久久久清纯| 中文字幕乱码久久午夜不卡| 国产丝袜在线精品| 亚洲欧洲av一区二区三区久久| 欧美伊人久久大香线蕉综合69| 九九热在线视频观看这里只有精品| 欧美国产日韩在线观看| 国产精品麻豆99久久久久久| 一区二区三区自拍| 久久精品噜噜噜成人88aⅴ| 国内久久精品视频| 成人一级黄色片| 欧美做爰猛烈大尺度电影无法无天| 亚洲精品综合在线| 日韩一级免费一区| 国产日韩欧美综合一区| 国产精品你懂的在线| 亚洲一级在线观看| 精品一区二区三区日韩| 色乱码一区二区三区88| 欧美一卡2卡3卡4卡| 日韩美女视频一区二区| 亚洲色欲色欲www在线观看| 亚洲电影中文字幕在线观看| 国产精品一卡二卡在线观看| 欧美伊人精品成人久久综合97| 不卡的av电影在线观看| 在线不卡一区二区| 亚洲日本va午夜在线电影| 国产精品一区二区久久不卡| 欧美三级日韩三级| 亚洲欧洲精品一区二区三区| 亚洲麻豆国产自偷在线| 欧美视频第二页| 国产清纯在线一区二区www| 亚洲小说欧美激情另类| 99热在这里有精品免费| 日韩女优av电影| 国产精品免费av| 精品一区二区三区在线播放视频 | 日韩午夜激情电影| 亚洲视频在线一区| 国产精品一二二区| 日韩欧美一级二级三级| 亚洲成人自拍网| 99久久精品99国产精品| 日本一区二区视频在线| 国产精品123| www精品美女久久久tv| 久久精品久久久精品美女| 国产馆精品极品| 欧美调教femdomvk| 亚洲欧美一区二区久久| 色狠狠av一区二区三区| 亚洲另类中文字| 99精品欧美一区二区蜜桃免费| 成人中文字幕电影| 欧美精品一区视频| 韩国视频一区二区| 久久久五月婷婷| 国产suv精品一区二区6| 亚洲国产岛国毛片在线| 成人污污视频在线观看| 亚洲人一二三区| 在线观看av一区| 日韩精彩视频在线观看| 欧美日韩不卡一区二区| 人人精品人人爱| 久久―日本道色综合久久| 粉嫩高潮美女一区二区三区| 一区在线观看免费| 在线观看av一区| 99re6这里只有精品视频在线观看| 国产.欧美.日韩| 国产精品久久久久影院色老大| 亚洲欧美乱综合| 色8久久人人97超碰香蕉987| 丝袜美腿亚洲综合| 日韩三级av在线播放| 国产成人午夜视频| 中文字幕一区三区| 欧美三级中文字| 国产精品一区二区在线看| 日韩久久一区二区| 91麻豆精品国产无毒不卡在线观看 | 亚洲国产高清aⅴ视频| 99在线视频精品| 日韩va欧美va亚洲va久久| 国产三级欧美三级日产三级99 | 在线观看www91| 麻豆国产91在线播放| 国产精品人成在线观看免费| 欧洲一区二区三区在线| 国产老女人精品毛片久久| 亚洲男帅同性gay1069| 日韩三级中文字幕| 色香蕉成人二区免费| 激情文学综合网| 亚洲一区在线观看网站| 久久久久久久久伊人| 欧美图片一区二区三区| youjizz久久| 狠狠色狠狠色综合系列| 一区二区三区精品视频| 国产精品天美传媒| 日韩午夜av一区| 色悠悠久久综合| 紧缚奴在线一区二区三区| 午夜欧美电影在线观看| 中文字幕一区二区5566日韩| 精品国产亚洲在线| 日韩小视频在线观看专区| 欧美写真视频网站| 91蜜桃在线免费视频| 国产成人精品三级| 日韩一区日韩二区| 欧美在线影院一区二区| 国产99一区视频免费| 蜜臀av性久久久久蜜臀aⅴ四虎| 在线亚洲精品福利网址导航| 美国av一区二区| 欧美不卡一区二区三区| 欧美亚洲一区三区| 色婷婷综合久久| 97精品久久久午夜一区二区三区 | 色综合天天性综合| 高清视频一区二区| 美女高潮久久久| 日韩电影一二三区| 三级在线观看一区二区| 亚洲狠狠丁香婷婷综合久久久| 在线看不卡av| 在线中文字幕一区二区| 在线观看欧美黄色| 日本精品免费观看高清观看| 92国产精品观看| 一本大道久久a久久综合| 国产成人精品网址| 不卡电影一区二区三区| 成人h版在线观看| 99re成人精品视频| 欧美性受xxxx| 欧美男男青年gay1069videost| 精品一区二区三区av| 国产综合久久久久久鬼色| 国产一区二三区好的| 国产精一品亚洲二区在线视频| 中文字幕av一区二区三区免费看 | 一区二区久久久| 夜色激情一区二区| 午夜久久久影院| 日本午夜一本久久久综合| 日本sm残虐另类| 国产精品1区二区.| 91麻豆福利精品推荐| 精品视频在线免费看| 日韩欧美一级在线播放| 国产精品区一区二区三区| 自拍偷拍国产精品| 亚洲成av人片在线观看无码| 激情六月婷婷久久| 99视频热这里只有精品免费| 91麻豆国产福利在线观看| 91精品在线免费| 国产精品国产三级国产aⅴ原创| 欧美一二三在线| 国产精品色眯眯| 日韩精品一二三四| 成人午夜av电影| 欧美亚洲一区三区| 欧美国产乱子伦| 视频一区二区三区中文字幕| 国产麻豆精品视频| 精品婷婷伊人一区三区三| 国产午夜精品一区二区| 亚洲国产成人av好男人在线观看| 国产日产欧产精品推荐色| 亚洲尤物在线视频观看| 韩国一区二区视频| 欧美乱妇23p| 欧美日韩日日骚| 毛片av一区二区三区|