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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? rbsp.c

?? H264EncPlayer,H264協(xié)議解碼與播放代碼
?? C
字號(hào):
/*****************************************************************************
 *
 *  T264 AVC CODEC
 *
 *  Copyright(C) 2004-2005 llcc <lcgate1@yahoo.com.cn>
 *               2004-2005 visionany <visionany@yahoo.com.cn>
 *
 *  This program is free software ; you can redistribute it and/or modify
 *  it under the terms of the GNU General Public License as published by
 *  the Free Software Foundation ; either version 2 of the License, or
 *  (at your option) any later version.
 *
 *  This program is distributed in the hope that it will be useful,
 *  but WITHOUT ANY WARRANTY ; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 *  GNU General Public License for more details.
 *
 *  You should have received a copy of the GNU General Public License
 *  along with this program ; if not, write to the Free Software
 *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
 *
 ****************************************************************************/

#include "stdio.h"

#include "T264.h"
#include "bitstream.h"
#include "portab.h"
#include "rbsp.h"
#include "cabac_engine.h"

void 
nal_unit_init(_RW T264_nal_t* nal, int32_t nal_ref_idc, int32_t nal_unit_type)
{
    nal->nal_ref_idc   = nal_ref_idc;
    nal->nal_unit_type = nal_unit_type;
}

void 
nal_unit_write(_R T264_t* t, _R T264_nal_t* nal)
{
    eg_write_direct(t->bs, 1, 32);
    eg_write_direct(t->bs, ((uint32_t)nal->nal_ref_idc) << 5 | nal->nal_unit_type, 8);
}

void 
seq_set_init(_R T264_t* t, _RW T264_seq_set_t* seq)
{
    //
    // NOTE: FIXME
    //
	//for CABAC
	if( t->param.cabac || t->param.b_num > 0 )
		seq->profile_idc               = 77;
	else
		seq->profile_idc      = 66;
  
    seq->level_idc                 = 30;
    seq->seq_id                    = 0;
    seq->log2_max_frame_num_minus4 = 12;
    seq->pic_order_cnt_type        = 0;
    seq->max_pic_order             = 12;
    seq->num_ref_frames            = t->param.ref_num;
    seq->pic_width_in_mbs_minus1   = t->width / 16 - 1;
    seq->pic_height_in_mbs_minus1  = t->height / 16 - 1;
    seq->frame_mbs_only_flag       = 1;
}

void 
seq_set_write(_R T264_t* t, _RW T264_seq_set_t* seq)
{
    eg_write_direct(t->bs, ((uint32_t)seq->profile_idc << 16) |seq->level_idc, 24);
    eg_write_ue(t->bs, seq->seq_id);
    eg_write_ue(t->bs, seq->log2_max_frame_num_minus4);
    eg_write_ue(t->bs, seq->pic_order_cnt_type);

    if (seq->pic_order_cnt_type == 0)
    {
        eg_write_ue(t->bs, seq->max_pic_order);
    }
    else
    {
        //
        // ...
        //
    }

    eg_write_ue(t->bs, seq->num_ref_frames);
    eg_write_direct1(t->bs, 0);
    eg_write_ue(t->bs, seq->pic_width_in_mbs_minus1);
    eg_write_ue(t->bs, seq->pic_height_in_mbs_minus1);
    eg_write_direct1(t->bs, seq->frame_mbs_only_flag);
    eg_write_direct1(t->bs, 0);
    eg_write_direct1(t->bs, 0);
    // vui_parameters_present_flag
    eg_write_direct1(t->bs, 1);
    // aspect_ratio_info_present_flag
    eg_write_direct1(t->bs, 1);
    eg_write_direct(t->bs, t->param.aspect_ratio, 8);
    // overscan_info_present_flag
    eg_write_direct1(t->bs, 0);
    // video_signal_type_present_flag
    eg_write_direct1(t->bs, 1);
    eg_write_direct(t->bs, t->param.video_format, 3);
    // video_full_range_flag
    eg_write_direct1(t->bs, 0);
    // colour_description_present_flag
    eg_write_direct1(t->bs, 0);
    // chroma_loc_info_present_flag
    eg_write_direct1(t->bs, 0);
    // timing_info_present_flag
    // nal_hrd_parameters_present_flag
    // vcl_hrd_parameters_present_flag
    // pic_struct_present_flag 
    // bitstream_restriction_flag
    eg_write_direct(t->bs, 0, 5);

    rbsp_trailing_bits(t);
}

