1.音视频开篇

目录

音视频播放的原理

音视频数据格式YUV

YUV数据存储比

[​编辑 YUV空间格式](#编辑 YUV空间格式)

RGB与YUV转换


音视频播放的原理

主要分为:解协议->解封装->解码->音视频同步->播放。当然,如果是本地播放,没有解协议这一步骤。

采集数据其实就可以反过来

音视频数据格式YUV

RGB 是色彩空间的格式:分别是红、绿、蓝色,数值是0-255,比如我们屏幕像素可能就是RGB的混合显示。

YUV数据存储比

YUV数据由Y、U、V三个分量组成,现在通常说的YUV指的是YCbCr

  • Y:表示亮度(Luminance、Luma),占8bit(1字节)
  • CbCr :表示色度(Chrominance、Chroma)
    • Cb(U):蓝色色度分量,占8bit(1字节)
    • Cr(V):红色色度分量,占8bit(1字节)

那比如我们常说的YUV(4:4:4)是指空间上的占比:4*4矩阵,Y、U、V比例为4:4:4,相当于一个像素点是由yuv组成的 ,每一个 Y 分量对于一对 UV 分量

每两个 Y 分量共用一对 UV 分量,每像素占用 (Y + 0.5U + 0.5V = 8 + 4 + 4 = 16bits)2 字节;水平方向Y分量与UV分量2:1采样,垂直方向不降低采样率

每四个 Y 分量共用一对 UV 分量,每像素占用 (Y + 0.25U + 0.25V = 8 + 2 + 2 = 12bits)1.5 字节。水平和垂直方向上Y分量和UV分量对的采样比都是2:1

YUV空间格式

主要分为packet、planar、semi-planar三种:

◆ packet:打包格式,即先存储一个yuv,再存储下一个yuv;

◆ planar:平面格式,即先存储y平面,再存储u平面,再存储v平面;

◆ semi-planar:先存储y平面,再存储uv平面;

YUV422各种存储格式如下:

YUV420各种存储格式如下:

◆NV:NV系列都属于semi-plane系列,"12"、"16"代表先U后V,"21"、"61"代表先V后U

◆ 12、16:代表一个像素占的位数

RGB与YUV转换

转换公式1

  • RGB的取值范围是[0,255]

  • Y的取值范围是[16,235]

  • UV的取值范围是[16,239]

    Y = 0.257R + 0.504G + 0.098B + 16
    U = -0.148R - 0.291G + 0.439B + 128
    V = 0.439R - 0.368G - 0.071B + 128

    R = 1.164(Y - 16) + 2.018(U - 128)
    G = 1.164(Y - 16) - 0.813(V - 128) - 0.391(U - 128)
    B = 1.164(Y - 16) + 1.596(V - 128)

公式2

  • RGB的取值范围是[0, 1]

  • Y的取值范围是[0, 1]

  • UV的取值范围是[-0.5, 0.5]

    Y = 0.299R + 0.587G + 0.114B
    U = 0.564(B - Y) = -0.169R - 0.331G + 0.500B
    V = 0.713(R - Y) = 0.500R - 0.419G - 0.081B

    R = Y + 1.403V
    G = Y - 0.344U - 0.714V
    B = Y + 1.770U

公式3

  • RGB的取值范围是[0, 255]

  • YUV的取值范围是[0, 255]

    Y = 0.299R + 0.587G + 0.114B
    U = -0.169R - 0.331G + 0.500B + 128
    V = 0.500R - 0.419G - 0.081B + 128

    R = Y + 1.403(V - 128)
    G = Y - 0.343(U - 128) - 0.714(V - 128)
    B = Y + 1.770(U - 128)

相关推荐
王道长服务器 | 亚马逊云6 小时前
AWS + 发财CMS:高效采集站的新形态
服务器·网络·云计算·音视频·aws
EasyDSS7 小时前
无人机RTMP推流平台EasyDSS:构建新一代智能交通视频监控系统
音视频·无人机
Vue10248 小时前
uniapp 使用renderjs 封装 video-player 视频播放器, html5视频播放器-解决视频层级、覆盖、播放卡顿
uni-app·音视频·html5
mortimer11 小时前
使用阿里AI模型去除背景噪音:单文件40行代码实现
python·ffmpeg·阿里巴巴
骄傲的心别枯萎13 小时前
RV1126 NO.37:OPENCV的图像叠加功能
人工智能·opencv·计算机视觉·音视频·视频编解码·rv1126
今天也想MK代码20 小时前
WebRtc语音通话前置铃声处理
ffmpeg·webrtc
库奇噜啦呼21 小时前
【iOS】音频与视频播放
ios·音视频·cocoa
撬动未来的支点1 天前
解读ffmpeg控制台输出
ffmpeg
小小测试开发1 天前
Playwright进阶:录制视频与追踪功能,让自动化过程“看得见、可分析”
自动化·音视频
开开心心就好1 天前
微软官方出品:免费数据恢复工具推荐
网络·笔记·microsoft·pdf·word·音视频·symfony