热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

libx264libfdk_aac编码解码详解

首先升级用vs2015来编译开发windows下的程序,因为更好的兼容c99语法,不用改很多东西。libx264的编译:在ubuntu下的确非常容易,windows平台有点麻烦,需

首先升级用 vs2015 来编译开发 windows 下的程序,因为更好的兼容 c99 语法,不用改很多东西。

libx264 的编译:

在 ubuntu 下的确非常容易,windows 平台有点麻烦,需要用到 MYSY2 ,现在这些开源项目,有的都不提供 vs 的工程,哪怕提供个 cmake 也行啊。

找到一个老版本的 libx264 http://download.videolan.org/pub/videolan/x264/snapshots/x264-snapshot-20091006-2245.tar.bz2 带有 vs 的工程。

http://yasm.tortall.net/  需要安装这个,汇编器,速度比较快吧。

使用 vs 2015 打开解决方案,libx264 编译成功 x264 测试程序不行。

有几个函数找不到 _x264_lookahead_init _x264_lookahead_is_empt _x264_lookahead_put_frame ....

添加 encoder\lookahead.c 到lib ,重新编译成功2个。

========== 全部重新生成: 成功 2 个,失败 0 个,跳过 0 个 ==========

1,RGB 转 YUV 

ffmpeg 方法

 1 read_jpeg(file_image, &video_width, &video_height, &image_buff);
 2 
 3 uint8_t *indata[AV_NUM_DATA_POINTERS] = { 0 };
 4 indata[0] = (uint8_t *)image_buff;
 5 int inlinesize[AV_NUM_DATA_POINTERS] = { 0 };
 6 inlinesize[0] = frame->width * 3;
 7 
 8 ret = sws_scale(sws_ctx, indata, inlinesize, 0, frame->height, frame->data, frame->linesize);
 9 
10 for (int j = 0; j <3; j++)
11 {
12     printf("j:%d linesize in:%d out:%d\n", j, inlinesize[j], frame->linesize[j]);
13 }

get_video_size: 480*272
file_image:img/image-00001.jpg
j:0 linesize in:1440 out:480
j:1 linesize in:0 out:256
j:2 linesize in:0 out:256

RGB 数据被转为 YUV 数组,那么怎么取出来呢?

 1 //方法1
 2 if (0 > x264_picture_alloc(&m_pic, m_param.i_csp, m_param.i_width, m_param.i_height*2))
 3 {
 4     printf("x264 [error]: malloc failed\n");
 5     return -1;
 6 }
 7 
 8 memcpy(m_pic.img.plane[0], frame->data[0], frame->linesize[0]*frame->height);
 9 m_pic.img.i_stride[0] = frame->linesize[0];
10 
11 memcpy(m_pic.img.plane[1], frame->data[1], frame->linesize[1]*frame->height/2);
12 m_pic.img.i_stride[1] = frame->linesize[1];
13 
14 memcpy(m_pic.img.plane[2], frame->data[2], frame->linesize[2]*frame->height/2);
15 m_pic.img.i_stride[2] = frame->linesize[2];
16 
17 //方法2
18 if (0 > x264_picture_alloc(&m_pic, m_param.i_csp, m_param.i_width, m_param.i_height))
19 {
20     printf("x264 [error]: malloc failed\n");
21     return -1;
22 }
23 sws_scale(sws_ctx, indata, inlinesize, 0, frame->height, m_pic.img.plane, m_pic.img.i_stride);

有2种方法,如果手动 memcpy 则需要将图片内存申请的大一些,因为有对齐的问题,如果用 ffmpeg 传入 m_pic.img.plane, m_pic.img.i_stride 就不需要,ffmpeg 内部应该是做了 realloc。

参考 example.c 编写测试程序,x264_encoder_encode() i_nal 一直为 0。所以重新编译了静态库,方便调试。

#x264-master# ./configure --prefix=/usr --disable-asm --enable-static --enable-shared --enable-debug

编译测试程序 :g++ encode_video.cpp -lavcodec -lavutil -lswscale -lswresample -lavformat -ljpeg libx264.a -lpthread -ldl

x264_encoder_encode() 返回一直为0的问题,调了好几个小时,想了各种方法,改了各种参数,都没有效果,最后终于找到问题了,原来是测试的 YUV 数据太少。

 jpg 图片转的 YUV 用了40帧后才出现编码数据。

 1 x264 [debug]: frame=   0 QP=19.71 NAL=3 Slice:I Poc:0   I:396  P:0    SKIP:0    size=9052 bytes
 2 frame_size:9052
 3 file_image:img//image-00042.jpg
 4 Send frame 41
 5 x264 [debug]: frame=   1 QP=20.29 NAL=2 Slice:P Poc:2   I:6    P:140  SKIP:250  size=836 bytes
 6 frame_size:836
 7 file_image:img//image-00043.jpg
 8 Send frame 42
 9 x264 [debug]: frame=   2 QP=19.75 NAL=2 Slice:P Poc:4   I:0    P:43   SKIP:353  size=132 bytes
