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

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

?? t264enc.c

?? 經(jīng)過開源的H.264壓縮算法代碼
?? C
?? 第 1 頁 / 共 3 頁
字號:
                    memset(&dst[t->stride + EDGED_WIDTH + 2], src[t->stride - 1 + 3 + 2], EDGED_WIDTH - 2);
                    dst += t->edged_stride;
                    src += t->edged_stride;
                }
                // top
                dst = f->Y[3] - EDGED_HEIGHT * t->edged_stride - EDGED_WIDTH;
                src = f->Y[3] - EDGED_WIDTH;
                for(i = 0 ; i < EDGED_HEIGHT ; i ++)
                {
                    memcpy(dst, src, t->edged_stride);
                    dst += t->edged_stride;
                }
                // bottom
                src = f->Y[3] + (t->height - 1) * t->edged_stride - EDGED_WIDTH;
                dst = src + t->edged_stride;
                for(i = 0 ; i < EDGED_HEIGHT ; i ++)
                {
                    memcpy(dst, src, t->edged_stride);
                    dst += t->edged_stride;
                }
            }
        }
        else
        {
            src_offset = - 3 * t->edged_stride - 3;
            width      = t->width + 3 + 2;
            height     = t->height + 3 + 2;
            t->interpolate_halfpel_hv(f->Y[0] + src_offset, t->edged_stride, f->Y[3] + src_offset, t->edged_stride, width, height);
            // extend border
            {
                uint8_t* src, *dst;
                int32_t i;
                // left & right
                dst = f->Y[3] - 3 * t->edged_stride - EDGED_WIDTH;
                src = f->Y[3] - 3 * t->edged_stride - 3;
                for(i = 0 ; i < t->height + 3 + 2 ; i ++)
                {
                    // left
                    memset(dst, src[0], EDGED_WIDTH - 3);
                    // right
                    memset(&dst[t->stride + EDGED_WIDTH + 2], src[t->stride - 1 + 3 + 2], EDGED_WIDTH - 2);
                    dst += t->edged_stride;
                    src += t->edged_stride;
                }
                // top
                dst = f->Y[3] - EDGED_HEIGHT * t->edged_stride - EDGED_WIDTH;
                src = f->Y[3] - 3 * t->edged_stride - EDGED_WIDTH;
                for(i = 0 ; i < EDGED_HEIGHT - 3 ; i ++)
                {
                    memcpy(dst, src, t->edged_stride);
                    dst += t->edged_stride;
                }
                // bottom
                src = f->Y[3] + (t->height + 2 - 1) * t->edged_stride - EDGED_WIDTH;
                dst = src + t->edged_stride;
                for(i = 0 ; i < EDGED_HEIGHT - 2 ; i ++)
                {
                    memcpy(dst, src, t->edged_stride);
                    dst += t->edged_stride;
                }
            }
        }
    }
}


