音视频处理 FFmpeg相关内容介绍 以及八大

FFmpeg的介绍

  •  FFmpeg由Fabrice Bellard于2000年创建,由C和汇编语言进行开发
  • FF -> Fast Forward 快进
  • mpeg -> 标准化组织 Moving Pictures Experts Group
  • 使用到FFmpeg的开源项目
  • gstreamer: a framework for streaming media
  • chromium
  • mpv: Command line video player
  • kdenlive: Free and open source video editor, based on MLT Framework and KDE Frameworks 5
  • synfig: Synfig Studio is a free and open-source 2D animation software, designed as powerful industrial-strength solution for creating film-quality animation using a vector and bitmap artwork.
  • FFmpegMediaMetadataRetriever: provides a unified interface for retrieving frame and meta data from an input media file
  • HandBrake: HandBrake is an open-source video transcoder available for Linux, Mac, and Windows
  • Nadeshiko: A Linux tool to cut short videos with ffmpeg
  • 更多项目可以参考projects.html

参考链接

  • GitHub - FFmpeg/FFmpeg: Mirror of https://git.ffmpeg.org/ffmpeg.git
  • FFmpeg学习目录 - 简书
  • FFmpeg初识 - 简书

命令行工具介绍

  • ffmpeg: 对音视频、图片数据进行编解码、格式转换、分割和合并
  • ffplay:媒体播放器 使用了ffmpeg和sdl库
  • ffprobe:音视频文件分析工具

播放器架构

  • 对文件进行解复用,分离音频和视频
  • 音频通过MP3进行播放
  • 视频通过YUV进行播放
  • 解复用分离音视频 用到了FFmpeg技术
  • 播放的时候 需要注意 音视频 同步

音视频处理 FFmpeg相关内容介绍 以及八大_第1张图片

FFMpeg都能做啥

  • FFmpeg是一个非常优秀的多媒体框架,具有开源、免费、跨平台的特性
  • 对音频和视频的处理需要对应的插件进行处理
  • 可以运行在Linux MAC Windows等诸多应用平台上
  • 功能:编码  解码 转码 复用 解复用 过滤音视频数据 视频录制 媒体格式转换 

FFmpeg文件介绍

  • libavformat  对多媒体格式的解析和封装,如MP4、FLV、TS等文件的封装格式,RTMP、RTSP、HLS等网络协议封装格式
  • libavutil 常用的工具函数库 包括随机数生成器、数据结构、数学工具、核心多媒体工具
  • libavcodec 音频编解码,只负责调用插件,本身并不会自主执行
  • libavdevice  对多媒体输入和输出设备的信息进行采集和呈现,包括Video4Linux2,VfW,DShow和ALSA
  • libavresample 对音频重新采样
  • libavfilter  对音视频的后期处理 滤镜
  • libswresample 对音频操作。提供了转换音频的采样频率、声道格式或者样本格式的功能
  • libswscale 对视频的操作,高度优化的图像比例缩放、图像颜色空间/像素格式的转换,如rgb和yuv之间的转换

FFmpeg 常用命令 分类

  • 基本信息查询
  • 录制命令 音频和视频
  • 分解/复用命令
  • 处理原始数据命令 处理视频/音频采集的原始数据
  • 裁剪与合并命令 
  • 图片和视频互转命令
  • 直播相关命令
  • 各种滤镜命令

FFmpeg处理流程

  • 输入文件 mp4 mov格式的文件,这是一个封装,包含了音频和视频等数据
  • 对输入文件进行demuxer得到编码数据(视频和音频),编码数据包是经过压缩的
  • 对编码数据包 进行 解码 得到 数据帧,此刻的数据帧是 高度还原 原始数据信息,也就是使用麦克风直接采集到的数据,但是不是完全一样的。对数据帧进行重新编码,进行封装

音视频处理 FFmpeg相关内容介绍 以及八大_第2张图片

 FFmpeg基本信息查询命令

  • -demuxers 和 -muxers 分解 和 封装的格式
  • -devices 将其当做一个 输入设备,音频、视频、桌面设备
  • -protocol 支持的网络协议,将网络文件作为输入
  • -filters 加水印 去除水印
  • -pix_fmts 像素格式 rgm YUV
  • -sample_fmts 可用的采样模式 每一个采样点大小 ,使用多少字节存储一个采用,8位 16位 浮点型还是整数型等
  • -layouts 显示channel名称,单声道 多声道 还是 立体声 

 FFmpeg录制命令