10 frame_size:132

参数设置,每10帧产生一个 关键 I 帧 ,同时禁用了 B 帧,因为我们要做 live 直播,去掉了。

m_param.i_frame_reference = 10;
m_param.i_bframe = 0;

libx264 libfdk_aac 编码 解码 详解


推荐阅读
  • 本文介绍了lua语言中闭包的特性及其在模式匹配、日期处理、编译和模块化等方面的应用。lua中的闭包是严格遵循词法定界的第一类值,函数可以作为变量自由传递,也可以作为参数传递给其他函数。这些特性使得lua语言具有极大的灵活性,为程序开发带来了便利。 ... [详细]
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • 本文介绍了C#中数据集DataSet对象的使用及相关方法详解,包括DataSet对象的概述、与数据关系对象的互联、Rows集合和Columns集合的组成,以及DataSet对象常用的方法之一——Merge方法的使用。通过本文的阅读,读者可以了解到DataSet对象在C#中的重要性和使用方法。 ... [详细]
  • 1,关于死锁的理解死锁,我们可以简单的理解为是两个线程同时使用同一资源,两个线程又得不到相应的资源而造成永无相互等待的情况。 2,模拟死锁背景介绍:我们创建一个朋友 ... [详细]
  • 动态规划算法的基本步骤及最长递增子序列问题详解
    本文详细介绍了动态规划算法的基本步骤,包括划分阶段、选择状态、决策和状态转移方程,并以最长递增子序列问题为例进行了详细解析。动态规划算法的有效性依赖于问题本身所具有的最优子结构性质和子问题重叠性质。通过将子问题的解保存在一个表中,在以后尽可能多地利用这些子问题的解,从而提高算法的效率。 ... [详细]
  • 猜字母游戏
    猜字母游戏猜字母游戏——设计数据结构猜字母游戏——设计程序结构猜字母游戏——实现字母生成方法猜字母游戏——实现字母检测方法猜字母游戏——实现主方法1猜字母游戏——设计数据结构1.1 ... [详细]
  • HDU 2372 El Dorado(DP)的最长上升子序列长度求解方法
    本文介绍了解决HDU 2372 El Dorado问题的一种动态规划方法,通过循环k的方式求解最长上升子序列的长度。具体实现过程包括初始化dp数组、读取数列、计算最长上升子序列长度等步骤。 ... [详细]
  • 本文讨论了如何优化解决hdu 1003 java题目的动态规划方法,通过分析加法规则和最大和的性质,提出了一种优化的思路。具体方法是,当从1加到n为负时,即sum(1,n)sum(n,s),可以继续加法计算。同时,还考虑了两种特殊情况:都是负数的情况和有0的情况。最后,通过使用Scanner类来获取输入数据。 ... [详细]
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • 本文详细介绍了Linux中进程控制块PCBtask_struct结构体的结构和作用,包括进程状态、进程号、待处理信号、进程地址空间、调度标志、锁深度、基本时间片、调度策略以及内存管理信息等方面的内容。阅读本文可以更加深入地了解Linux进程管理的原理和机制。 ... [详细]
  • 本文介绍了在Linux下安装Perl的步骤,并提供了一个简单的Perl程序示例。同时,还展示了运行该程序的结果。 ... [详细]
  • 《数据结构》学习笔记3——串匹配算法性能评估
    本文主要讨论串匹配算法的性能评估,包括模式匹配、字符种类数量、算法复杂度等内容。通过借助C++中的头文件和库,可以实现对串的匹配操作。其中蛮力算法的复杂度为O(m*n),通过随机取出长度为m的子串作为模式P,在文本T中进行匹配,统计平均复杂度。对于成功和失败的匹配分别进行测试,分析其平均复杂度。详情请参考相关学习资源。 ... [详细]
  • 高质量SQL书写的30条建议
    本文提供了30条关于优化SQL的建议,包括避免使用select *,使用具体字段,以及使用limit 1等。这些建议是基于实际开发经验总结出来的,旨在帮助读者优化SQL查询。 ... [详细]
  • 本文介绍了指针的概念以及在函数调用时使用指针作为参数的情况。指针存放的是变量的地址,通过指针可以修改指针所指的变量的值。然而,如果想要修改指针的指向,就需要使用指针的引用。文章还通过一个简单的示例代码解释了指针的引用的使用方法,并思考了在修改指针的指向后,取指针的输出结果。 ... [详细]
  • 在project.properties添加#Projecttarget.targetandroid-19android.library.reference.1..Sliding ... [详细]
author-avatar
AD518最丶设计
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有