void
T264_init_cpu(T264_t* t)
{

    t->pred16x16[Intra_16x16_TOP]    = T264_predict_16x16_mode_0_c;
    t->pred16x16[Intra_16x16_LEFT]   = T264_predict_16x16_mode_1_c;
    t->pred16x16[Intra_16x16_DC]     = T264_predict_16x16_mode_2_c;
    t->pred16x16[Intra_16x16_PLANE]  = T264_predict_16x16_mode_3_c;
    t->pred16x16[Intra_16x16_DCTOP]  = T264_predict_16x16_mode_20_c;
    t->pred16x16[Intra_16x16_DCLEFT] = T264_predict_16x16_mode_21_c;
    t->pred16x16[Intra_16x16_DC128]  = T264_predict_16x16_mode_22_c;
    
    t->pred8x8[Intra_8x8_TOP]    = T264_predict_8x8_mode_0_c;
    t->pred8x8[Intra_8x8_LEFT]   = T264_predict_8x8_mode_1_c;
    t->pred8x8[Intra_8x8_DC]     = T264_predict_8x8_mode_2_c;
    t->pred8x8[Intra_8x8_PLANE]  = T264_predict_8x8_mode_3_c;
    t->pred8x8[Intra_8x8_DCTOP]  = T264_predict_8x8_mode_20_c;
    t->pred8x8[Intra_8x8_DCLEFT] = T264_predict_8x8_mode_21_c;
    t->pred8x8[Intra_8x8_DC128]  = T264_predict_8x8_mode_22_c;

    t->pred4x4[Intra_4x4_TOP]    = T264_predict_4x4_mode_0_c;
    t->pred4x4[Intra_4x4_LEFT]   = T264_predict_4x4_mode_1_c;
    t->pred4x4[Intra_4x4_DC]     = T264_predict_4x4_mode_2_c;
    t->pred4x4[Intra_4x4_DCTOP]  = T264_predict_4x4_mode_20_c;
    t->pred4x4[Intra_4x4_DCLEFT] = T264_predict_4x4_mode_21_c;
    t->pred4x4[Intra_4x4_DC128]  = T264_predict_4x4_mode_22_c;

    t->pred4x4[Intra_4x4_DIAGONAL_DOWNLEFT]  = T264_predict_4x4_mode_3_c;
    t->pred4x4[Intra_4x4_DIAGONAL_DOWNRIGHT]  = T264_predict_4x4_mode_4_c;
    t->pred4x4[Intra_4x4_VERTICAL_RIGHT]  = T264_predict_4x4_mode_5_c;
    t->pred4x4[Intra_4x4_HORIZONTAL_DOWN]  = T264_predict_4x4_mode_6_c;
    t->pred4x4[Intra_4x4_VERTICAL_LEFT]  = T264_predict_4x4_mode_7_c;
    t->pred4x4[Intra_4x4_HORIZONTAL_UP]  = T264_predict_4x4_mode_8_c;

    if (t->flags & USE_SAD)
    {
        t->cmp[MB_16x16] = T264_sad_u_16x16_c;
        t->cmp[MB_16x8]  = T264_sad_u_16x8_c;
        t->cmp[MB_8x16]  = T264_sad_u_8x16_c;
        t->cmp[MB_8x8]   = T264_sad_u_8x8_c;
        t->cmp[MB_8x4]   = T264_sad_u_8x4_c;
        t->cmp[MB_4x8]   = T264_sad_u_4x8_c;
        t->cmp[MB_4x4]   = T264_sad_u_4x4_c;
    }
    else
    {
        t->cmp[MB_16x16] = T264_satd_u_16x16_c;
        t->cmp[MB_16x8]  = T264_satd_u_16x8_c;
        t->cmp[MB_8x16]  = T264_satd_u_8x16_c;
        t->cmp[MB_8x8]   = T264_satd_u_8x8_c;
        t->cmp[MB_8x4]   = T264_satd_u_8x4_c;
        t->cmp[MB_4x8]   = T264_satd_u_4x8_c;
        t->cmp[MB_4x4]   = T264_satd_u_4x4_c;
    }

    t->sad[MB_16x16] = T264_sad_u_16x16_c;
    t->sad[MB_16x8]  = T264_sad_u_16x8_c;
    t->sad[MB_8x16]  = T264_sad_u_8x16_c;
    t->sad[MB_8x8]   = T264_sad_u_8x8_c;
    t->sad[MB_8x4]   = T264_sad_u_8x4_c;
    t->sad[MB_4x8]   = T264_sad_u_4x8_c;
    t->sad[MB_4x4]   = T264_sad_u_4x4_c;
    t->fdct4x4   = dct4x4_c;
    t->fdct4x4dc = dct4x4dc_c;
    t->fdct2x2dc = dct2x2dc_c;
    t->idct4x4   = idct4x4_c;
    t->idct4x4dc = idct4x4dc_c;
    t->idct2x2dc = idct2x2dc_c;

    t->quant4x4    = quant4x4_c;
    t->quant4x4dc  = quant4x4dc_c;
    t->quant2x2dc  = quant2x2dc_c;
    t->iquant4x4   = iquant4x4_c;
    t->iquant4x4dc = iquant4x4dc_c;
    t->iquant2x2dc = iquant2x2dc_c;

    t->expand8to16   = expand8to16_c;
    t->contract16to8 = contract16to8_c;
    t->contract16to8add = contract16to8add_c;
    t->expand8to16sub   = expand8to16sub_c;
    t->memcpy_stride_u = memcpy_stride_u_c;
    t->eighth_pixel_mc_u = T264_eighth_pixel_mc_u_c;

    t->interpolate_halfpel_h = interpolate_halfpel_h_c;
    t->interpolate_halfpel_v = interpolate_halfpel_v_c;
    t->interpolate_halfpel_hv = interpolate_halfpel_hv_c;

    //t->pixel_avg = T264_pixel_avg_c;  //modify by wushangyun for pia optimization
    t->pia[MB_16x16] = T264_pia_u_16x16_c;
    t->pia[MB_16x8]  = T264_pia_u_16x8_c;
    t->pia[MB_8x16]  = T264_pia_u_8x16_c;
    t->pia[MB_8x8]   = T264_pia_u_8x8_c;
    t->pia[MB_8x4]   = T264_pia_u_8x4_c;
    t->pia[MB_4x8]   = T264_pia_u_4x8_c;
    t->pia[MB_4x4]   = T264_pia_u_4x4_c;
    t->pia[MB_2x2]   = T264_pia_u_2x2_c;

    t->T264_satd_16x16_u = T264_satd_i16x16_u_c;
    
    
    // flags relative
    if (t->flags & USE_FULLSEARCH)
        t->search = T264_spiral_search_full;
    else if (t->flags & USE_DIAMONDSEACH)
        t->search = T264_search;
    else
        t->search = T264_search_full; 
}

