4.X264.c中,h = x264_encoder_open( param ) )是用来复制参数并验证参数的有效性,在CCS下应该是不需要验证参数的(参数都是在程序中设置好的),因此此处只作复制参数param和初始化X264_T h的操作.(VC下程序修改记录080106下午)

修改COMMON.C中的void    x264_param_default( x264_param_t *param )(即设置param的默认参数)为:

void    x264_param_default( x264_param_t *param )
{
    /* */
    memset( param, 0, sizeof( x264_param_t ) );

/* CPU autodetect */
//   param->cpu = x264_cpu_detect();
param->cpu = 0;
    param->i_threads = 1;

/* Video properties */
    param->i_csp           = X264_CSP_I420;
    param->i_width         = 0;
    param->i_height        = 0;
    param->vui.i_sar_width = 0;
    param->vui.i_sar_height= 0;
//    param->vui.i_overscan = 0; /* undef */
//    param->vui.i_vidformat = 5; /* undef */
//    param->vui.b_fullrange = 0; /* off */
//    param->vui.i_colorprim = 2; /* undef */
//    param->vui.i_transfer = 2; /* undef */
//    param->vui.i_colmatrix = 2; /* undef */
//    param->vui.i_chroma_loc= 0; /* left center */

param->i_fps_num       = 25;
    param->i_fps_den       = 1;
//   param->i_level_idc     = 51; /* as close to "unrestricted" as we can get */
param->i_level_idc     = 40; /* level 4.0 is sufficient for 720x576 with16 reference frames */

/* Encoder parameters */
    param->i_frame_reference = 1;
    param->i_keyint_max = 250;
    param->i_keyint_min = 25;
    param->i_bframe = 0;   // 在IP帧之间可插入的B帧数量最大值,范围0~16,默认0
    param->i_scenecut_threshold = 40; ;// 画面动态变化限,当超出此值时插入I帧,默认40
//    param->b_bframe_adaptive = 1; 好像是自适应的B帧个数
param->b_bframe_adaptive = 0;
    param->i_bframe_bias = 0;
    param->b_bframe_pyramid = 0;

//    param->b_deblocking_filter = 1; //去块效应相关
param->b_deblocking_filter = 0;
    param->i_deblocking_filter_alphac0 = 0;
    param->i_deblocking_filter_beta = 0;

//    param->b_cabac = 1;
param->b_cabac = 0;
//    param->i_cabac_init_idc = 0;
param->i_cabac_init_idc = -1;

param->rc.i_rc_method = X264_RC_CQP; //使用恒定质量方式
    param->rc.i_bitrate = 0;
    param->rc.f_rate_tolerance = 1.0;
    param->rc.i_vbv_max_bitrate = 0;
    param->rc.i_vbv_buffer_size = 0;
    param->rc.f_vbv_buffer_init = 0.9;
    param->rc.i_qp_constant = 26;
    param->rc.i_rf_constant = 0;
    param->rc.i_qp_min = 10;
    param->rc.i_qp_max = 51;
    param->rc.i_qp_step = 4;
    param->rc.f_ip_factor = 1.4;
    param->rc.f_pb_factor = 1.3;

param->rc.b_stat_write = 0;
    param->rc.psz_stat_out = "x264_2pass.log";
    param->rc.b_stat_read = 0;
    param->rc.psz_stat_in = "x264_2pass.log";
    param->rc.psz_rc_eq = "blurCplx^(1-qComp)";
    param->rc.f_qcompress = 0.6;
    param->rc.f_qblur = 0.5;
    param->rc.f_complexity_blur = 20;
    param->rc.i_zones = 0;

/* Log */
    param->pf_log = x264_log_default;
    param->p_log_private = NULL;
    param->i_log_level = X264_LOG_INFO;

/* */
//   param->analyse.intra = X264_ANALYSE_I4x4 | X264_ANALYSE_I8x8;
param->analyse.intra = X264_ANALYSE_I4x4;
//    param->analyse.inter = X264_ANALYSE_I4x4 | X264_ANALYSE_I8x8
//                         | X264_ANALYSE_PSUB16x16 | X264_ANALYSE_BSUB16x16;
param->analyse.inter = X264_ANALYSE_I4x4
                           | X264_ANALYSE_PSUB16x16 | X264_ANALYSE_BSUB16x16;
    param->analyse.i_direct_mv_pred = X264_DIRECT_PRED_SPATIAL;
//   param->analyse.i_me_method = X264_ME_HEX;
param->analyse.i_me_method = X264_ME_DIA; //使用菱形搜索
    param->analyse.i_me_range = 16;
//    param->analyse.i_subpel_refine = 5;
param->analyse.i_subpel_refine = 3; 亚像素搜索范围
    param->analyse.b_chroma_me = 1;
//   param->analyse.i_mv_range = -1; // set from level_idc
param->analyse.i_mv_range = 512;//运动向量搜索范围
    param->analyse.i_chroma_qp_offset = 0; //色度和亮度之间的量化差,范围-12~+12,默认0
    param->analyse.b_fast_pskip = 1;
    param->analyse.b_dct_decimate = 1;
//    param->analyse.b_psnr = 1;
param->analyse.b_psnr = 0; //是否使用信噪比

param->i_cqm_preset = X264_CQM_FLAT;
    memset( param->cqm_4iy, 16, 16 );
    memset( param->cqm_4ic, 16, 16 );
    memset( param->cqm_4py, 16, 16 );
    memset( param->cqm_4pc, 16, 16 );
    memset( param->cqm_8iy, 16, 64 );
    memset( param->cqm_8py, 16, 64 );

param->b_repeat_headers = 1;
    param->b_aud = 0;
}

