FFmpeg再学习 -- 视音频基础知识

最近一直在看雷霄骅 FFmpeg 系列视频,然后将自己的理解总结一下。

参看:《基于 FFmpeg + SDL 的视频播放器的制作》课程的视频

一、视频播放器原理 


自己理解:

比如一个 MP4 文件,它是有音频、有视频两部分封装的。PCM 音频采样数据和 YUV 视频像素数据,通过音视频编码 Encode,生成AAC和H.264文件,最后封装成 MP4 文件。

然后,我想起我使用 PR 剪辑视频时,其实就是这个过程,将音视频合成MP4文件的。




二、常用播放器

     

VLC、CyberLink PowerDVD 14、完美风暴

下载:VLC media player 下载

下载:powerDVD 14 破解 安装 方法 下载 地址 免费

下载:完美解码V20170702官方版

三、信息查看工具

(1)综合信息查看:MediaInfo


可选择以什么形式查看,比如我们以文本形式查看:


任意4个文件的总体信息

(2)二进制信息查看

下载:UltraEdit



(3)单项详细分析

封装格式: Elecard Format Analyzer


MKV、 MP4、 AVI封装格式信息



视频编码数据: Elecard Stream Eye


H.264码流分析信息

               红色的帧: I帧;蓝色的帧: P帧;绿色的帧: B帧。

视频像素数据: YUV Player


YUV视频像素数据
 

音频采样数据: Adobe Audition


PCM音频采样数据 


四、封装格式

(1)封装格式的作用

视频码流和音频码流按照一定的格式存储在一个文件中。

(2)格式类型


五、视频编码数据

(1)视频编码的作用

将视频像素数据(RGB,YUV等)压缩成为视频码流,从而降低视频的数据量。

(2)视频编码类型


六、音频编码数据

(1)音频编码的作用

将音频采样数据(PCM 等)压缩成为音频码流,从而降低音频的数据量。

(2)音频编码类型


七、视频像素数据

(1)视频像素数据作用

保存了屏幕上每个像素点的像素值。

(2)格式

常见的像素数据格式有 RGB24,RGB32,YUV420P,YUV422P,YUV444P 等。压缩编码中一般使用的是 YUV 格式的像素数据,最为常见的格式为 YUV420P。

(3)特点

视频像素数据体积很大,一般情况下 1 小时高清视频的 RGB24 格式的数据体积为:

        3600*25*1920*1080*3=559.9GByte
PS:这里假定帧率为25Hz,取样精度8bit。

(4)RGB 格式简介

Red、 Green、 Blue三种颜色,可以混合成世界上所有的颜色。
彩色图像中每个点,由R、 G、 B三个分量组成。
以 RGB24 为例,图像像素数据的存储方式如下:

       

从图中可以看出, RGB24依次存储了每个像素点的R、 G、 B信息。
PS: BMP文件中存储的就是RGB格式的像素数据。

(5)YUV格式简介

相关实验表明,人眼对亮度敏感而对色度不敏感。因而可以将亮度信息和色度信息分离,并对色度信息采用更“狠”一点的压缩方案,从而提高压缩效率。
YUV 格式中, Y 只包含亮度信息,而 UV 只包含色度信息。以 YUV420P 为例,图像像素数据的存储方式如图所示。从图中可以看出, YUV420P 首先存储了整张图像的Y信息,然后存储整张图像的 U 信息,最后存储了整张图像的 V 信息。


8、音频采样数据

(1)音频采样数据作用

保存了音频中每个采样点的值。

(2)特点

音频采样数据体积很大,一般情况下一首4分钟的PCM格式的
歌曲体积为:
        4*60*44100*2*2=42.3MByte
PS:这里假定采样率为44100Hz,采样精度为16bit。

(3)PCM格式简介

单声道的情况下按照顺序存储每个采样点的数据。

双声道的情况下按照“左右、左右”的顺序存储每个采样点两个声道的数据。




  • 29
    点赞
  • 38
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
ffmpeg-web-pusher是一个基于FFmpeg的实用工具,用于实时将音频和视频内容推送到Web服务器。它可以将本地视频或音频文件编码并传输到网络服务器上,从而实现实时推流功能。 ffmpeg-web-pusher具有以下几个主要功能: 1. 编码和推送:通过FFmpeg进行音视频编码,然后使用HTTP或RTMP协议将数据推送到Web服务器。这样,可以实现通过Web浏览器或其他支持Web播放的设备来实时观看视频或听取音频。 2. 多种格式支持:ffmpeg-web-pusher支持多种音视频格式,包括常见的MP4、FLV、AVI等。无论是从本地文件还是摄像头进行推流,都可以根据需要选择合适的格式。 3. 音频和视频参数设置:通过ffmpeg-web-pusher,可以根据需求设置音频和视频的各种参数,如比特率、帧率、分辨率等。这样可以根据网络带宽和终端设备的性能来进行适当的优化。 4. 实时监控:ffmpeg-web-pusher提供实时监控功能,可以显示当前推送的音频和视频的传输状态,如帧率、码率、延迟等。这对于调试和优化音视频传输非常有帮助。 ffmpeg-web-pusher是一个功能强大而灵活的工具,可以帮助开发人员实现实时音视频推流功能,并在Web浏览器上进行播放。无论是在线直播、视频会议、视频监控还是其他实时音视频场景,都可以通过使用ffmpeg-web-pusher来实现。它在提供高质量音视频传输的同时,还可以根据具体需求进行各种参数调整,使其更好地适应不同的应用场景。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

聚优致成

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值