static uint32_t
write_dst(uint8_t* src, int32_t nal_pos[4], int32_t nal_num, uint8_t* dst, int32_t dst_size)
{
    int32_t i, j, n;
    int32_t count;
    int32_t nal_len;

    n = 0;
    for(i = 0 ; i < nal_num - 1; i ++)
    {
        nal_len = nal_pos[i + 1] - nal_pos[i];
        
        // start code 00 00 00 01
        dst[n ++] = src[0];
        dst[n ++] = src[1];
        dst[n ++] = src[2];
        dst[n ++] = src[3];
        count = 0;
        for(j = 4 ; j < nal_len - 1; j ++)
        {
            if (src[j] == 0)
            {
                count ++;
                if (count >= 2 && src[j + 1] <= 3)
                {
                    dst[n ++] = 0;
                    dst[n ++] = 3;
                    count = 0;
                    continue;
                }
            }
            else
            {
                count = 0;
            }
            dst[n ++] = src[j];
        }
        dst[n ++] = src[j];
        src += nal_len;
    }

    return n;
}

///////////////////////////////////////////////////////////
// interface
T264_t*
T264_open(T264_param_t* para)
{
    T264_t* t;
    int32_t i;

    //
    // TODO: here check the input param if it is valid
    //
    if (para->flags & USE_FORCEBLOCKSIZE)
        para->flags |= USE_SUBBLOCK;
    if (para->flags & USE_QUARTPEL)
        para->flags |= USE_HALFPEL;

    t = T264_malloc(sizeof(T264_t), CACHE_SIZE);
    memset(t, 0, sizeof(T264_t));

    t->mb_width  = para->width >> 4;
    t->mb_height = para->height >> 4;
    t->mb_stride = t->mb_width;
    t->width  = t->mb_width << 4;
    t->height = t->mb_height << 4;
    t->edged_width = t->width + 2 * EDGED_WIDTH;
    t->edged_height = t->height + 2 * EDGED_HEIGHT;
    t->qp_y   = para->qp;
    t->flags  = para->flags;

    t->stride    = t->width;
    t->stride_uv = t->width >> 1;
    t->edged_stride = t->edged_width;
    t->edged_stride_uv = t->edged_width >> 1;

    t->bs = T264_malloc(sizeof(bs_t), CACHE_SIZE);
    t->bs_buf = T264_malloc(t->width * t->height << 1, CACHE_SIZE);
    para->direct_flag = 1;  /* force direct mode */
    if (para->b_num)
        para->ref_num ++;

    for(i = 0 ; i < para->ref_num + 1 ; i ++)
    {
        uint8_t* p = T264_malloc(t->edged_width * t->edged_height + (t->edged_width * t->edged_height >> 1), CACHE_SIZE);
        t->refn[i].Y[0] = p + EDGED_HEIGHT * t->edged_width + EDGED_WIDTH;
        t->refn[i].U = p + t->edged_width * t->edged_height + (t->edged_width * EDGED_HEIGHT >> 2) + (EDGED_WIDTH >> 1);
        t->refn[i].V = p + t->edged_width * t->edged_height + (t->edged_width * t->edged_height >> 2) + (t->edged_width * EDGED_HEIGHT >> 2) + (EDGED_WIDTH >> 1);
        t->refn[i].mb = T264_malloc(t->mb_height * t->mb_width * sizeof(T264_mb_context_t), CACHE_SIZE);
        p = T264_malloc(t->edged_width * t->edged_height * 3, CACHE_SIZE);
        t->refn[i].Y[1] = p + EDGED_HEIGHT * t->edged_width + EDGED_WIDTH;
        t->refn[i].Y[2] = t->refn[i].Y[1] + t->edged_width * t->edged_height;
        t->refn[i].Y[3] = t->refn[i].Y[2] + t->edged_width * t->edged_height;
    }
    for(i = 0 ; i < para->b_num ; i ++)
    {
        t->pending_bframes[i].Y[0] = T264_malloc(t->width * t->height + (t->width * t->height >> 1), CACHE_SIZE);
    }

    t->param = *para;
    t->idr_pic_id = -1;
    t->frame_id = 0;
    t->last_i_frame_id = 0;

    T264_init_cpu(t);    
    
    if (t->flags & USE_EXTRASUBPELSEARCH)
        t->subpel_pts = 8;
    else
        t->subpel_pts = 4;

    return t;
}

