这是来自H.264乐园的一个帖子。

typedef struct x264_param_t
{
    /* CPU 标志位 */
    unsigned int cpu;
    int         i_threads;       /* 并行编码多帧 */
    int         b_deterministic; /*是否允许非确定性时线程优化*/
    int         i_sync_lookahead; /* 线程超前缓冲 */

/* 视频属性 */
    int         i_width; /* 宽度*/
    int         i_height; /* 高度*/
    int         i_csp;  /* 编码比特流的CSP,仅支持i420,色彩空间设置 */
    int         i_level_idc; /* level值的设置*/
    int         i_frame_total; /* 编码帧的总数, 默认 0 */
/*Vui参数集视频可用性信息视频标准化选项 */
    struct
    {
        /* they will be reduced to be 0 < x <= 65535 and prime */
        int         i_sar_height;
        int         i_sar_width; /* 设置长宽比 */

int         i_overscan;    /* 0=undef, 1=no overscan, 2=overscan 过扫描线,默认"undef"(不设置),可选项:show(观看)/crop(去除)*/

/*见以下的值h264附件E */
        Int       i_vidformat;/* 视频格式,默认"undef",component/pal/ntsc/secam/mac/undef*/
        int       b_fullrange; /*Specify full range samples setting,默认"off",可选项:off/on*/
        int       i_colorprim; /*原始色度格式,默认"undef",可选项:undef/bt709/bt470m/bt470bg,smpte170m/smpte240m/film*/
        int   i_transfer; /*转换方式,默认"undef",可选项:undef/bt709/bt470m/bt470bg/linear,log100/log316/smpte170m/smpte240m*/
        int  i_colmatrix; /*色度矩阵设置,默认"undef",undef/bt709/fcc/bt470bg,smpte170m/smpte240m/GBR/YCgCo*/
        int         i_chroma_loc;    /* both top & bottom色度样本指定,范围0~5,默认0 */
    } vui;

int         i_fps_num;
    int         i_fps_den;
/*这两个参数是由fps帧率确定的,赋值的过程见下:
{        float fps;      
if( sscanf( value, "%d/%d", &p->i_fps_num, &p->i_fps_den ) == 2 )
            ;
        else if( sscanf( value, "%f", &fps ) )
        {
            p->i_fps_num = (int)(fps * 1000 + .5);
            p->i_fps_den = 1000;
        }
        else
            b_error = 1;
    }
Value的值就是fps。*/

/*流参数 */
    int         i_frame_reference;  /* 参考帧最大数目 */
    int         i_keyint_max;       /* 在此间隔设置IDR关键帧 */
    int         i_keyint_min;       /* 场景切换少于次值编码位I, 而不是 IDR. */
    int         i_scenecut_threshold; /*如何积极地插入额外的I帧 */
    int         i_bframe;   /*两个相关图像间P帧的数目 */
    int         i_bframe_adaptive; /*自适应B帧判定*/
    int         i_bframe_bias; /*控制插入B帧判定,范围-100~+100,越高越容易插入B帧,默认0*/
    int         b_bframe_pyramid;   /*允许部分B为参考帧 */
/*去块滤波器需要的参数*/
    int         b_deblocking_filter;
    int         i_deblocking_filter_alphac0;    /* [-6, 6] -6 light filter, 6 strong */
    int         i_deblocking_filter_beta;       /* [-6, 6]  idem */
   /*熵编码 */
    int         b_cabac;
    int         i_cabac_init_idc;

int         b_interlaced; /* 隔行扫描 */
    /*量化 */
    int         i_cqm_preset;         /*自定义量化矩阵(CQM),初始化量化模式为flat*/
    char        *psz_cqm_file;      /* JM format读取JM格式的外部量化矩阵文件,自动忽略其他—cqm 选项*/
    uint8_t     cqm_4iy[16];        /* used only if i_cqm_preset == X264_CQM_CUSTOM */
    uint8_t     cqm_4ic[16];
    uint8_t     cqm_4py[16];
    uint8_t     cqm_4pc[16];
    uint8_t     cqm_8iy[64];
    uint8_t     cqm_8py[64];

/* 日志 */
    void        (*pf_log)( void *, int i_level, const char *psz, va_list );
    void        *p_log_private;
    int         i_log_level;
    int         b_visualize;
    char        *psz_dump_yuv;  /* 重建帧的名字 */

/* 编码分析参数*/
    struct
    {
        unsigned int intra;     /* 帧间分区*/
        unsigned int inter;     /* 帧内分区 */

int          b_transform_8x8; /* 帧间分区*/
        int          b_weighted_bipred; /*为b帧隐式加权 */
        int          i_direct_mv_pred; /*时间空间队运动预测 */
        int          i_chroma_qp_offset; /*色度量化步长偏移量 */

int          i_me_method; /* 运动估计算法 (X264_ME_*) */
        int          i_me_range; /* 整像素运动估计搜索范围 (from predicted mv) */
        int          i_mv_range; /* 运动矢量最大长度(in pixels). -1 = auto, based on level */
        int          i_mv_range_thread; /* 线程之间的最小空间. -1 = auto, based on number of threads. */
        int          i_subpel_refine; /* 亚像素运动估计质量 */
        int          b_chroma_me; /* 亚像素色度运动估计和P帧的模式选择 */
        int          b_mixed_references; /*允许每个宏块的分区在P帧有它自己的参考号*/
        int          i_trellis;  /* Trellis量化,对每个8x8的块寻找合适的量化值,需要CABAC,默认0 0:关闭1:只在最后编码时使用2:一直使用*/
        int          b_fast_pskip; /*快速P帧跳过检测*/
        int          b_dct_decimate; /* 在P-frames转换参数域 */
        int          i_noise_reduction; /*自适应伪盲区 */
        float        f_psy_rd; /* Psy RD strength */
        float        f_psy_trellis; /* Psy trellis strength */
        int          b_psy; /* Toggle all psy optimizations */

/*,亮度量化中使用的无效区大小*/
        int          i_luma_deadzone[2]; /* {帧间, 帧内} */

int          b_psnr;    /* 计算和打印PSNR信息 */
        int          b_ssim;    /*计算和打印SSIM信息*/
    } analyse;

/* 码率控制参数 */
    struct
    {
        int         i_rc_method;    /* X264_RC_* */

int         i_qp_constant;  /* 0-51 */
        int         i_qp_min;       /*允许的最小量化值 */
        int         i_qp_max;       /*允许的最大量化值*/
        int         i_qp_step;      /*帧间最大量化步长 */

int         i_bitrate;  /*设置平均码率 */
        float       f_rf_constant;  /* 1pass VBR, nominal QP */
        float       f_rate_tolerance;
        int         i_vbv_max_bitrate; /*平均码率模式下,最大瞬时码率,默认0(与-B设置相同) */
        int         i_vbv_buffer_size; /*码率控制缓冲区的大小,单位kbit,默认0 */
        float       f_vbv_buffer_init; /* <=1: fraction of buffer_size. >1: kbit码率控制缓冲区数据保留的最大数据量与缓冲区大小之比,范围0~1.0,默认0.9*/
        float       f_ip_factor;
        float       f_pb_factor;

int         i_aq_mode;      /* psy adaptive QP. (X264_AQ_*) */
        float       f_aq_strength;
        int         b_mb_tree;      /* Macroblock-tree ratecontrol. */
        int         i_lookahead;

/* 2pass 多次压缩码率控制 */
        int         b_stat_write;   /* Enable stat writing in psz_stat_out */
        char        *psz_stat_out;
        int         b_stat_read;    /* Read stat from psz_stat_in and use it */
        char        *psz_stat_in;

/* 2pass params (same as ffmpeg ones) */
        float       f_qcompress;    /* 0.0 => cbr, 1.0 => constant qp */
        float       f_qblur;        /*时间上模糊量化 */
        float       f_complexity_blur; /* 时间上模糊复杂性 */
        x264_zone_t *zones;         /* 码率控制覆盖 */
        int         i_zones;        /* number of zone_t's */
        char        *psz_zones;     /*指定区的另一种方法*/
    } rc;

/* Muxing parameters */
    int b_aud;                  /*生成访问单元分隔符*/
    int b_repeat_headers;       /* 在每个关键帧前放置SPS/PPS*/
    int i_sps_id;               /* SPS 和 PPS id 号 */

/*切片(像条)参数 */
    int i_slice_max_size;    /* 每片字节的最大数,包括预计的NAL开销. */
    int i_slice_max_mbs;     /* 每片宏块的最大数,重写 i_slice_count */
    int i_slice_count;       /* 每帧的像条数目: 设置矩形像条. */

/* Optional callback for freeing this x264_param_t when it is done being used.
     * Only used when the x264_param_t sits in memory for an indefinite period of time,
     * i.e. when an x264_param_t is passed to x264_t in an x264_picture_t or in zones.
     * Not used when x264_encoder_reconfig is called directly. */
    void (*param_free)( void* );
} x264_param_t;