录制视频

  • ffmpeg -f avfoundation -i 1  -r  30 out.yuv
    • -f:指定使用avfoundation进行数据采集
    • -i:指定输入,从哪采集数据,他是一个文件的索引号,1 代表屏幕 0代表摄像头
    • -r:指定帧率 25帧就算比较流畅,60帧以上高清
    • out.yuv 保存后的数据格式 yuv表示原始数据,比较大,无压缩
  • ctrl + c 结束录制
  • ffplay -s 2560x1600 -pix_fmt uyvy422 out.yuv
    • 因为yuv格式的文件未封装,ffplay不知道如何播放
    • 但是ffmpeg在进行视频录制的过程中会保存相关的配置信息,播放时需要指定即可
    • -pix_fmt uyvy422 像素格式
  • ffmpeg -f avfoundation  -list_devices  true -i “”显示设备列表
    • 视频设备
      • [0] camera
      • [1] 屏幕录制
    • 音频设备
      • [0]  虚拟音频设备
      • [1] 设备内置 麦克风

录制音频

  • 视频在冒号之前指定,音频设备在冒号后面指定
  • ffmpeg -f avfoundation -i :0 out.wav
  • 播放 ffplay out.wav

  FFmpeg分解与复用

多媒体格式转换

  • ffmpeg -i out.mp4 -vcodec copy -acodec copy out.flv
    • -vcodec copy  v代表视频,copy表示先前封装不变,直接拷贝
    • -acodec copy  a代表音频,copy表示先前封装不变,直接拷贝
    • out.flv 表示另外一种输出格式

  FFmpeg处理原始数据

例子一 FFmpeg提取YUV数据

  • ffmpeg -i input.mp4 -an -c:v rawvideo -pix_fmt yuv420p out.yuv
  • -an a表示音频 n 表示不要,输出视频不包含 音频
  • -c:v rawvideo 对原始视频进行编码
  • -pix_fmt yuv420p 对像素格式进行处理
  • 播放需要指定参数ffplay -s 638x358 out.yuv

例子二 FFmpeg提取PCM数据

  • ffmpeg -i out.mp4 -vn -ar 44100 -ac2 -f s16le out.pcm
  • -vn 不要视频
  • -ar 44100 音频采样率
  • -ac2 c表示声道 2 表示双声道
  • -f s16le s表示有符号 16表示每一个数值使用16位表示 l表示小 e表示end 小端存储
  • 播放指定参数 ffplay -ar 44100 -ac 2 -f s16le out.pcm

  FFmpeg滤镜

  • 滤镜需要针对解码数据进行操作,对其进行过滤,再次编码

音视频处理 FFmpeg相关内容介绍 以及八大_第3张图片

  •  ffmpeg -i in.mov -vf crop=in_w-200:in_h-200 -c:v libx264 -c:a copy out.mp4
  • -vf 视频滤镜
  • crop是滤镜的名字
  • =in_w-200:in_h-200 是与crop相对应的参数
  • in_w 视频本身的宽度,in_h视频本身的高度
  • -200,即在原有的视频高度和宽度的基础上 裁剪200,实现视频的裁剪
  • -c:v 视频的编码器是libx264
  • -c:a copy 音频不处理 直接拷贝

  FFmpeg裁剪与合并命令

  • 音视频裁剪
  • ffmpeg -i in.mp4 -ss 00:00:00 -t 10 out.ts
  • -ss 00:00:00 裁剪的起始时间 时:分:秒
  • -t 10 截取多长时间的视频,以秒为单位
  • 音视频合并
  • ffmpeg -f concat -i inputs,txt out,flv
  • concat 拼接
  • -i inputs.txt  存储想要合并的文件,也就是文件列表
    • inputs.txt内容为 file filename 每一行指定一个文件
    • 例子
    • file '1.ts'
    • file '2.ts'
  • out.flv 输出结果