修改后对foreman01.yuv编码速率由1.82fps提高到3.03fps

将main函数改为:

int main( int argc, char **argv )
{
    x264_param_t param;
    cli_opt_t opt;
/*                                                        主要是屏蔽以下四句,因为在CCS下不需要
#ifdef _MSC_VER
    _setmode(_fileno(stdin), _O_BINARY);
    _setmode(_fileno(stdout), _O_BINARY);
#endif
*/
    x264_param_default( &param );

/* Parse command line */
    if( Parse( argc, argv, &param, &opt ) < 0 )
        return -1;

/* Control-C handler */                //用来判断是否按下CTRL+C键,若按下则退出命令行模式
//   signal( SIGINT, SigIntHandler );

return Encode( &param, &opt );
}

程序可运行,fps无影响

将X264程序中的muxers.c,matroskv.c文件删除,其中的i

int open_file_yuv( char *psz_filename, hnd_t *p_handle, x264_param_t *p_param );
int get_frame_total_yuv( hnd_t handle );
int read_frame_yuv( x264_picture_t *p_pic, hnd_t handle, int i_frame );
int close_file_yuv( hnd_t handle );

int open_file_bsf( char *psz_filename, hnd_t *p_handle );
int set_param_bsf( hnd_t handle, x264_param_t *p_param );
int write_nalu_bsf( hnd_t handle, uint8_t *p_nal, int i_size );
int set_eop_bsf( hnd_t handle, x264_picture_t *p_picture );
int close_file_bsf( hnd_t handle );

extern int (*p_open_infile)( char *psz_filename, hnd_t *p_handle, x264_param_t *p_param );
extern int (*p_get_frame_total)( hnd_t handle );
extern int (*p_read_frame)( x264_picture_t *p_pic, hnd_t handle, int i_frame );
extern int (*p_close_infile)( hnd_t handle );

在X264.c中重写.

muxer和matroskv文件的一些函数主要是定义了对mp4,y4m,mkv文件格式的输入输出支持,修改后程序则只能执行YUV格式的输入输出了.运行正常,2.97fps

4.X264.c中,h = x264_encoder_open( param ) )是用来复制参数并验证参数的有效性,在CCS下应该是不需要验证参数的(参数都是在程序中设置好的),因此此处只作复制参数param和初始化X264_T h的操作.

但是也不能将static int x264_validate_parameters( x264_t *h )函数屏蔽了,因为里面还有其它赋值操作,在此函数中删除了判断图像的宽高,CSP420的语句,速度3.36fps

