帧率 fps的概念

帧率,单位FPS(frame per second), 用于衡量视频每秒的处理帧数,对于编码器而言说明编码器在1s的编码的速度,通常可以使用一帧的编码时间倒数简单计算;对于解码器而言,帧率表示1秒内解码帧数。

电视节目中比较常用的帧率制式有NTSC、PAL。另外,帧率可能会因为视频是否是交织(interlaved,i)或逐行(progressive,p)的,描述上有所不同。对于交织的视频,一帧数据包含两场:顶场和底场。

NTSC标准使用60i fps,意思是每秒60场,亦即30帧。(60 fields),30帧

PAL标准使用50i fps,意思是每秒50场,亦即25帧。

如何设置转码帧率

ffmpeg提供了-r用于设置转码之后的帧率,命令行如下:

ffmpeg -i input.avi -r 30 output.mp4

使用fps filter

这里介绍第一个filter,名字是fps,可用于设置输出视频的帧率,语法如下:

fps=fps=number_of_frames

比如下面命令行将input.avi的帧率处理成25帧,输出到output.mp4中

ffmpeg -i input.avi -vf fps=fps=25 output.mp4

预定义的帧率

ffmpeg提供了几种常用的帧率:

缩写				帧率			准确值
ntsc-film 23.97fps 24000/1001
film 24fps 24/1
pal、qpal、spal 25fps 25/1
ntsc、qntsc、sntsc 29.97fps 30000/1001

在使用-r参数是可以用上面的缩写指代特定帧率。

码率 bitrate

码率是指单位时间内处理的音视频数据的比特数,单位bps。在同样的编码条件下,码率决定音视频数据的质量。

比较常用的码率控制策略有下面三种:

  • ABR:平均码率,固定编码大小的情况下较常用
  • CBR:固定码率,多数用于流媒体串流或直播,用于保存不实用。
  • VBR:自适应码率,简单场景使用低码率编码,复杂场景使用高码率编码。同等大小情况下,编码质量比VBR和CBR要好。

ffmpeg中设置码率的参数在FFmpeg Basics学习笔记(1)ffmpeg基础已经介绍了,有兴趣可以看看。

CBR设置

设置为CBR码率输出时,需要指定minrate和maxrate参数,并保证-b和二者的参数相同即可。

ffmpeg -i in.avi -b 500K -minrate 500K -maxrate 500K -bufsize 1M out.mkv

限制输出文件的大小

可以使用-fs命令

ffmpeg -i in.avi -fs 10MB out.mp4

视频缩放

视频缩放可分为两种,保持宽高比的缩放(Scale)、任意比例缩放(Resize)。前者通常不破坏原始图像的显示比例,视觉效果通常比较好,类似数学中的等比例变换;后者比较灵活,可以任意变换。

比如下面的缩放处理,将源视频缩放为320x240大小

ffmpeg -i in.mp4 -s 320x240 out.mp4

ffmpeg中预先定义了一些分辨率,比如:(注意描述视频时通常是宽x高)

  • qcif、cif、4cif、16cif,宽高都是2倍递增的关系。只需要记住cif:352x288
  • vga 表示640x480分辨率
  • hd720 表示1280x720分辨率,通常说的720p
  • hd1080 表示1920x1080分辨率,通常说的1080p

scale video filter

scale视频filter支持视频的缩放。其基础语法如下:

scale=width:height[inter1={1|-1}]

其中width和height表示缩放之后的视频宽高,inter表示是否是自动启用去交织的功能。在实际命令函中还可以出现以下参数:

  • iw、ih 输入源的视频宽高
  • ow、oh 输出的视频宽高
  • a、sar、dar(a 宽高比=iw/ih; sar 输入源的宽高比; dar 输入源的显示宽高比=a*sar)
  • hsub、vsub 水平和垂直方向上色度分量的采样步长,比如对YUV422p的格式,hsub=2、vsub=1

具体使用可以参考下面命令行:

ffmpeg -i in.mp4 -vf sacle=320:240 out.mp4

下面两条语句分别实现等比例缩放、指定宽高的等比缩放

ffmpeg -i in.mp4 -vf scale=iw0.6:ih0.6 out.mp4

ffmpeg -i in.mp4 -vf scale=200:200/a out.mp4

