1、常见的音视频格式介绍
常见的音频格式有:mp3,wav,aac ,ac-3 等,常见的视频格式有:mp4, avi, flv, mkv 等。
但是以上的音视频格式又分为容器格式和编码格式。
1.1 容器格式
MP4
支持的视频编码格式:H.264, H.265, MPEG-4
支持的音频编码格式:AAC, MP3, AC-3
优点:广泛支持,适用于流媒体和本地播放。
AVI
支持的视频编码格式:DivX, XviD, H.264
支持的音频编码格式:MP3, AC-3
优点:老牌格式,兼容性好,但不支持现代编解码器。
FLV
支持的视频编码格式:H.263, H.264
支持的音频编码格式:MP3, AAC
优点:主要用于流媒体播放。
1.2 视频编码格式
H.264 (AVC)
- 应用广泛,压缩效率高,适用于流媒体和存储。
- 常用于MP4, MKV, MOV等容器格式。
H.265 (HEVC)
- 相比H.264,具有更高的压缩效率,适合4K视频。
- 常用于MP4, MKV容器格式。
VP8/VP9
- 由Google开发,适用于网络视频流。
- 常用于WebM容器格式。
MPEG-4 Part 2
- 老牌视频编码格式,压缩效率相对较低。
- 常用于AVI, MP4容器格式。
1.3 音频编码格式
AAC (Advanced Audio Codec)
- 广泛使用,音质优良,适用于流媒体。
- 常用于MP4, MKV, MOV容器格式。
MP3 (MPEG-1 Audio Layer III)
- 老牌音频编码格式,广泛支持。
- 常用于MP4, AVI, MKV容器格式。
AC-3 (Dolby Digital)
- 多声道音频,适用于家庭影院和DVD。
- 常用于MP4, MKV容器格式。
FLAC (Free Lossless Audio Codec)
- 无损音频编码,适用于高保真音频。
- 常用于MKV容器格式。
ALAC (Apple Lossless Audio Codec)
- 苹果公司的无损音频编码格式。
- 常用于MOV, MP4容器格式。
2、视频格式的转换
FFmpeg 内置了强大的视频格式转换功能。常见的命令形式如下:
#转换一种格式到另一种格式
ffmpeg -i input.xxx output.yyy
#转换mp4格式到mov格式 直接复制 不重新编码
ffmpeg -i input.mp4 -vcodec copy -acodec copy output.mov
#转换mov格式到mp4格式
ffmpeg -i input.mov -acodec copy -vcodec copy output.mp4
#MOV 文件转换为 MP4 文件,并使用 H.265 编码进行压缩。慢速预设 CRF(恒定质量因子)设置为 25,同时保留了原始音频编码。
ffmpeg -i in.mov -c:v libx265 -preset slow -crf 25 -acodec copy out.mp4
3、视频和音频抽取
FFmpeg 命令同样可以进行视频或者音频的抽取。
3.1 视频的抽取
#视频的抽取
ffmpeg -i input.mov -an -vcodec copy output.h264
视频抽取过程可能因为时间戳的问题有一些错误提醒,可以重新封装输出文件解决。
ffmpeg -i 001.mkv -an -vcodec copy -fflags +genpts -f mp4 output.mp4
3.2 音频的抽取
#音频抽取
ffmpeg -i input.mkv -vn -c:a aac output.aac #-vn 禁止复制视屏流 -c:a acc 指定音频编解码器为 AAC
4、FFmpeg 提取 yuv 和 pcm 数据
4.1 提取 yuv 数据
ffmpeg -i input.mp4 -an -c:v rawvideo -pix_fmt yuv420p output.mp4
命令释义:
-i input.mp4: 指定输入文件为 input.mp4。
-an: 去除音频流。
-c:v rawvideo: 将视频编码为原始视频格式(无压缩)。
-pix_fmt yuv420p: 指定像素格式为 YUV420p。
output.mp4: 指定输出文件为 output.mp4。
需要注意的输出的是无压缩的原始视频格式,通常这个文件都非常的大。
4.2 提取 pcm 音频数据
ffpmeg -i input.mp4 -vn -ar 44100 -ac2 -f s16le out.pcm
命令释义:
-i input.mp4: 指定输入文件为 input.mp4。
-vn: 禁用视频流,只处理音频。
-ar 44100: 设置音频采样率为 44100 Hz。
-ac 2: 设置音频通道数为 2(立体声)。
-f s16le: 指定输出格式为 16位小端序 PCM。
out.pcm: 指定输出文件为 out.pcm。
以上是音视频的格式转换和音视频抽取,更多详细的内容,请参考FFmpeg手册或者官方示例。
1595

被折叠的 条评论
为什么被折叠?



