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

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

?? adpcm.c.svn-base

?? ffmpeg最新源碼
?? SVN-BASE
?? 第 1 頁 / 共 5 頁
字號:
        if(st){            c->status[1].predictor= (int16_t)(src[0] + (src[1]<<8)); src+=2;        }        c->status[0].step_index= (int16_t)(src[0] + (src[1]<<8)); src+=2;        if(st){            c->status[1].step_index= (int16_t)(src[0] + (src[1]<<8)); src+=2;        }        if (cs->step_index < 0) cs->step_index = 0;        if (cs->step_index > 88) cs->step_index = 88;        m= (buf_size - (src - buf))>>st;        for(i=0; i<m; i++) {            *samples++ = adpcm_ima_expand_nibble(&c->status[0], src[i] & 0x0F, 4);            if (st)                *samples++ = adpcm_ima_expand_nibble(&c->status[1], src[i+m] & 0x0F, 4);            *samples++ = adpcm_ima_expand_nibble(&c->status[0], src[i] >> 4, 4);            if (st)                *samples++ = adpcm_ima_expand_nibble(&c->status[1], src[i+m] >> 4, 4);        }        src += m<<st;        break;    case CODEC_ID_ADPCM_MS:        if (avctx->block_align != 0 && buf_size > avctx->block_align)            buf_size = avctx->block_align;        n = buf_size - 7 * avctx->channels;        if (n < 0)            return -1;        block_predictor[0] = av_clip(*src++, 0, 7);        block_predictor[1] = 0;        if (st)            block_predictor[1] = av_clip(*src++, 0, 7);        c->status[0].idelta = (int16_t)((*src & 0xFF) | ((src[1] << 8) & 0xFF00));        src+=2;        if (st){            c->status[1].idelta = (int16_t)((*src & 0xFF) | ((src[1] << 8) & 0xFF00));            src+=2;        }        c->status[0].coeff1 = AdaptCoeff1[block_predictor[0]];        c->status[0].coeff2 = AdaptCoeff2[block_predictor[0]];        c->status[1].coeff1 = AdaptCoeff1[block_predictor[1]];        c->status[1].coeff2 = AdaptCoeff2[block_predictor[1]];        c->status[0].sample1 = ((*src & 0xFF) | ((src[1] << 8) & 0xFF00));        src+=2;        if (st) c->status[1].sample1 = ((*src & 0xFF) | ((src[1] << 8) & 0xFF00));        if (st) src+=2;        c->status[0].sample2 = ((*src & 0xFF) | ((src[1] << 8) & 0xFF00));        src+=2;        if (st) c->status[1].sample2 = ((*src & 0xFF) | ((src[1] << 8) & 0xFF00));        if (st) src+=2;        *samples++ = c->status[0].sample1;        if (st) *samples++ = c->status[1].sample1;        *samples++ = c->status[0].sample2;        if (st) *samples++ = c->status[1].sample2;        for(;n>0;n--) {            *samples++ = adpcm_ms_expand_nibble(&c->status[0 ], src[0] >> 4  );            *samples++ = adpcm_ms_expand_nibble(&c->status[st], src[0] & 0x0F);            src ++;        }        break;    case CODEC_ID_ADPCM_IMA_DK4:        if (avctx->block_align != 0 && buf_size > avctx->block_align)            buf_size = avctx->block_align;        c->status[0].predictor = (int16_t)(src[0] | (src[1] << 8));        c->status[0].step_index = src[2];        src += 4;        *samples++ = c->status[0].predictor;        if (st) {            c->status[1].predictor = (int16_t)(src[0] | (src[1] << 8));            c->status[1].step_index = src[2];            src += 4;            *samples++ = c->status[1].predictor;        }        while (src < buf + buf_size) {            /* take care of the top nibble (always left or mono channel) */            *samples++ = adpcm_ima_expand_nibble(&c->status[0],                src[0] >> 4, 3);            /* take care of the bottom nibble, which is right sample for             * stereo, or another mono sample */            if (st)                *samples++ = adpcm_ima_expand_nibble(&c->status[1],                    src[0] & 0x0F, 3);            else                *samples++ = adpcm_ima_expand_nibble(&c->status[0],                    src[0] & 0x0F, 3);            src++;        }        break;    case CODEC_ID_ADPCM_IMA_DK3:        if (avctx->block_align != 0 && buf_size > avctx->block_align)            buf_size = avctx->block_align;        if(buf_size + 16 > (samples_end - samples)*3/8)            return -1;        c->status[0].predictor = (int16_t)(src[10] | (src[11] << 8));        c->status[1].predictor = (int16_t)(src[12] | (src[13] << 8));        c->status[0].step_index = src[14];        c->status[1].step_index = src[15];        /* sign extend the predictors */        src += 16;        diff_channel = c->status[1].predictor;        /* the DK3_GET_NEXT_NIBBLE macro issues the break statement when         * the buffer is consumed */        while (1) {            /* for this algorithm, c->status[0] is the sum channel and             * c->status[1] is the diff channel */            /* process the first predictor of the sum channel */            DK3_GET_NEXT_NIBBLE();            adpcm_ima_expand_nibble(&c->status[0], nibble, 3);            /* process the diff channel predictor */            DK3_GET_NEXT_NIBBLE();            adpcm_ima_expand_nibble(&c->status[1], nibble, 3);            /* process the first pair of stereo PCM samples */            diff_channel = (diff_channel + c->status[1].predictor) / 2;            *samples++ = c->status[0].predictor + c->status[1].predictor;            *samples++ = c->status[0].predictor - c->status[1].predictor;            /* process the second predictor of the sum channel */            DK3_GET_NEXT_NIBBLE();            adpcm_ima_expand_nibble(&c->status[0], nibble, 3);            /* process the second pair of stereo PCM samples */            diff_channel = (diff_channel + c->status[1].predictor) / 2;            *samples++ = c->status[0].predictor + c->status[1].predictor;            *samples++ = c->status[0].predictor - c->status[1].predictor;        }        break;    case CODEC_ID_ADPCM_IMA_WS:        /* no per-block initialization; just start decoding the data */        while (src < buf + buf_size) {            if (st) {                *samples++ = adpcm_ima_expand_nibble(&c->status[0],                    src[0] >> 4  , 3);                *samples++ = adpcm_ima_expand_nibble(&c->status[1],                    src[0] & 0x0F, 3);            } else {                *samples++ = adpcm_ima_expand_nibble(&c->status[0],                    src[0] >> 4  , 3);                *samples++ = adpcm_ima_expand_nibble(&c->status[0],                    src[0] & 0x0F, 3);            }            src++;        }        break;    case CODEC_ID_ADPCM_XA:        while (buf_size >= 128) {            xa_decode(samples, src, &c->status[0], &c->status[1],                avctx->channels);            src += 128;            samples += 28 * 8;            buf_size -= 128;        }        break;    case CODEC_ID_ADPCM_IMA_EA_EACS:        samples_in_chunk = bytestream_get_le32(&src) >> (1-st);        if (samples_in_chunk > buf_size-4-(8<<st)) {            src += buf_size - 4;            break;        }        for (i=0; i<=st; i++)            c->status[i].step_index = bytestream_get_le32(&src);        for (i=0; i<=st; i++)            c->status[i].predictor  = bytestream_get_le32(&src);        for (; samples_in_chunk; samples_in_chunk--, src++) {            *samples++ = adpcm_ima_expand_nibble(&c->status[0],  *src>>4,   3);            *samples++ = adpcm_ima_expand_nibble(&c->status[st], *src&0x0F, 3);        }        break;    case CODEC_ID_ADPCM_IMA_EA_SEAD:        for (; src < buf+buf_size; src++) {            *samples++ = adpcm_ima_expand_nibble(&c->status[0], src[0] >> 4, 6);            *samples++ = adpcm_ima_expand_nibble(&c->status[st],src[0]&0x0F, 6);        }        break;    case CODEC_ID_ADPCM_EA:        samples_in_chunk = AV_RL32(src);        if (samples_in_chunk >= ((buf_size - 12) * 2)) {            src += buf_size;            break;        }        src += 4;        current_left_sample = (int16_t)AV_RL16(src);        src += 2;        previous_left_sample = (int16_t)AV_RL16(src);        src += 2;        current_right_sample = (int16_t)AV_RL16(src);        src += 2;        previous_right_sample = (int16_t)AV_RL16(src);        src += 2;        for (count1 = 0; count1 < samples_in_chunk/28;count1++) {            coeff1l = ea_adpcm_table[ *src >> 4       ];            coeff2l = ea_adpcm_table[(*src >> 4  ) + 4];            coeff1r = ea_adpcm_table[*src & 0x0F];            coeff2r = ea_adpcm_table[(*src & 0x0F) + 4];            src++;            shift_left  = (*src >> 4  ) + 8;            shift_right = (*src & 0x0F) + 8;            src++;            for (count2 = 0; count2 < 28; count2++) {                next_left_sample  = (int32_t)((*src & 0xF0) << 24) >> shift_left;                next_right_sample = (int32_t)((*src & 0x0F) << 28) >> shift_right;                src++;                next_left_sample = (next_left_sample +                    (current_left_sample * coeff1l) +                    (previous_left_sample * coeff2l) + 0x80) >> 8;                next_right_sample = (next_right_sample +                    (current_right_sample * coeff1r) +                    (previous_right_sample * coeff2r) + 0x80) >> 8;                previous_left_sample = current_left_sample;                current_left_sample = av_clip_int16(next_left_sample);                previous_right_sample = current_right_sample;                current_right_sample = av_clip_int16(next_right_sample);                *samples++ = (unsigned short)current_left_sample;                *samples++ = (unsigned short)current_right_sample;            }        }        break;    case CODEC_ID_ADPCM_EA_MAXIS_XA:        for(channel = 0; channel < avctx->channels; channel++) {            for (i=0; i<2; i++)                coeff[channel][i] = ea_adpcm_table[(*src >> 4) + 4*i];            shift[channel] = (*src & 0x0F) + 8;            src++;        }        for (count1 = 0; count1 < (buf_size - avctx->channels) / avctx->channels; count1++) {            for(i = 4; i >= 0; i-=4) { /* Pairwise samples LL RR (st) or LL LL (mono) */                for(channel = 0; channel < avctx->channels; channel++) {                    int32_t sample = (int32_t)(((*(src+channel) >> i) & 0x0F) << 0x1C) >> shift[channel];                    sample = (sample +                             c->status[channel].sample1 * coeff[channel][0] +                             c->status[channel].sample2 * coeff[channel][1] + 0x80) >> 8;                    c->status[channel].sample2 = c->status[channel].sample1;                    c->status[channel].sample1 = av_clip_int16(sample);                    *samples++ = c->status[channel].sample1;                }            }            src+=avctx->channels;        }        break;    case CODEC_ID_ADPCM_EA_R1:    case CODEC_ID_ADPCM_EA_R2:    case CODEC_ID_ADPCM_EA_R3: {        /* channel numbering           2chan: 0=fl, 1=fr           4chan: 0=fl, 1=rl, 2=fr, 3=rr           6chan: 0=fl, 1=c,  2=fr, 3=rl,  4=rr, 5=sub */        const int big_endian = avctx->codec->id == CODEC_ID_ADPCM_EA_R3;        int32_t previous_sample, current_sample, next_sample;        int32_t coeff1, coeff2;        uint8_t shift;        unsigned int channel;        uint16_t *samplesC;        const uint8_t *srcC;        samples_in_chunk = (big_endian ? bytestream_get_be32(&src)                                       : bytestream_get_le32(&src)) / 28;        if (samples_in_chunk > UINT32_MAX/(28*avctx->channels) ||            28*samples_in_chunk*avctx->channels > samples_end-samples) {            src += buf_size - 4;            break;        }        for (channel=0; channel<avctx->channels; channel++) {            srcC = src + (big_endian ? bytestream_get_be32(&src)                                     : bytestream_get_le32(&src))                       + (avctx->channels-channel-1) * 4;            samplesC = samples + channel;            if (avctx->codec->id == CODEC_ID_ADPCM_EA_R1) {                current_sample  = (int16_t)bytestream_get_le16(&srcC);                previous_sample = (int16_t)bytestream_get_le16(&srcC);            } else {                current_sample  = c->status[channel].predictor;                previous_sample = c->status[channel].prev_sample;            }            for (count1=0; count1<samples_in_chunk; count1++) {                if (*srcC == 0xEE) {  /* only seen in R2 and R3 */                    srcC++;                    current_sample  = (int16_t)bytestream_get_be16(&srcC);                    previous_sample = (int16_t)bytestream_get_be16(&srcC);                    for (count2=0; count2<28; count2++) {                        *samplesC = (int16_t)bytestream_get_be16(&srcC);                        samplesC += avctx->channels;                    }                } else {                    coeff1 = ea_adpcm_table[ *srcC>>4     ];                    coeff2 = ea_adpcm_table[(*srcC>>4) + 4];                    shift = (*srcC++ & 0x0F) + 8;                    for (count2=0; count2<28; count2++) {                        if (count2 & 1)                            next_sample = (int32_t)((*srcC++ & 0x0F) << 28) >> shift;                        else                            next_sample = (int32_t)((*srcC   & 0xF0) << 24) >> shift;                        next_sample += (current_sample  * coeff1) +                                       (previous_sample * coeff2);                        next_sample = av_clip_int16(next_sample >> 8);                        previous_sample = current_sample;                        current_sample  = next_sample;                        *samplesC = current_sample;                        samplesC += avctx->channels;                    }                }            }            if (avctx->codec->id != CODEC_ID_ADPCM_EA_R1) {

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久精品人人爽人人爽| 欧美色视频一区| 久久国产乱子精品免费女| 亚洲超碰精品一区二区| 亚洲综合在线免费观看| 国产精品国产三级国产有无不卡 | 91免费国产在线观看| 亚洲欧美国产77777| 欧美一区二区免费视频| 6080yy午夜一二三区久久| 亚洲美女在线一区| 黄网站免费久久| 另类欧美日韩国产在线| 亚洲综合一区二区| 日本一区二区三区免费乱视频| 欧美久久久影院| 日韩精品中文字幕一区二区三区| 91女厕偷拍女厕偷拍高清| 亚洲影视在线观看| 国产亚洲1区2区3区| 99re视频这里只有精品| 亚洲综合图片区| 日韩精品中文字幕在线不卡尤物| 成人激情小说网站| 国产一区二区在线视频| 国产精品一二三在| 欧美日韩国产中文| 91精品国产综合久久久久久漫画 | 丁香婷婷综合五月| 亚洲欧美另类久久久精品| 国产欧美日韩一区二区三区在线观看| av高清久久久| 免费在线观看一区二区三区| 一区二区在线看| 亚洲国产精华液网站w| 91精品国产色综合久久ai换脸 | 色哟哟一区二区三区| 久久99精品国产91久久来源 | 欧美综合天天夜夜久久| 色综合久久综合网欧美综合网 | 久久超碰97中文字幕| 国产欧美一区二区三区在线看蜜臀| 色婷婷综合激情| 自拍偷拍亚洲欧美日韩| 26uuu亚洲综合色欧美| 4hu四虎永久在线影院成人| 欧美电视剧在线观看完整版| 国产乱色国产精品免费视频| 成人av免费在线观看| 国产精品乱码一区二三区小蝌蚪| 中文字幕国产一区| 美女脱光内衣内裤视频久久网站 | 中文字幕亚洲视频| 国产亚洲成aⅴ人片在线观看| 亚洲国产精品精华液2区45| 亚洲一线二线三线久久久| 麻豆精品新av中文字幕| 日本道精品一区二区三区| 精品一区二区三区的国产在线播放| 成人午夜短视频| 欧美色网站导航| 国产欧美一区二区精品性色| 夜夜夜精品看看| 成人午夜av在线| 日韩一级二级三级精品视频| 亚洲精品乱码久久久久久日本蜜臀| 青草av.久久免费一区| 99国产精品国产精品毛片| 欧美va天堂va视频va在线| 亚洲欧美二区三区| 国产宾馆实践打屁股91| 欧美一区二区视频在线观看2020 | 欧美三级在线视频| 国产精品久久久久久久久快鸭 | av激情综合网| 精品国产制服丝袜高跟| 午夜精品视频在线观看| 一本色道亚洲精品aⅴ| 99久久久国产精品| 国产福利一区二区三区视频在线| 国产99精品国产| 一本到不卡免费一区二区| 性做久久久久久免费观看| 91国偷自产一区二区三区观看| 最新高清无码专区| 午夜视频在线观看一区| 日本高清免费不卡视频| 国产精品色哟哟| 欧美日韩国产免费一区二区| 亚洲欧美色图小说| 97久久超碰精品国产| 国产成人av一区二区三区在线 | 色欧美片视频在线观看| 国产精品美女久久久久久久| 91在线看国产| 国产成人av在线影院| 久久久91精品国产一区二区精品| 狠狠色综合播放一区二区| 日韩欧美国产一区二区三区| 久久国产精品色婷婷| 2023国产精品自拍| 成人激情图片网| 一级中文字幕一区二区| 91精品蜜臀在线一区尤物| 国产黑丝在线一区二区三区| 国产乱人伦精品一区二区在线观看 | 亚洲成人午夜影院| 欧美日韩日日摸| 日韩高清欧美激情| 日韩一区二区三区在线| 久久99日本精品| 国产亚洲成av人在线观看导航| 国产精品一区二区在线观看不卡| 国产午夜精品理论片a级大结局| 国产精品亚洲第一区在线暖暖韩国| 久久免费美女视频| 国产福利91精品一区| 国产精品你懂的| 日本黄色一区二区| 视频一区在线视频| 99久久精品国产一区二区三区| 亚洲国产精品自拍| 中文字幕在线观看一区| 亚洲精品一区二区三区蜜桃下载 | 亚洲在线中文字幕| 亚洲国产一区二区三区| 夜夜嗨av一区二区三区| 天堂久久久久va久久久久| 久久久久九九视频| xnxx国产精品| 一区二区激情小说| 国产黑丝在线一区二区三区| 91蝌蚪porny| 在线观看网站黄不卡| 成人白浆超碰人人人人| 玉足女爽爽91| 国产精品麻豆欧美日韩ww| 成人性生交大片免费看视频在线| 亚洲成人在线网站| 亚洲欧洲国产日韩| 精品国产91九色蝌蚪| 欧美va在线播放| 日韩精品一区在线观看| 成人性生交大合| 国产成人精品免费看| 久久欧美中文字幕| 亚洲欧洲日产国码二区| 亚洲一区二区三区四区在线免费观看| 亚洲大片在线观看| 精品在线视频一区| 91视频免费观看| 欧美老女人第四色| 欧美日韩成人在线一区| 日韩精品一区国产麻豆| 国产精品成人一区二区艾草| 久久精品亚洲精品国产欧美kt∨| 中文成人av在线| 亚洲精品日韩综合观看成人91| 自拍偷拍亚洲综合| 国产高清视频一区| 91色porny| 欧美一级淫片007| 久久久久久久性| 国产在线精品免费| 国产老肥熟一区二区三区| www.亚洲免费av| 欧美日韩国产大片| 精品国产91亚洲一区二区三区婷婷| 久久久久一区二区三区四区| 亚洲永久免费视频| 日韩中文字幕区一区有砖一区| 亚洲尤物在线视频观看| 国产精品亚洲专一区二区三区| 欧美变态口味重另类| 午夜精品视频一区| 99麻豆久久久国产精品免费| 欧美一级生活片| 午夜在线电影亚洲一区| 国产91富婆露脸刺激对白| 7777精品伊人久久久大香线蕉经典版下载| 日日夜夜免费精品| 日韩精品最新网址| 日韩精品视频网| 日韩欧美在线不卡| 日本电影亚洲天堂一区| 国产一区二区福利| 日本不卡一区二区三区| 日韩av中文字幕一区二区| 亚洲私人黄色宅男| 欧美极品少妇xxxxⅹ高跟鞋| 欧美一区二区三区啪啪| 欧美日本一区二区在线观看| 色八戒一区二区三区| 成人av免费观看| 国产乱妇无码大片在线观看| 久久丁香综合五月国产三级网站 | 亚洲欧美一区二区三区国产精品| 久久人人爽爽爽人久久久| 欧美一卡二卡三卡| 3d动漫精品啪啪一区二区竹菊|