视频裁剪 Crop

视频裁剪指的是从指定视频的某个区域(通常是矩形)取出部分画面。

crop video filter

crop filter的语法如下:

crop=ow[:oh[❌[y:[:keep_aspect]]]]

除了能使用scale filter提供的参数外,还可以使用用x、y、n、pos、t等参数,具体含义如下:

  • x,y 裁剪区域起始点坐标,默认为((iw-ow)/2, (ih-oh)/2)
  • n、pos、t分别用于标识当前帧数、位置及时间戳

只截取源视频的中心区域(长宽取一半)

ffmpeg -i in.avi -vf crop=iw/2:ih/2 out.mp4

cropdetect video filter

自动截取非黑色的区域。在4:3和16:9视频显示时通常填充黑边,cropdetect filter会比较有用。其语法如下:

cropdetect[=limit[:round[:reset]]]

各字段含义:

  • limit: 黑色判定门限,取值范围[0,255],默认为24
  • round,向上取整参数,整数对齐,比如必须要求输出宽高是16的倍数、偶数。
  • reset,重新计算裁剪区域的间隔

ffmpeg命令行格式,

ffmpeg -i input.mpg -vf cropdetect=limit=0 output.mp4

pad video filter

区域填充特殊颜色,通常色彩填充多用于视频分辨率和屏幕分辨率不一致的情况下,为了保证视频的效果,保持拉伸的宽高比,在左右填充或者上下填充。pad filter语法如下:

pad=width[:height[:x[:y[:color]]]]

除了可以使用crop filer中参数,这里提供了color,用于指定填充颜色;width和height为输出视频的分辨率;x和y表示输入源的左上角在输出画面上的偏移。

下面语句的功能是在800x640的图片外围填充30个像素的粉红色边框。

ffmpeg -i photo.jpg -vf pad=860:660:30:30:pink framed_photo.jpg

视频的镜像

hflip video filter

hflip实现对视频的水平翻转。语法如下:

-vf hflip

翻转效果类似下面的示例:(翻转之后图像互为水平镜像)

ABC	  |   CBA
DEF | FED

vflip video filter

vflip实现对视频的垂直翻转。语法如下:

-vf vflip

翻转效果类似下面(垂直镜像)

000    |    888
111 | 111
888 | 000

transpose video filter

transpose filter用于实现特定角度旋转和翻转配合的效果。其语法如下:

-vf transpose={0,1,2,3}

0	逆时针旋转90°+垂直翻转
1 顺时针旋转90°
2 逆时针旋转90°
3 顺时针旋转90°+垂直翻转

类型0和3是旋转和垂直翻转配合的处理。下面两个输出是一样的:

ffplay -f lavfi -i smptebars -vf transpose=0

ffplay -f lavfi -i smptebars -vf transpose=2,vflip

顺时针旋转90°的效果是这样的(左边是原图,右边是transpose之后的图)

AB			CA
CD DB

顺时针旋转90°+垂直翻转的效果如下:

AB			DB
CD CA

对比下图即可。

附加说明

本部分内容主要涉及《Ffmpeg Basic》的第3章到第7章(包含第7章),介绍了比较多的视频编码参数和处理,比如帧率、码率、缩放、裁剪、填充和旋转。

概念性内容比较多,建议可以简单了解下有关内容,实际需要用到的时候再深入研究下。

