ffmpeg 简介及使用
简介
ffmpeg [global_options] {[input_file_options] -i input_url} ... {[output_file_options] output_url} ...
ffmpeg 是一款非常快速的视频和音频转换器, 是开源项目 FFmpeg (Fast Forward moving pictures expert group) 的命令行程序。 它可以在任意采样率之间转换,并通过高质量的多相滤波器实时调整视频大小。
ffmpeg 程序的转码流程,如下所示
_______ ______________
| | | |
| input | demuxer | encoded data | decoder
| file | ---------> | packets | -----+
|_______| |______________| |
v
_________
| |
| decoded |
| frames |
|_________|
________ ______________ |
| | | | |
| output | <-------- | encoded data | <----+
| file | muxer | packets | encoder
|________| |______________| 其中, demuxer 为解复用器, muxer 为复用器; decoder 为解码器, encoder 为编码器
具体使用示例
假定 PCM 音频格式 s16le (signed 16 bits little endian, 有符号 16 位小端) , 更多格式参见"补充内容 - 1. PCM格式".
1. PCM 音频转换为 WAV 格式
ffmpeg -y -f s16le -ar 16k -ac -i input.raw output.wav
其中, -y 表示无需询问,直接覆盖输出文件; -f s16le 用于设置文件格式为 s16le ; -ar 16k 用于设置音频采样频率为 16k; -ac 1 用于设置通道数为 1; -i input.raw 用于设置输入文件为 input.raw; output.wav 为输出文件.
2. PCM 音频转换为 MP3 格式
ffmpeg -y -f s16le -ar 16k -ac -i input.raw output.mp3
注: 与PCM音频转换为WAV命令相比, 只有输出文件不同, 其他相同.
3. WAV 音频转换为 PCM 格式
ffmpeg -y -i input.wav -acodec pcm_s16le -f s16le -ac 1 -ar 16k output.pcm
其中, -acodec 用于设置音频的编码器和解码器(codec, 即 coder-decoder 的混成词). 也是参数 -codec:a 的别名, 其中a表示 audio.
4. MP3 音频转换为 PCM 格式
ffmpeg -y -i input.mp3 -acodec pcm_s16le -f s16le -ac 1 -ar 16k output.pcm
5. WAV 音频转换为 MP3 格式
ffmpeg -y -i input.wav input.mp3
6. MP3 音频转换为 WAV 格式
ffmpeg -y -i input.mp3 input.wav
补充内容
1. PCM 格式
PCM, 英文全称为 pulse-code modulation, 中文名为脉冲编码调制, 是用于数字化表示采样后的模拟信号的一种方法. 其也是数字音频的标准形式. 更多内容参见 Pulse-code modulation, Wikipedia. 由于 PCM 音频只包含数据, 没有数据头指定采样率, 通道数, 数据位数等, 所以需要在转码(transcoding)前, 指定这些参数. 在 ffmpeg 程序中, 支持多种格式的 PCM 数据, 如下所示:
$ ffmpeg -formats | grep PCM
DE alaw PCM A-law
DE f32be PCM -bit floating-point big-endian
DE f32le PCM -bit floating-point little-endian
DE f64be PCM -bit floating-point big-endian
DE f64le PCM -bit floating-point little-endian
DE mulaw PCM mu-law
DE s16be PCM signed -bit big-endian
DE s16le PCM signed -bit little-endian
DE s24be PCM signed -bit big-endian
DE s24le PCM signed -bit little-endian
DE s32be PCM signed -bit big-endian
DE s32le PCM signed -bit little-endian
DE s8 PCM signed -bit
DE u16be PCM unsigned -bit big-endian
DE u16le PCM unsigned -bit little-endian
DE u24be PCM unsigned -bit big-endian
DE u24le PCM unsigned -bit little-endian
DE u32be PCM unsigned -bit big-endian
DE u32le PCM unsigned -bit little-endian
DE u8 PCM unsigned -bit
其中, A-law 和 mu-law 都是压缩和扩展算法 (companding algorithm). 在 8 位 PCM 数字通信系统中, 用于优化模拟信号数字化的动态范围. A-law 算法主要应用在欧洲, 而 mu-law 算法主要应用在北美和日本. 更多内容,参见 A-law algorithm, Wikipedia 和 μ-law algorithm, Wikipedia .
2. 使用 ffplay 播放音频
$ ffplay [options] [input_url]
ffplay 是一款使用 FFmpeg 库(用于转换视频和音频文件, 官方网址为 https://ffmpeg.org) 和 SDL 库(Simple DirectMedia Layer, 一个跨平台的开发库, 用于通过 OpenGL 和 Direct3D, 提供对音频, 鼠标, 操纵杆和图形硬件的低层访问, 官方网址为 https://www.libsdl.org), 主要用于各种 FFmpeg API 的测试平台.
注意: 播放PCM文件时, 同样需要指定具体参数信息.
具体播放命令, 示例如下:
1). 播放 s16le 格式的 PCM 文件 input.raw
$ ffplay -f s16le -ac 1 -ar 16k -i input.raw
其中, -i 参数可以省略
2). 播放 wav 格式文件
$ ffplay -i input.wav
3). 播放 mp3 格式文件
$ ffplay -i input.mp3
参考资料
1. ffmpeg Documentation. https://ffmpeg.org/ffmpeg.html
2. Can ffmpeg convert audio to raw PCM? If so, how? https://stackoverflow.com/questions/4854513/can-ffmpeg-convert-audio-to-raw-pcm-if-so-how
3. FFmpeg wiki: audio types. https://trac.ffmpeg.org/wiki/audio%20types
4. ffplay Documentation. https://ffmpeg.org/ffplay.html
5. FFmpeg - Wikipedia. https://en.wikipedia.org/wiki/FFmpeg
ffmpeg 简介及使用的更多相关文章
- Ffmpeg简介
http://www.ffmpeg.com.cn/index.php/%E9%A6%96%E9%A1%B5 FFmpeg is a complete solution to record, conve ...
- FFmpeg 学习(一):FFmpeg 简介
一.FFmpeg 介绍 FFmpeg是一套可以用来记录.转换数字音频.视频,并能将其转化为流的开源计算机程序.采用LGPL或GPL许可证.它提供了录制.转换以及流化音视频的完整解决方案.它包含了非常先 ...
- 第一章 FFmpeg简介
1.1 FFmpeg的定义 Fast Forward Moving Picture Experts Group(动态图像专家组) 1.2 FFmpeg的历史 1.3 FFmpeg的基本组成 1 FFm ...
- Windows下FFmpeg快速入门
本系列文章导航 Windows下FFmpeg快速入门 ffmpeg参数解释 mencoder和ffmpeg参数详解(Java处理视频) Java 生成视频缩略图(ffmpeg) 使用ffmpeg进行视 ...
- Windows下FFmpeg快速入门 <第二篇>
FFmpeg简介 FFmpeg是什么? FFmpeg是用于录制.转换和流化音频和视频的完整解决方案, 包括 libavcodec ,一套领先的音/视频编解码类库.FFmpeg 在Linux上开发,当可 ...
- 【Linux】关于ffmpeg的一些常见用法
一.FFmpeg简介 FFmpeg是一款非常快速的视频和音频转换器, 是开源项目 FFmpeg (Fast Forward moving pictures expert group) 的命令行程序. ...
- C++调用ffmpeg.exe提取视频帧
有时候,我们获得一段视频,需要将其中的每一帧都提取出来,来进行一些相关的处理,这时候我们就可以需要用到ffmpeg.exe来进行视频帧的提取. ffmpeg简介:FFmpeg是一套可以用来记录.转换数 ...
- Windows配置ffmpeg
一.ffmpeg简介 ffmpeg是一套可以用来记录.转换数字音频.视频,并能将其转化为流的开源计算机程序.采用LGPL或GPL许可证.它提供了录制.转换以及流化音视频的完整解决方案. 支持操作系统: ...
- 玩转音频、视频的利器:FFmpeg
导语 当下直播平台发展十分迅猛,依靠游戏内直播平台的发展带动游戏活跃提升收入,那么对于我们开发来说如何玩转视频呢?下面就来介绍一个音频.视频处理利器——FFmpeg. FFmpeg 简介 FFmpeg ...
随机推荐
- mongoengine在python中的使用
# /usr/bin/python # encoding: utf-8 # Author: masako from mongoengine import * host ='127.0.0.1' por ...
- Yii 使用Widge面面观
我们可以把Widget视为一个嵌入到控制器管理 的视图中的微控制器,其实就是.net框架中的用户控件,或者类似于.net MVC中的子视图.与controller相比较,微件没有既没有动作,也没有过滤 ...
- springboot: mybatis逆向工程
第一步: pom文件配置 黄线的部分是所要配置的 <?xml version="1.0" encoding="UTF-8"?> <projec ...
- hibernate一对多多对一双向
注意事项:一对多,多对一双向关联,在一的一方的多的getSet集合上的oneToMany上加上mappedBy.告诉hibernate由多的方一来维护关系.这也符合逻辑 ,本来外键就是在加在多的一方. ...
- python笔记03-----文件操作
文件操作 创建一个文件名字为filename 内容是 BJSHGDTW 打印文件编码 f = open("filename",'r',encoding="utf-8&qu ...
- 配置MySQL接受远程登录连接
一 开放mysql mysql的配置文件在/etc/mysql/my.cnf文件内,里面有一行bind-address = 127.0.0.1表示只允许本地访问,将这行注释即可 # bind-addr ...
- 哪些网站需要HTTPS(SSL证书)
很多站长似乎不了解https站点是怎么回事,这就要从传统站点说起:传统的站点的http超文本传输协议,采用明文传输模式,存在着大量的灰色中 间环节,明文信息在中间代理服务器.路由器.wifi热点.通信 ...
- 【转】SQL SERVER 2005/2008 中关于架构的理解
在一次的实际工作中碰到以下情况,在 SQL SERVER 2008中,新建了一个新用户去访问几张由其他用户创建的表,但是无法进行查询,提示“对象名'CustomEntry' 无效.”.当带上了架构名称 ...
- shell脚本:行列转换
Mybatis中写sql,如select,会涉及到一长串列名. `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(100) COLLATE ut ...
- C#中的分部类和分部方法:partial
这篇文章主要介绍了C#中的分部类和分部方法,讲解了类的拆分和方法的定义的拆分,需要的朋友可以参考下可以将类或结构.接口或方法的定义拆分到两个或多个源文件中.每个源文件包含类型或方法定义的一部分,编译应 ...