FFmpeg 图片和视频互转命令

  • 视频转图片
  • ffmpeg -i in.flv -r 1 -f image2 image-%3d.jpeg
  • -r 转换图片的速率 此时设置为1,表示每秒钟转换1张图片
  • -f 将输入文件 转化为什么格式的,这里是image2
  • 输出结果是 image-%3d.jpeg %3d动态的递增,%3表示3个数字组成,即文件命名image-000.jpeg 开始 ,以image-999.jpeg 结束
  • 图片转视频
  • ffmpeg -i image-%3d.jpeg out.mp4
  • 播放 ffplay out.mp4 播放视频,几张图立刻播放完毕

FFmpeg 直播 推 / 拉流

  • 推流
  • ffmpeg -re -i out.mp4 -c copy -f flv rtmp://server/live/steamName
  • -re 减慢帧率
  • -i out.mp4 推出去的流媒体
  • -c 音视频
  • -v 视频
  • -a 音频
  • -f 推出去流媒体的格式 
  • rtmp://server/live/steamName 服务器
  • 拉流
  • ffmpeg -i rtmp://server/live/steamName -c copy dump.flv
  • -c 音视频 copy不进行编码
  • dump.flv 将其转换为 flv格式

简单命令

  •  修改图片和视频的分辨率
    • ffmpeg -i input -vf scale=iw/2:-1 output
    • iw: 输入帧宽 此处将帧宽缩短为先前的1/2
    • -1: 要求scale filter保持纵横比
  • ffplay 播放文件
    • ffplay test.mp4
  • 播放网络文件
    • ffplay rtsp://184.72.239.149/vod/mp4://BigBuckBunny_175k.mov //大白熊
  • 以json字符串的形式输出数据视频和音频流的详细信息
    • ffprobe -print_format json -show_streams test.mp4
    • 结果示例