FFmpeg Basics学习笔记(2)的更多相关文章

  1. FFmpeg Basics学习笔记(1)ffmpeg基础

    1 FFmpeg的由来 FFmpeg缩写中,FF指的是Fast Forward,mpeg是 Moving Pictures Experts Group的缩写.官网:ffmpeg.org 编译好的可执行 ...

  2. FFmpeg Basic学习笔记(3)

    视频叠加--画中画效果 overlay video filter 视频叠加比较常见的应用场景是台标的叠加,在画面左上角.右上角.左下角或右下角叠加台标. ffmpeg提供的overlay filter ...

  3. FFmpeg编程学习笔记二:音频重採样

    ffmpeg实现音频重採样的核心函数swr_convert功能很强大,但是ffmpeg文档对它的凝视太过简单.在应用中往往会出这样那样的问题,事实上在读取数据->重採样->编码数据的循环中 ...

  4. FFmpeg Basic学习笔记(4)

    图像处理 常见的图片格式包括YUV.BMP.JPG.GIF.PNG. 图像的创建 可以使用下面命令从输入源中截取图像 ffmpeg -i input -ss t image.type 从videocl ...

  5. FFmpeg Basics阅读笔记1:介绍

    Multimedia handling with a fast audio and video encoder 作者:Frantisek Korbel 网址:http://ffmpeg.tv/ FFm ...

  6. Markdown 学习笔记: Basics

    Markdown 学习笔记: Basics 原文:Basics. 了解Markdown格式化句法的要点 本页对如何使用Markdown提供了一个简单的概述.在"句法"页中对Mark ...

  7. FFmpeg常用命令学习笔记(一)基本信息查询命令

    笔者才开始学习音视频开发,FFmpeg学习笔记系列主要是从慕课网李超老师的FFmpeg音视频核心技术精讲与实战课程学习的心得体会. FFmpeg音视频核心技术精讲与实战:https://coding. ...

  8. ffmpeg学习笔记

           对于每一个刚開始学习的人,刚開始接触ffmpeg时,想必会有三个问题最为关心,即ffmpeg是什么?能干什么?怎么開始学习?本人前段时间開始接触ffmpeg,在刚開始学习过程中.这三个问 ...

  9. jQuery学习笔记 - 基础知识扫盲入门篇

    jQuery学习笔记 - 基础知识扫盲入门篇 2013-06-16 18:42 by 全新时代, 11 阅读, 0 评论, 收藏, 编辑 1.为什么要使用jQuery? 提供了强大的功能函数解决浏览器 ...

随机推荐

  1. iOS获取ipa素材、提取ipa资源图片文件

    当我们看到一款优秀的App时,我们可能对它的一些素材比较感兴趣,或者我们也想仿写一款类似app,那么怎么能获取到它的素材资源文件呢? 下面我以ofo举例: 1.打开iTunes,搜索ofo关键字,选择 ...

  2. tensorflow中的sequence_loss_by_example

    在编写RNN程序时,一个很常见的函数就是sequence_loss_by_example loss = tf.contrib.legacy_seq2seq.sequence_loss_by_examp ...

  3. [转]GAN论文集

    really-awesome-gan A list of papers and other resources on General Adversarial (Neural) Networks. Th ...

  4. Language and Compiler Features Since Delphi 7

    from: http://edn.embarcadero.com/cn/article/34324 Language and Compiler Features Since Delphi 7   In ...

  5. linux shell 脚本攻略学习15--如何只列出目录,如何快速切换目录

    工作中经常遇到关于目录方面的问题,例如,如何只列出当前目录下的所有目录,以及如何快速高效的切换目录,而不需要使用鼠标,下面将简单介绍关于这两方面的解决方案: 一.如何只列出目录? 看似简单的任务,其实 ...

  6. JavaScript escape() unescape() decodeURI()函数对字符串进行编码解码

    定义和用法 escape() 函数可对字符串进行编码,这样就可以在所有的计算机上读取该字符串. 语法 escape(string) 参数 描述 string 必需.要被转义或编码的字符串. 返回值 已 ...

  7. iptables中ULOG和NFLOG实现分析【转】

    原文地址:http://blog.csdn.net/eydwyz/article/details/52456335 ----------原文如下---------------------------- ...

  8. VS2010调试多进程

    http://msdn.microsoft.com/zh-cn/library/ms123401.aspx 选择启动项目 在“解决方案资源管理器”中,右击项目名,然后在快捷菜单上单击“设为启动项目”. ...

  9. 初步了解pandas(学习笔记)

    1 pandas简介 pandas 是一种列存数据分析 API.它是用于处理和分析输入数据的强大工具,很多机器学习框架都支持将 pandas 数据结构作为输入. 虽然全方位介绍 pandas API ...

  10. Android登录client,验证码的获取,网页数据抓取与解析,HttpWatch基本使用

    大家好,我是M1ko.在互联网时代的今天,假设一个App不接入互联网.那么这个App一定不会有长时间的生命周期,因此Android网络编程是每个Android开发人员必备的技能.博主是在校大学生,自学 ...