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

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

?? apedecompresscore.cpp

?? Lossless Audio 縮解壓 window
?? CPP
字號:
#include "All.h"
#ifdef BACKWARDS_COMPATIBILITY

#include "UnMAC.h"
#include "APEDecompressCore.h"
#include "../APEInfo.h"
#include "GlobalFunctions.h"
#include "../UnBitArrayBase.h"
#include "Anti-Predictor.h"
#include "UnMAC.h"
#include "../Prepare.h"
#include "../UnBitArray.h"
#include "../Assembly/Assembly.h"

CAPEDecompressCore::CAPEDecompressCore(CIO * pIO, IAPEDecompress * pAPEDecompress)
{
    m_pAPEDecompress = pAPEDecompress;

    // initialize the bit array
    m_pUnBitArray = CreateUnBitArray(pAPEDecompress, pAPEDecompress->GetInfo(APE_INFO_FILE_VERSION));
    
    if (m_pAPEDecompress->GetInfo(APE_INFO_FILE_VERSION) >= 3930)
        throw(0);

    m_pAntiPredictorX = CreateAntiPredictor(pAPEDecompress->GetInfo(APE_INFO_COMPRESSION_LEVEL), pAPEDecompress->GetInfo(APE_INFO_FILE_VERSION));
    m_pAntiPredictorY = CreateAntiPredictor(pAPEDecompress->GetInfo(APE_INFO_COMPRESSION_LEVEL), pAPEDecompress->GetInfo(APE_INFO_FILE_VERSION));
    
    m_pDataX = new int [pAPEDecompress->GetInfo(APE_INFO_BLOCKS_PER_FRAME) + 16];
    m_pDataY = new int [pAPEDecompress->GetInfo(APE_INFO_BLOCKS_PER_FRAME) + 16];
    m_pTempData = new int [pAPEDecompress->GetInfo(APE_INFO_BLOCKS_PER_FRAME) + 16];

    m_nBlocksProcessed = 0;
    
    // check to see if MMX is available
    m_bMMXAvailable = GetMMXAvailable();
    
}

CAPEDecompressCore::~CAPEDecompressCore()
{
    SAFE_DELETE(m_pUnBitArray)
        
    SAFE_DELETE(m_pAntiPredictorX)
    SAFE_DELETE(m_pAntiPredictorY)
    
    SAFE_ARRAY_DELETE(m_pDataX)
    SAFE_ARRAY_DELETE(m_pDataY)
    SAFE_ARRAY_DELETE(m_pTempData)
}

void CAPEDecompressCore::GenerateDecodedArrays(int nBlocks, int nSpecialCodes, int nFrameIndex, int nCPULoadBalancingFactor)
{
    CUnBitArray * pBitArray = (CUnBitArray *) m_pUnBitArray;
    
    if (m_pAPEDecompress->GetInfo(APE_INFO_CHANNELS) == 2)
    {
        if ((nSpecialCodes & SPECIAL_FRAME_LEFT_SILENCE) && (nSpecialCodes & SPECIAL_FRAME_RIGHT_SILENCE)) 
        {
            memset(m_pDataX, 0, nBlocks * 4);
            memset(m_pDataY, 0, nBlocks * 4);
        }
        else if (nSpecialCodes & SPECIAL_FRAME_PSEUDO_STEREO) 
        {
            GenerateDecodedArray(m_pDataX, nBlocks, nFrameIndex, m_pAntiPredictorX, nCPULoadBalancingFactor);
            memset(m_pDataY, 0, nBlocks * 4);
        }
        else 
        {
            GenerateDecodedArray(m_pDataX, nBlocks, nFrameIndex, m_pAntiPredictorX, nCPULoadBalancingFactor);
            GenerateDecodedArray(m_pDataY, nBlocks, nFrameIndex, m_pAntiPredictorY, nCPULoadBalancingFactor);
        }
    }
    else
    {
        if (nSpecialCodes & SPECIAL_FRAME_LEFT_SILENCE)
        {
            memset(m_pDataX, 0, nBlocks * 4);
        }
        else
        {
            GenerateDecodedArray(m_pDataX, nBlocks, nFrameIndex, m_pAntiPredictorX, nCPULoadBalancingFactor);
        }
    }
}


