Chinaunix首页 | 论坛 | 博客
  • 博客访问: 290717
  • 博文数量: 124
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 21
  • 用 户 组: 普通用户
  • 注册时间: 2016-08-20 14:44
文章分类

全部博文(124)

文章存档

2020年(1)

2018年(2)

2016年(2)

2015年(6)

2014年(10)

2013年(23)

2012年(7)

2011年(18)

2010年(15)

2009年(8)

2007年(8)

2006年(23)

2005年(1)

我的朋友

分类: Android平台

2013-11-24 10:48:18

  1.  avcodec_encode_video2(c, &pkt, dstVideoFrame, &got_output); 将pkt.data直接写入文件,用ffplay播放时会很快;
  2. 对于上面的结果用ffmpeg -i a b;直接转换一下,播放速度变慢;(下面讨论a就是原始编码文件,b就是ffmpeg的转码文件)
  3. 中pkt.pts 就是dstVideoFrame中的pts; 对于直接将pkt的data写入文件后生成的多媒体文件,播放时没有任何影响;修改pkt.dts对于播放速度没有任何效果;不影响编码显示效果;
  4. ffmpeg后的文件的播放速度直接又fps决定; 测试方法如下:保持一定的原始图片供给速度,将fps加大,(如实际供给是13,但是代码中fps时25)。再播放b时,实际速度加倍了。(就是实际录制了20秒的视频,10秒播放完毕);
  5. 编码前将dstVideoFrame.pts设为0, 编码质量很差,b文件的播放速度正确;(从log看每次pkt.size变得很小);
  6. 比较了dstVideoFrame.pts每次+4,和pts每次+1的编码输出,明显发现跳变(每次+4)时每帧输出变大;
  7. 由此可见,该文件中并没又记录每帧在什么时候播放,b文件在转吗时,就是简单额根据每秒的帧数安排时间;
  8. 降低bit_rate后,发现输出文件也明显变小;
2.
阅读(8326) | 评论(0) | 转发(1) |
给主人留下些什么吧!~~