void 
pic_set_init(_R T264_t* t, _RW T264_pic_set_t* pic)
{
    pic->seq_id = 0;
    pic->pic_id = 0;
	//for CABAC
	if(t->param.cabac == 0)
    	pic->entroy_coding_mode_flag = 0;
	else
		pic->entroy_coding_mode_flag = 1;

    pic->pic_order_present_flag = 0;
    pic->num_slice_groups_minus1 = 0;
    pic->num_ref_idx_l0_active_minus1 = t->param.ref_num - 1;
    pic->num_ref_idx_l1_active_minus1 = 0;
    pic->weighted_pred_flag = 0;
    pic->weighted_bipred_idc = 0;
    pic->pic_init_qp_minus26 = t->param.qp - 26;
    pic->pic_init_qs_minus26 = t->param.qp - 26;
    pic->chroma_qp_index_offset = 0;
    if (t->param.disable_filter)
        pic->deblocking_filter_control_present_flag = 1;
    else
        pic->deblocking_filter_control_present_flag = 0;
}

void 
pic_set_write(_R T264_t* t, _RW T264_pic_set_t* pic)
{
    eg_write_ue(t->bs, pic->pic_id);
    eg_write_ue(t->bs, pic->seq_id);
    eg_write_direct1(t->bs, pic->entroy_coding_mode_flag);
    eg_write_direct1(t->bs, pic->pic_order_present_flag);
    eg_write_ue(t->bs, pic->num_slice_groups_minus1);
    eg_write_ue(t->bs, pic->num_ref_idx_l0_active_minus1);
    eg_write_ue(t->bs, pic->num_ref_idx_l1_active_minus1);
    eg_write_direct1(t->bs, pic->weighted_pred_flag);
//  eg_write_direct1(t->bs, pic->weighted_bipred_idc); /*error bits*/
	eg_write_direct(t->bs, pic->weighted_bipred_idc, 2);
    eg_write_se(t->bs, pic->pic_init_qp_minus26);
    eg_write_se(t->bs, pic->pic_init_qs_minus26);
    eg_write_se(t->bs, pic->chroma_qp_index_offset);
    eg_write_direct1(t->bs, pic->deblocking_filter_control_present_flag);
    eg_write_direct1(t->bs, 0);
    eg_write_direct1(t->bs, 0);
    rbsp_trailing_bits(t);
}

void 
slice_header_init(_R T264_t* t, _RW T264_slice_t* slice)
{
    slice->first_mb_in_slice = 0;
	slice->slice_type = t->slice_type;	/* ^^^ */
    slice->pic_id = 0;
    slice->idr_pic_id = t->idr_pic_id;
    slice->pic_order_cnt_lsb = t->poc % (1 << (t->ss.max_pic_order + 4));
    slice->frame_num = t->frame_num;
    slice->direct_spatial_mv_pred_flag = t->param.direct_flag;
    slice->ref_pic_list_reordering_flag_l0 = 0;
    slice->no_output_of_prior_pics_flag = 0;
    slice->long_term_reference_flag = 0;
    slice->adaptive_ref_pic_marking_mode_flag = 0;
    slice->slice_qp_delta = 0;

	//for CABAC
	/* get adapative cabac model if needed */
	if( t->param.cabac )
	{
		t->slice.cabac_init_idc = T264_cabac_model_get( &t->cabac, t->slice_type );
	}
}