void CAPEDecompressCore::GenerateDecodedArray(int * Input_Array, uint32 Number_of_Elements, int Frame_Index, CAntiPredictor *pAntiPredictor, int CPULoadBalancingFactor)
{
    const int nFrameBytes = m_pAPEDecompress->GetInfo(APE_INFO_FRAME_BYTES, Frame_Index);

    // run the prediction sequence
    switch (m_pAPEDecompress->GetInfo(APE_INFO_COMPRESSION_LEVEL)) 
    {

#ifdef ENABLE_COMPRESSION_MODE_FAST
        case COMPRESSION_LEVEL_FAST:
            if (m_pAPEDecompress->GetInfo(APE_INFO_FILE_VERSION) < 3320)
            {
                m_pUnBitArray->GenerateArray(m_pTempData, Number_of_Elements, nFrameBytes);
                pAntiPredictor->AntiPredict(m_pTempData, Input_Array, Number_of_Elements);
            }
            else
            {
                m_pUnBitArray->GenerateArray(Input_Array, Number_of_Elements, nFrameBytes);
                pAntiPredictor->AntiPredict(Input_Array, NULL, Number_of_Elements);
            }

            break;
#endif // #ifdef ENABLE_COMPRESSION_MODE_FAST
            
#ifdef ENABLE_COMPRESSION_MODE_NORMAL
        
        case COMPRESSION_LEVEL_NORMAL:
        {
            // get the array from the bitstream
            m_pUnBitArray->GenerateArray(m_pTempData, Number_of_Elements, nFrameBytes);
            pAntiPredictor->AntiPredict(m_pTempData, Input_Array, Number_of_Elements);
            break;
        }

#endif // #ifdef ENABLE_COMPRESSION_MODE_NORMAL

#ifdef ENABLE_COMPRESSION_MODE_HIGH
        case COMPRESSION_LEVEL_HIGH:
            // get the array from the bitstream
            m_pUnBitArray->GenerateArray(m_pTempData, Number_of_Elements, nFrameBytes);
            pAntiPredictor->AntiPredict(m_pTempData, Input_Array, Number_of_Elements);
            break;
#endif // #ifdef ENABLE_COMPRESSION_MODE_HIGH

#ifdef ENABLE_COMPRESSION_MODE_EXTRA_HIGH
        case COMPRESSION_LEVEL_EXTRA_HIGH:
            
            unsigned int aryCoefficientsA[64], aryCoefficientsB[64], nNumberOfCoefficients;
            
            #define GET_COEFFICIENTS(NumberOfCoefficientsBits, ValueBits)                                            \
                nNumberOfCoefficients = m_pUnBitArray->DecodeValue(DECODE_VALUE_METHOD_X_BITS, NumberOfCoefficientsBits);        \
                for (unsigned int z = 0; z <= nNumberOfCoefficients; z++)                                            \
                {                                                                                                    \
                    aryCoefficientsA[z] = m_pUnBitArray->DecodeValue(DECODE_VALUE_METHOD_X_BITS, ValueBits);                    \
                    aryCoefficientsB[z] = m_pUnBitArray->DecodeValue(DECODE_VALUE_METHOD_X_BITS, ValueBits);                    \
                }                                                                                                    \

            if (m_pAPEDecompress->GetInfo(APE_INFO_FILE_VERSION) < 3320) 
            {
                GET_COEFFICIENTS(4, 6)
                m_pUnBitArray->GenerateArray(m_pTempData, Number_of_Elements, nFrameBytes);
                ((CAntiPredictorExtraHigh0000To3320 *) pAntiPredictor)->AntiPredict(m_pTempData, Input_Array, Number_of_Elements, nNumberOfCoefficients, &aryCoefficientsA[0], &aryCoefficientsB[0]);
            }
            else if (m_pAPEDecompress->GetInfo(APE_INFO_FILE_VERSION) < 3600) 
            {
                GET_COEFFICIENTS(3, 5)
                m_pUnBitArray->GenerateArray(m_pTempData, Number_of_Elements, nFrameBytes);
                ((CAntiPredictorExtraHigh3320To3600 *) pAntiPredictor)->AntiPredict(m_pTempData, Input_Array, Number_of_Elements, nNumberOfCoefficients, &aryCoefficientsA[0], &aryCoefficientsB[0]);
            }
            else if (m_pAPEDecompress->GetInfo(APE_INFO_FILE_VERSION) < 3700) 
            {
                GET_COEFFICIENTS(3, 6)
                m_pUnBitArray->GenerateArray(m_pTempData, Number_of_Elements, nFrameBytes);
                ((CAntiPredictorExtraHigh3600To3700 *) pAntiPredictor)->AntiPredict(m_pTempData, Input_Array, Number_of_Elements, nNumberOfCoefficients, &aryCoefficientsA[0], &aryCoefficientsB[0]);
            }
            else if (m_pAPEDecompress->GetInfo(APE_INFO_FILE_VERSION) < 3800) 
            {
                GET_COEFFICIENTS(3, 6)
                m_pUnBitArray->GenerateArray(m_pTempData, Number_of_Elements, nFrameBytes);
                ((CAntiPredictorExtraHigh3700To3800 *) pAntiPredictor)->AntiPredict(m_pTempData, Input_Array, Number_of_Elements, nNumberOfCoefficients, &aryCoefficientsA[0], &aryCoefficientsB[0]);
            }    
            else
            {
                m_pUnBitArray->GenerateArray(m_pTempData, Number_of_Elements, nFrameBytes);
                ((CAntiPredictorExtraHigh3800ToCurrent *) pAntiPredictor)->AntiPredict(m_pTempData, Input_Array, Number_of_Elements, m_bMMXAvailable, CPULoadBalancingFactor, m_pAPEDecompress->GetInfo(APE_INFO_FILE_VERSION));
            }
            
            break;
#endif // #ifdef ENABLE_COMPRESSION_MODE_EXTRA_HIGH
    }
}