void
T264_close(T264_t* t)
{
    int32_t i;

    for(i = 0 ; i < t->param.ref_num + 1 ; i ++)
    {
        T264_free(t->refn[i].Y[0] - (EDGED_HEIGHT * t->edged_width + EDGED_WIDTH));
        T264_free(t->refn[i].mb);
        T264_free(t->refn[i].Y[1] - (EDGED_HEIGHT * t->edged_width + EDGED_WIDTH));
    }

    for(i = 0 ; i < t->plug_num ; i ++)
    {
        t->plugins[i].close(t, &t->plugins[i]);
    }

    for(i = 0 ; i < t->param.b_num ; i ++)
    {
        T264_free(t->pending_bframes[i].Y[0]);
    }
    T264_free(t->bs_buf);
    T264_free(t->bs);

    T264_free(t);	
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久99久久| 色综合中文字幕国产| 亚洲午夜免费福利视频| 国产精品久久久久久久久免费桃花 | 国产精品久久久久久一区二区三区| 3atv一区二区三区| 欧美精品一二三| 日韩午夜三级在线| 久久久精品免费观看| 亚洲欧美视频在线观看| 日本不卡一二三| 色综合久久天天综合网| 精品少妇一区二区三区日产乱码 | 91在线观看下载| 欧美一区二区三区的| 国产三级欧美三级| 日韩福利视频导航| 欧洲精品一区二区| 亚洲国产激情av| 日本v片在线高清不卡在线观看| 国产精品影视网| 欧美高清一级片在线| 一色屋精品亚洲香蕉网站| 手机精品视频在线观看| 99精品视频在线免费观看| 日韩欧美中文字幕公布| 麻豆精品国产91久久久久久| 精品久久一区二区三区| 国产一区不卡视频| 欧美人与z0zoxxxx视频| 一本大道久久a久久综合婷婷| 亚洲欧美乱综合| 欧美精品在线一区二区三区| 国产欧美综合在线观看第十页 | 91精品婷婷国产综合久久| 国产精品久久久久影院色老大| 99久久亚洲一区二区三区青草| 一区二区不卡在线播放| 欧美成人性福生活免费看| 成人久久久精品乱码一区二区三区| 亚洲视频中文字幕| 欧美岛国在线观看| 日本黄色一区二区| 久久99精品久久久久久动态图| 99久久精品一区二区| 国产三级欧美三级| 国产综合一区二区| 欧美狂野另类xxxxoooo| 国产欧美一区二区三区网站| 日韩电影一区二区三区四区| 蜜臀久久99精品久久久画质超高清| 丁香婷婷综合激情五月色| 日韩午夜激情电影| 亚洲一区二区三区四区不卡| 国产香蕉久久精品综合网| 精品一区二区三区久久久| 91精品国产欧美日韩| 久久电影网站中文字幕| 欧美伊人精品成人久久综合97 | 99热这里都是精品| 秋霞电影一区二区| 欧美色偷偷大香| 久久婷婷一区二区三区| 精品在线观看免费| 欧美人妖巨大在线| 欧美网站大全在线观看| 欧美亚洲一区二区在线| 欧美伊人精品成人久久综合97| 色综合久久精品| 欧美色偷偷大香| 欧美日本一道本| 精品国产伦一区二区三区观看方式 | 国产suv精品一区二区三区| 亚洲综合激情网| 亚洲国产成人午夜在线一区| 91麻豆精品国产无毒不卡在线观看| 日韩午夜在线影院| 国产精品自在在线| 国产欧美日韩中文久久| 男女性色大片免费观看一区二区 | 972aa.com艺术欧美| 综合激情成人伊人| 亚洲国产高清在线| 国产精品乱子久久久久| 国产日韩欧美一区二区三区乱码| 日韩精品一区二区三区蜜臀 | 国产精品三级视频| 国产精品久久99| 亚洲人成人一区二区在线观看| 久久午夜电影网| 亚洲欧美在线视频观看| 亚洲蜜桃精久久久久久久| 亚洲欧美一区二区久久| 亚洲一区中文日韩| 奇米亚洲午夜久久精品| 国模一区二区三区白浆| 欧美性受xxxx黑人xyx| 欧美视频一区二区三区四区| 日一区二区三区| 国产精品女人毛片| 精品日韩一区二区三区| 久久91精品国产91久久小草| 日韩电影一区二区三区四区| 中文乱码免费一区二区| 国产精品久久久久aaaa樱花| 最新国产成人在线观看| 首页综合国产亚洲丝袜| 国产黄色精品网站| 制服丝袜成人动漫| 国产精品传媒入口麻豆| 欧美极品美女视频| 日韩免费看的电影| 欧美成va人片在线观看| 欧美性感一区二区三区| 3751色影院一区二区三区| 精品少妇一区二区三区在线播放| 欧美人体做爰大胆视频| 国产喷白浆一区二区三区| 秋霞电影一区二区| 色综合一区二区| 一区在线观看免费| 韩国成人福利片在线播放| 精品污污网站免费看| **性色生活片久久毛片| 狠狠色狠狠色综合日日91app| 欧美三区在线观看| 国产精品国模大尺度视频| 久久99日本精品| 日韩一级完整毛片| 日韩av一二三| 日韩一级大片在线观看| 蜜桃一区二区三区在线观看| 欧美日韩黄视频| 亚洲国产中文字幕在线视频综合| 91捆绑美女网站| 亚洲视频免费在线观看| av不卡免费在线观看| 亚洲最快最全在线视频| 精品视频1区2区| 麻豆国产精品官网| 久久精品人人做人人爽97| 高清免费成人av| 亚洲精品成a人| 日韩精品一区二区三区在线 | 99久久综合99久久综合网站| 亚洲人成精品久久久久久| 欧美亚洲愉拍一区二区| 久久国产免费看| 中文字幕一区二区三区在线观看| 色视频一区二区| 久草精品在线观看| 亚洲精品乱码久久久久久| 日韩欧美在线影院| 91麻豆福利精品推荐| 青青草国产精品亚洲专区无| 亚洲国产成人一区二区三区| 欧美亚洲日本国产| 国产精品综合av一区二区国产馆| 亚洲品质自拍视频| 欧美mv日韩mv国产网站| 日本韩国欧美三级| 国产一区二区三区免费在线观看| 亚洲精品国久久99热| 欧美xingq一区二区| 欧美日韩成人高清| 97久久久精品综合88久久| 国产一区二区三区美女| 天堂午夜影视日韩欧美一区二区| 国产精品久久午夜| 欧美—级在线免费片| 日韩亚洲欧美成人一区| 欧美日韩精品免费| 欧美视频一区在线观看| 91美女在线观看| 91久久国产最好的精华液| av在线播放不卡| av电影天堂一区二区在线观看| 国产福利91精品一区| 国产一区二区h| www.综合网.com| av亚洲产国偷v产偷v自拍| 91丨porny丨户外露出| 91小视频在线免费看| 欧美影视一区在线| 日韩一区二区不卡| 久久久亚洲精品一区二区三区| 日本一区二区在线不卡| 国产精品福利一区| 亚洲免费在线看| 婷婷久久综合九色综合绿巨人| 三级欧美在线一区| 国产成人久久精品77777最新版本| 国产大片一区二区| 色吊一区二区三区| 欧美成va人片在线观看| 亚洲乱码一区二区三区在线观看| 亚洲国产精品精华液网站| 免费高清在线一区| 99久久综合精品| 欧美刺激午夜性久久久久久久|