chy-cpabe@ubuntu:~/ffmpeg-source/ffmpeg$ ./ffprobe -print_format json -show_streams /home/chy-cpabe/Videos/test.mp4 
ffprobe version N-106797-g580fb6a8c9 Copyright (c) 2007-2022 the FFmpeg developers
  built with gcc 7 (Ubuntu 7.5.0-3ubuntu1~18.04)
  configuration: --prefix=/home/chy-cpabe/ffmpeg_build --pkg-config-flags=--static --extra-cflags=-I/home/chy-cpabe/ffmpeg_build/include --extra-ldflags=-L/home/chy-cpabe/ffmpeg_build/lib --extra-libs='-lpthread -lm' --ld=g++ --bindir=/home/chy-cpabe/bin --enable-gpl --enable-gnutls --enable-libass --enable-libfdk-aac --enable-libfreetype --enable-libmp3lame --enable-libopus --enable-libsvtav1 --enable-libdav1d --enable-libvorbis --enable-libvpx --enable-libx264 --enable-libx265 --enable-nonfree
  libavutil      57. 24.101 / 57. 24.101
  libavcodec     59. 27.100 / 59. 27.100
  libavformat    59. 23.100 / 59. 23.100
  libavdevice    59.  6.100 / 59.  6.100
  libavfilter     8. 37.100 /  8. 37.100
  libswscale      6.  6.100 /  6.  6.100
  libswresample   4.  6.100 /  4.  6.100
  libpostproc    56.  5.100 / 56.  5.100
{
Input #0, mov,mp4,m4a,3gp,3g2,mj2, from '/home/chy-cpabe/Videos/test.mp4':
  Metadata:
    major_brand     : M4V 
    minor_version   : 1
    compatible_brands: isomavc1mp42
    creation_time   : 2021-02-14T02:11:02.000000Z
  Duration: 00:00:23.36, start: 0.000000, bitrate: 6313 kb/s
  Stream #0:0[0x1](und): Video: h264 (High) (avc1 / 0x31637661), yuv420p(tv, bt709, progressive), 1920x1080 [SAR 1:1 DAR 16:9], 6147 kb/s, 23.98 fps, 23.98 tbr, 24k tbn (default)
    Metadata:
      creation_time   : 2021-02-14T02:11:02.000000Z
      handler_name    : ETI ISO Video Media Handler
      vendor_id       : [0][0][0][0]
      encoder         : Elemental H.264
  Stream #0:1[0x2](und): Audio: aac (LC) (mp4a / 0x6134706D), 48000 Hz, stereo, fltp, 160 kb/s (default)
    Metadata:
      creation_time   : 2021-02-14T02:11:02.000000Z
      handler_name    : ETI ISO Audio Media Handler
      vendor_id       : [0][0][0][0]
    "streams": [
        {
            "index": 0,
            "codec_name": "h264",
            "codec_long_name": "H.264 / AVC / MPEG-4 AVC / MPEG-4 part 10",
            "profile": "High",
            "codec_type": "video",
            "codec_tag_string": "avc1",
            "codec_tag": "0x31637661",
            "width": 1920,
            "height": 1080,
            "coded_width": 1920,
            "coded_height": 1080,
            "closed_captions": 0,
            "film_grain": 0,
            "has_b_frames": 1,
            "sample_aspect_ratio": "1:1",
            "display_aspect_ratio": "16:9",
            "pix_fmt": "yuv420p",
            "level": 40,
            "color_range": "tv",
            "color_space": "bt709",
            "color_transfer": "bt709",
            "color_primaries": "bt709",
            "chroma_location": "left",
            "field_order": "progressive",
            "refs": 1,
            "is_avc": "true",
            "nal_length_size": "4",
            "id": "0x1",
            "r_frame_rate": "24000/1001",
            "avg_frame_rate": "24000/1001",
            "time_base": "1/24000",
            "start_pts": 0,
            "start_time": "0.000000",
            "duration_ts": 560560,
            "duration": "23.356667",
            "bit_rate": "6147092",
            "bits_per_raw_sample": "8",
            "nb_frames": "560",
            "extradata_size": 60,
            "disposition": {
                "default": 1,
                "dub": 0,
                "original": 0,
                "comment": 0,
                "lyrics": 0,
                "karaoke": 0,
                "forced": 0,
                "hearing_impaired": 0,
                "visual_impaired": 0,
                "clean_effects": 0,
                "attached_pic": 0,
                "timed_thumbnails": 0,
                "captions": 0,
                "descriptions": 0,
                "metadata": 0,
                "dependent": 0,
                "still_image": 0
            },
            "tags": {
                "creation_time": "2021-02-14T02:11:02.000000Z",
                "language": "und",
                "handler_name": "ETI ISO Video Media Handler",
                "vendor_id": "[0][0][0][0]",
                "encoder": "Elemental H.264"
            }
        },
        {
            "index": 1,
            "codec_name": "aac",
            "codec_long_name": "AAC (Advanced Audio Coding)",
            "profile": "LC",
            "codec_type": "audio",
            "codec_tag_string": "mp4a",
            "codec_tag": "0x6134706d",
            "sample_fmt": "fltp",
            "sample_rate": "48000",
            "channels": 2,
            "channel_layout": "stereo",
            "bits_per_sample": 0,
            "id": "0x2",
            "r_frame_rate": "0/0",
            "avg_frame_rate": "0/0",
            "time_base": "1/48000",
            "start_pts": 0,
            "start_time": "0.000000",
            "duration_ts": 1118656,
            "duration": "23.305333",
            "bit_rate": "160137",
            "nb_frames": "1094",
            "extradata_size": 2,
            "disposition": {
                "default": 1,
                "dub": 0,
                "original": 0,
                "comment": 0,
                "lyrics": 0,
                "karaoke": 0,
                "forced": 0,
                "hearing_impaired": 0,
                "visual_impaired": 0,
                "clean_effects": 0,
                "attached_pic": 0,
                "timed_thumbnails": 0,
                "captions": 0,
                "descriptions": 0,
                "metadata": 0,
                "dependent": 0,
                "still_image": 0
            },
            "tags": {
                "creation_time": "2021-02-14T02:11:02.000000Z",
                "language": "und",
                "handler_name": "ETI ISO Audio Media Handler",
                "vendor_id": "[0][0][0][0]"
            }
        }
    ]
}
chy-cpabe@ubuntu:~/ffmpeg-source/ffmpeg$ 

你可能感兴趣的:(音视频,音视频)