#endif // #ifdef BACKWARDS_COMPATIBILITY

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人av午夜影院| 日韩精品乱码免费| 欧美成人午夜电影| 日韩欧美一级二级| 精品国产乱码久久久久久久久 | 91麻豆精品国产91久久久更新时间 | 色综合久久久久综合99| 99视频在线观看一区三区| 成人教育av在线| 99久久99久久精品国产片果冻 | 亚洲h精品动漫在线观看| 亚洲成av人**亚洲成av**| 亚洲国产精品欧美一二99| 亚洲欧美经典视频| 亚洲电影一区二区| 日本免费新一区视频| 美女在线一区二区| 狠狠色伊人亚洲综合成人| 国内精品在线播放| av影院午夜一区| 欧美日韩国产一级| 久久夜色精品国产欧美乱极品| 久久综合色之久久综合| 中文字幕欧美日本乱码一线二线| 最近日韩中文字幕| 亚洲成国产人片在线观看| 久久www免费人成看片高清| 国内精品在线播放| 在线视频你懂得一区二区三区| 欧美日韩你懂得| 欧美极品少妇xxxxⅹ高跟鞋 | 日韩一区二区三区观看| 337p日本欧洲亚洲大胆精品| 国产精品沙发午睡系列990531| 亚洲香肠在线观看| 国产综合色精品一区二区三区| 97se亚洲国产综合在线| 91精品国产综合久久蜜臀| 欧美国产1区2区| 日韩高清不卡在线| 91丨porny丨首页| 精品美女被调教视频大全网站| 欧美激情一区二区三区不卡| 亚洲成人动漫av| 成人性视频网站| 欧美一二区视频| 亚洲乱码国产乱码精品精可以看| 日韩精品电影一区亚洲| 91天堂素人约啪| 精品国产sm最大网站| 亚洲国产欧美一区二区三区丁香婷| 国内精品国产成人| 欧美一区二区国产| 亚洲乱码中文字幕综合| 韩日精品视频一区| 欧美精品xxxxbbbb| 亚洲美女屁股眼交| 国产ts人妖一区二区| 日韩欧美电影一二三| 亚洲v精品v日韩v欧美v专区 | 久久99这里只有精品| 一本到三区不卡视频| 久久久久久一级片| 狠狠色狠狠色合久久伊人| 337p亚洲精品色噜噜狠狠| 一区二区三区日本| 91久久久免费一区二区| 国产精品黄色在线观看| 国产一区不卡视频| 精品免费日韩av| 九色综合狠狠综合久久| 欧美一区二区视频免费观看| 亚洲成av人片一区二区三区| 色哦色哦哦色天天综合| 亚洲欧洲制服丝袜| 一本高清dvd不卡在线观看| 亚洲欧洲精品一区二区三区| 成人一区二区三区视频在线观看 | 在线看国产一区| 亚洲一区视频在线观看视频| 欧美影院一区二区| 亚洲一级电影视频| 777欧美精品| 另类人妖一区二区av| 欧美大度的电影原声| 久久91精品国产91久久小草| 久久午夜色播影院免费高清| 国产成人亚洲精品青草天美| 久久久精品免费网站| 国产91对白在线观看九色| 中文字幕中文字幕在线一区| 91亚洲精品乱码久久久久久蜜桃| 一区二区中文字幕在线| 欧美性大战久久| 蜜臀av一级做a爰片久久| 欧美一区二区三级| 国产成人在线网站| 亚洲欧美日本在线| 欧美一区二区视频在线观看2020| 美国毛片一区二区三区| 国产精品免费视频观看| 在线影院国内精品| 极品尤物av久久免费看| 国产精品第13页| 在线不卡免费欧美| 国产精品1区2区| 1000部国产精品成人观看| 日本高清不卡视频| 久久国产生活片100| 亚洲欧美中日韩| 日韩精品一区在线| 91香蕉视频黄| 精品一区二区三区在线播放| 蜜桃一区二区三区在线| 国产精品免费久久久久| 欧美浪妇xxxx高跟鞋交| 国产不卡视频在线播放| 五月综合激情婷婷六月色窝| 国产亚洲精品资源在线26u| 欧美色图第一页| 成人午夜激情影院| 欧美a级理论片| 一区二区免费在线播放| 久久久久久久电影| 91精品国产一区二区三区蜜臀| 国产69精品久久久久毛片| 蜜臀国产一区二区三区在线播放 | 国产不卡高清在线观看视频| 午夜精品久久一牛影视| 日本一区二区不卡视频| 精品国产精品网麻豆系列| 精品视频一区三区九区| 一本一道综合狠狠老| 国产精品1区二区.| 激情综合五月天| 老司机午夜精品99久久| 婷婷夜色潮精品综合在线| 一区二区三区日本| 亚洲日本一区二区三区| 中文字幕一区视频| 国产亚洲欧美一级| 久久婷婷色综合| 久久一留热品黄| 国产亚洲成aⅴ人片在线观看| 欧美一区二区播放| 欧美一区二区三区电影| 51精品久久久久久久蜜臀| 在线日韩av片| 一本大道综合伊人精品热热| 99久久婷婷国产| 91在线视频在线| 99这里只有精品| 91麻豆国产福利在线观看| 97精品国产露脸对白| 91美女在线视频| 欧美午夜精品久久久久久超碰| 91福利精品视频| 欧美日韩视频一区二区| 欧美一区二区三区在线看| 亚洲欧美日本韩国| 亚洲综合在线观看视频| 亚洲国产你懂的| 久久黄色级2电影| 高清免费成人av| 一本色道亚洲精品aⅴ| 91视频免费播放| 欧美日韩一区久久| 日韩精品在线一区| 欧美国产一区视频在线观看| 中文字幕一区二区视频| 亚洲精选一二三| 日本最新不卡在线| 国产99精品国产| 91国偷自产一区二区开放时间 | 国产在线日韩欧美| 成人丝袜高跟foot| 欧美在线短视频| 日韩欧美精品在线| 国产精品亲子乱子伦xxxx裸| 尤物视频一区二区| 麻豆91在线播放免费| 高清不卡一区二区在线| 欧美亚洲另类激情小说| 精品国产凹凸成av人网站| 欧美极品美女视频| 日韩成人免费看| proumb性欧美在线观看| 欧美日韩美少妇| 国产精品丝袜一区| 午夜日韩在线电影| av在线不卡观看免费观看| 日韩午夜中文字幕| 伊人一区二区三区| 国产+成+人+亚洲欧洲自线| 欧美午夜在线观看| 日本一区二区三区四区在线视频| 亚洲不卡一区二区三区| 成人一二三区视频| 欧美一区二区三区免费在线看 | 三级成人在线视频|