参考:http://bbs.chinavideo.org/viewthread.php?tid=8345&page=1

X264结构体中的变量解释相关推荐

  1. 【C语言】宏offsetof的模拟实现 (计算结构体中某变量相对于首地址的偏移)

    首先我们应该特别留意 : offsetof 是一个宏,并非是一个函数 ! 宏offsetof的介绍 : 参数:第一个是结构体类型名称,第二个是结构体成员名 返回类型:size_t无符号整形 引用的头文 ...

  2. C语言中利用宏,实现一个整数的奇数位和偶数位交换,以及计算结构体中某变量相对于首地址的偏移

    C语言中的自定义宏 自定义宏,令其实现所需功能 1.写一个宏,可以将一个整数字的奇数位和偶数位交换. 2.写一个宏,计算结构体中某变量相对于首地址的偏移. 具体思路1: 首先取出当前数的奇数部分和偶数 ...

  3. C++57个入门知识点_17 类的访问权限及C语言模拟类的封装(类的私有权限突破方法:编译期进行权限检查,运行期通过指针修改类的私有成员变量;利用函数指针对结构体中成员变量进行修改;CPU大小尾排列)

    接上篇:C++57个入门知识点_16 类的标准写法(类名.成员变量.成员函数及对象命名规则:成员变量一般为私有,成员函数为公有并暴露给外部使用成员变量:防止类过大,声明写在.h,实现写在.cpp,调用 ...

  4. malloc和free——结构体中动态内存的管理

    C语言中内存的管理主要是依据malloc和free实现的,其中malloc主要是实现内存的分配,而free则是实现内存的释放.虽然这是我们已经很熟悉的,但是还是存在一些问题.特别是当结构体中存在指针的 ...

  5. 结构体中的malloc 与 free

    结构体中动态内存的管理(malloc和free) C语言中内存的管理主要是依据malloc和free实现的,其中malloc主要是实现内存的分配,而free则是实现内存的释放.虽然这是我们已经很熟悉的 ...

  6. libev中ev_loop结构体中宏定义的理解

    libev源代码由于有各种宏定义,十分让人费解,作者这么写确实使得代码很简练,但也给读者的阅读带来了巨大的麻烦,下面将分析下ev_loop这个结构体的定义,加深对作者代码简化的理解,先上代码: str ...

  7. 【Kernel】如何从kernel中获取cred结构体中的value

    获取linux kernel cred结构体中成员变量的value时,根绝kernel版本需要做适配. linux kernel 3.5以上,获取cred需要如下处理(重点 cred->uid. ...

  8. AVFrame结构体中变量解释

    AVPacket结构体内几个变量分析 uint8_t *data[AV_NUM_DATA_POINTERS]:指针数组,存放YUV数据的地方.如图所示,一般占用前3个指针,分别指向Y,U,V数据. 对 ...

  9. c语言给结构体指针申请空间,结构体中的指针变量申请空间问题

    本人声明了一个结构体包含id,age,name三个属性 struct studentInfo { int id; int age; char *name[20]; }; 本人又创建了一个双向循环链表, ...

  10. 获取结构体中变量的偏移量

    C/C++获取结构体中变量的偏移量 1.某些特殊需求下,我们需要知道某个变量在其结构体中的偏移位置. 通常的做法就是定义一个宏变量,如下: #define OFFSET(structure, memb ...

最新文章

  1. 混色,半透明的设定,以及我们视角即屏幕处在-1层,-1层的物体是看不见的
  2. QString和char *的相互转换
  3. 网络上的两台计算机如何互相访问,怎么样使两台电脑互相访问?
  4. 网络安全系列之三十五 缓冲区溢出
  5. 【MySQL】错误#1217:外键约束引起的错误
  6. 如何在jieba分词中加自定义词典_Pyspark Word2Vec + jieba 训练词向量流程
  7. 聊聊flink的FsStateBackend
  8. 没了Macbook的英特尔还好吗?比你想象的好
  9. js基础知识汇总03
  10. 奎享添加自己字体_文泰刻绘怎么添加字体 新字体导入与添加步骤教程
  11. IDEA导入MySQL驱动包(Mac版)
  12. [项目实战篇] Emos在线办公小程序--环境搭建
  13. Zabbix实现短信报警
  14. 分析Faster RCNN中的RPN
  15. Hbuilder插入图片网页中无法显示
  16. 房贷计算器html代码,html房贷计算器输出两个框怎么弄
  17. MFC radio button 设置默认选中
  18. 缩减openssl库体积
  19. C++ atof函数
  20. 学习笔记,神经网络和反向传播

热门文章

  1. 最新wp建站做淘宝客系统教程(共6课)附源码
  2. 最近学到一些linq和面向对象的经验分享
  3. 最近学习 variant configuration
  4. Spark DataFrames DataSet
  5. JxBrowser之四:对Http Response Code的处理
  6. 【软硬链接总结】描述linux下软链接和硬链接的区别(面试题)
  7. 国网四川电力应用大数据服务经济社会发展
  8. 洛谷 P1854 花店橱窗布置
  9. 做爬虫的一些技术观点-第450期
  10. PHPExcel按单元格读取数据