void 
slice_header_write(_R T264_t* t, _RW T264_slice_t* slice)
{
    eg_write_ue(t->bs, slice->first_mb_in_slice);
    eg_write_ue(t->bs, slice->slice_type);
    eg_write_ue(t->bs, slice->pic_id);
    eg_write_direct(t->bs, slice->frame_num, t->ss.log2_max_frame_num_minus4 + 4);
    if (t->nal.nal_unit_type == NAL_SLICE_IDR)
    {
        eg_write_ue(t->bs, slice->idr_pic_id);
    }
    if (t->ss.pic_order_cnt_type == 0)
    {
        eg_write_direct(t->bs, slice->pic_order_cnt_lsb, t->ss.max_pic_order + 4);
    }
    if (t->slice_type == SLICE_P)
    {
        // num_ref_idx_active_override_flag
        if (t->refl0_num == t->param.ref_num)
        {
            eg_write_direct1(t->bs, 0);
        }
        else
        {
            eg_write_direct1(t->bs, 1);
            eg_write_ue(t->bs, t->refl0_num - 1);
        }
        t->ps.num_ref_idx_l0_active_minus1 = t->refl0_num - 1;
        t->ps.num_ref_idx_l1_active_minus1 = 0;
    }
    else if (t->slice_type == SLICE_B)
    {
        // direct_spatial_mv_pred_flag
        eg_write_direct1(t->bs, slice->direct_spatial_mv_pred_flag);
        // num_ref_idx_active_override_flag
        {
            eg_write_direct1(t->bs, 1);
            eg_write_ue(t->bs, t->refl0_num - 1);
            eg_write_ue(t->bs, t->refl1_num - 1);
        }
        t->ps.num_ref_idx_l0_active_minus1 = t->refl0_num - 1;
        t->ps.num_ref_idx_l1_active_minus1 = t->refl1_num - 1;
    }

    /* ref_pic_list_reordering() */
	/*
	 *	^^^ ccc
	 */
	if(slice->slice_type != SLICE_I && slice->slice_type != SLICE_SI )
	{
		eg_write_direct1(t->bs, slice->ref_pic_list_reordering_flag_l0);
        if (slice->slice_type == SLICE_B)
            eg_write_direct1(t->bs, slice->ref_pic_list_reordering_flag_l0);
	}

    if (t->nal.nal_ref_idc != 0)
    {
        /* dec_ref_pic_marking() */
        if (t->nal.nal_unit_type == NAL_SLICE_IDR)
        {
            eg_write_direct1(t->bs, slice->no_output_of_prior_pics_flag);
            eg_write_direct1(t->bs, slice->long_term_reference_flag);
        }
        else
        {
            eg_write_direct1(t->bs, slice->adaptive_ref_pic_marking_mode_flag);
        }
    }

	//for CABAC
	if(t->ps.entroy_coding_mode_flag!=0 && t->slice_type!= SLICE_I)
	{
		eg_write_ue(t->bs, t->slice.cabac_init_idc);
	}

    eg_write_se(t->bs, t->qp_y - t->param.qp);
    if (t->ps.deblocking_filter_control_present_flag)
    {
        eg_write_ue(t->bs, t->param.disable_filter);
    }
}

void 
custom_set_init(_R T264_t* t, _RW T264_custom_set_t* set)
{
    set->ver = T264_VER;
    set->flags = 0;
    if (t->flags & USE_FASTINTERPOLATE)
        set->flags |= CUSTOM_FASTINTERPOLATE;
}

void 
custom_set_write(_R T264_t* t, _RW T264_custom_set_t* set)
{
    eg_write_direct(t->bs, set->ver, 32);
    eg_write_direct(t->bs, set->flags, 32);
}