VC下调用x264进行视频编码,相关推荐

  1. 视频编码中为什么须要进行变换编码?

    绝大多数图像都有一个共同的特征:平坦区域和内容缓慢变化区域占领一幅图像的大部分,而细节区域和内容突变区域则占小部分.也能够说,图像中直流和低频区占大部分,高频区占小部分.这样,空间域的图像变换到频域或 ...

  2. libx264进行视频编码的流程

    调用libx264进行视频编码的基本流程图 (1)要调用x264库,首先要加上头文件#include <x264.h>,为了方便后面的操作,定义了一个结构体Encoder,定义Encode ...

  3. MediaCodec 、x264、faac 实现音视频编码并通过 rtmp 协议实现推流

    前言 咱们回顾一下前面 2 篇文章,主要讲解了如何搭建 rtmp 直播服务器,和如何开发一款具有拉流功能的 Android 播放器.那么现在有了播放端和直播服务器还缺少推流端.该篇文章我们就一起来实现 ...

  4. H.264视频编码在VC++.Net中的实现

    From: http://blog.csdn.net/xwchen/article/details/5052981 引言:H.264编码技术是俱乐部在过去一段时间内研究的一个方向,对该编码技术进行过实 ...

  5. H.264视频编码在VC .Net中的实现(H264全文)

    H.264视频编码在VC++.Net中的实现 引言:H.264编码技术是俱乐部在过去一段时间内研究的一个方向,对该编码技术进行过实际的开发和应用,并取得了很大的收获.下面将重点介绍H.264视频编码在 ...

  6. 从零开始理解DM368的H264视频编码过程(下)

    目录 四.一些需要注意的问题和提示 色彩空间 支持的视频编码格式 支持的视频输入源 Camera的更换 IDR帧 五.后记 四.一些需要注意的问题和提示 色彩空间 在capture捕获线程中有一项设置 ...

  7. H.265视频编码与技术全析(下)

    H.265视频编码与技术全析(下) 四.帧内预测模式 共35个(h264有9个),包括Planar,DC,33个方向模式: 除了Intra_Angular预测外,HEVC还和H.264/MPEG-4 ...

  8. rtsp协议_如何在RTSP协议视频智能平台EasyNVR未登录的情况下调用通道直播的接口?...

    原标题:如何在RTSP协议视频智能平台EasyNVR未登录的情况下调用通道直播的接口? TSINGSEE青犀视频云边端架构全线都提供了丰富的API接口,用户可以自由调用进行二次开发.在本文之前,我们博 ...

  9. hm编码工具使用_H.265视频编码与技术全析(下)

    H.265视频编码与技术全析(下) 四.帧内预测模式 共35个(h264有9个),包括Planar,DC,33个方向模式: 除了Intra_Angular预测外,HEVC还和H.264/MPEG-4 ...

最新文章

  1. win10修改mac地址
  2. python学习笔记---字符串
  3. Python零碎知识(11):assert用法
  4. ES5-10 原型、原型链、闭包立即执行函数、插件开发
  5. vue图片查看控件v-viewer使用
  6. Javascript学习数据结构--集合(Set实现)
  7. 都在发5G手机,现在买4G手机还合算吗?
  8. OpenCV3 for python3 学习笔记3-----用OpenCV3处理图像2
  9. 使用python下载加密的流媒体m3u8视频文件,获取电影资源
  10. 借助JavaEE中Timer API实现定时关闭计算机的功能
  11. 应届生软件测试面经_应届毕业生面试软件测试工程师时应注意什么?
  12. 《麦田里的守望者》中最喜欢的两句话
  13. 深入浅出 - Android系统移植与平台开发(十)- Android编译系统与定制Android平台系统
  14. ffmpeg截取视频的片段
  15. QNX4系统启动过程
  16. Bugku / CTF / WEB 输入密码查看flag
  17. 南大计算机系统实验PA0 Compiling and Running NEMU报错解决方法
  18. 使用视频下载工具 you-get 下载视频
  19. 二进制转换为十六进制
  20. 特定用语检测 java_留学作业Movie Review的特定术语有哪些?

热门文章

  1. 用NPOI从DataBase到Excel '2
  2. TCL语言笔记:TCL中的String命令
  3. 显示/隐藏Mac系统中所有的隐藏文件
  4. 【转】Unity3D研究院之使用Xamarin Studio调试Unity程序
  5. mysql 获取自增主键
  6. gcc g++ Linux下动态库_静态库
  7. C#环境下的钩子详解
  8. hadoop 分片与分块,map task和reduce task的理解
  9. .net中前台javascript与后台c#函数相互调用
  10. Vue3的响应式原理解析