void rbsp_trailing_bits(_R T264_t* t)
{
    eg_write_direct1(t->bs, 1);
    eg_align(t->bs);
}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲成人1区2区| 91九色02白丝porn| 精品一区二区三区香蕉蜜桃 | 亚洲国产精品99久久久久久久久 | 久久99久久99精品免视看婷婷 | 欧美一卡二卡在线观看| 欧美日韩成人综合在线一区二区| 91久久精品日日躁夜夜躁欧美| 日本精品视频一区二区| 91久久精品一区二区二区| 欧美在线观看禁18| 6080日韩午夜伦伦午夜伦| 欧美一区二区三区视频免费| 欧美大胆人体bbbb| xvideos.蜜桃一区二区| 国产日韩v精品一区二区| 亚洲国产成人午夜在线一区| 日韩美女视频19| 亚洲大型综合色站| 男女性色大片免费观看一区二区| 免费成人深夜小野草| 国产一区二区三区四| 成人动漫一区二区| 91久久免费观看| 日韩欧美在线综合网| 欧美精品一区视频| 国产精品久久久久久久午夜片 | 麻豆国产91在线播放| 国产大陆a不卡| 波波电影院一区二区三区| 色天天综合久久久久综合片| 欧美性xxxxxx少妇| 精品国产乱码久久久久久老虎 | 日韩黄色片在线观看| 久久国产免费看| 波多野洁衣一区| 制服.丝袜.亚洲.另类.中文| 久久综合丝袜日本网| 亚洲欧洲色图综合| 视频一区欧美精品| 国产成人精品三级| 欧美三级电影网站| 久久午夜老司机| 亚洲最新在线观看| 精品一区二区三区不卡| 91一区二区三区在线观看| 91麻豆精品国产91久久久更新时间| 久久久久久久综合日本| 亚洲男人的天堂一区二区 | 欧美v国产在线一区二区三区| 国产精品视频一区二区三区不卡| 亚洲第一二三四区| 国产成人精品亚洲午夜麻豆| 欧美三级中文字幕| 国产欧美日韩不卡| 日韩成人dvd| 91视频在线观看免费| 日韩精品一区在线观看| 伊人夜夜躁av伊人久久| 国内偷窥港台综合视频在线播放| 欧美网站大全在线观看| 国产农村妇女精品| 日本在线观看不卡视频| 在线精品视频一区二区三四| 26uuu国产电影一区二区| 亚洲成人精品一区| 一道本成人在线| 国产日本亚洲高清| 欧美aⅴ一区二区三区视频| 色丁香久综合在线久综合在线观看| 久久久久99精品国产片| 午夜国产精品一区| 99久久免费国产| 久久久久国产一区二区三区四区| 奇米四色…亚洲| 欧美中文字幕一区| 亚洲狼人国产精品| 波多野结衣在线一区| 久久久www免费人成精品| 青娱乐精品在线视频| 欧美体内she精视频| 亚洲免费观看在线观看| 成人性生交大片免费 | 国产一区视频导航| 91精品国产91久久久久久一区二区 | 综合久久综合久久| 丁香天五香天堂综合| 国产午夜三级一区二区三| 美女视频黄a大片欧美| 91麻豆精品国产| 奇米色一区二区三区四区| 欧美精品亚洲二区| 性欧美大战久久久久久久久| 欧美伊人久久久久久午夜久久久久| 国产精品久久免费看| 成人免费av在线| 国产精品午夜免费| 粉嫩嫩av羞羞动漫久久久| 国产日本亚洲高清| 成人污视频在线观看| 国产精品网站在线观看| 成人国产一区二区三区精品| 国产精品久久久久天堂| 99热国产精品| 亚洲视频免费在线观看| 在线观看日韩精品| 亚洲午夜成aⅴ人片| 欧美三级三级三级爽爽爽| 亚洲成人免费视频| 欧美欧美欧美欧美首页| 五月天亚洲精品| 日韩欧美中文字幕公布| 国产在线视频精品一区| 国产精品区一区二区三| 白白色 亚洲乱淫| 亚洲精品你懂的| 欧美日韩大陆一区二区| 免费欧美日韩国产三级电影| 精品免费99久久| 国产91在线|亚洲| 亚洲免费在线观看| 在线中文字幕一区二区| 日韩高清一级片| 26uuuu精品一区二区| 成人美女在线观看| 亚洲综合在线五月| 日韩一区二区免费在线电影 | 欧美三级视频在线| 蜜臀久久99精品久久久久久9 | 极品尤物av久久免费看| 久久久精品综合| 91在线国内视频| 天天操天天综合网| 精品久久久久久久久久久院品网| 成人激情免费电影网址| 一区二区国产盗摄色噜噜| 欧美一级一级性生活免费录像| 国产精品一区二区三区乱码| 亚洲日本在线天堂| 欧美一区二区视频在线观看2020| 国产剧情一区在线| 亚洲精品国产精华液| 欧美tickling挠脚心丨vk| www.亚洲在线| 秋霞影院一区二区| 国产精品久久三区| 欧美一区二区三区免费大片| 粉嫩高潮美女一区二区三区| 亚洲成av人片观看| 中文字幕高清一区| 欧美人与禽zozo性伦| 国产精品自在在线| 亚洲成a人v欧美综合天堂下载| 欧美mv日韩mv| 91福利视频久久久久| 国产自产v一区二区三区c| 一区二区三区精品久久久| 久久久综合激的五月天| 欧美在线观看一二区| 国产激情偷乱视频一区二区三区| 亚洲国产另类精品专区| 国产精品日日摸夜夜摸av| 日韩一区二区影院| 欧美亚洲国产一区二区三区va| 国产精品一级二级三级| 日精品一区二区| 亚洲视频在线观看一区| 久久久久久久综合日本| 91精品麻豆日日躁夜夜躁| 97se亚洲国产综合在线| 紧缚捆绑精品一区二区| 亚洲444eee在线观看| 亚洲视频中文字幕| 日本一区二区视频在线观看| 日韩视频免费观看高清完整版在线观看 | 色一区在线观看| 国产寡妇亲子伦一区二区| 日韩av不卡一区二区| 亚洲综合色网站| 亚洲蜜臀av乱码久久精品蜜桃| 久久久99久久| 久久综合av免费| 日韩三级电影网址| 欧美二区在线观看| 欧美色爱综合网| 日本韩国欧美三级| 99热在这里有精品免费| 成人午夜激情视频| 成人亚洲一区二区一| 国产成人欧美日韩在线电影 | 日韩欧美精品三级| 在线视频欧美区| 91天堂素人约啪| 91亚洲国产成人精品一区二区三 | 国产精品一区二区三区四区| 久久精品国产第一区二区三区| 青青草原综合久久大伊人精品| 三级一区在线视频先锋| 亚洲高清不卡在线| 日韩中文字幕1|