音视频学习(六十七):音视频像素格式

在音视频处理领域,像素格式(Pixel Format)是视频编解码、图像处理和渲染的基础。像素格式决定了图像在内存中的组织方式,不同格式的选择会影响到存储效率、运算复杂度以及最终的画质表现。YUV 系列格式因其兼顾存储效率与图像质量,在视频编解码、硬件加速和传输过程中被广泛采用。尤其是 YUV420 家族和 NV12 格式,在 H.264/H.265 编解码器、GPU 图形接口以及视频处理管线中应用极为普遍。

YUV 色彩模型概述

YUV 的来源

YUV 是一种颜色编码方式,最初用于电视系统。与 RGB 模型不同,YUV 将图像分为 亮度(Y)色度(U、V) 两部分:

  • Y(Luma):表示亮度信息,决定图像的明暗层次;
  • U(Cb):表示蓝色色度偏移;
  • V(Cr):表示红色色度偏移。

人眼对亮度比对色度更敏感,因此在存储或传输时,通常会对 U、V 进行下采样,以减少数据量。

YUV 与 RGB 的关系

YUV 与 RGB 之间可以通过矩阵变换互相转换,常见公式如下(BT.601 标准):

bash 复制代码
Y=0.299R+0.587G+0.114B

U=−0.169R−0.331G+0.500B+128

V=0.500R−0.419G−0.081B+128

这种分离方式使得在视频压缩中可以利用人眼对色度的不敏感特性,有效降低码率。

YUV 采样格式分类

根据色度下采样方式,常见的 YUV 采样模式包括:

  1. YUV444:Y、U、V 各自都有完整分辨率,不进行色度下采样。质量最高,但存储开销大。
  2. YUV422:每两个像素共享一组 U、V 分量。数据量减少 1/3。
  3. YUV420:每 2×2 像素块共享一组 U、V 分量。数据量约为 YUV444 的一半。
  4. YUV411/410:更强的下采样,质量损失较大,现代视频编码中较少使用。

其中,YUV420 是现代视频编码的主流格式,因为它在图像质量与存储效率之间取得了良好平衡。

YUV420 系列格式

YUV420 根据 存储方式 的不同,衍生出多种具体格式。主要区别在于 Y、U、V 平面的排列顺序和存储方式

I420(YUV420P)

  • 存储顺序:Y 平面 → U 平面 → V 平面;
  • 每个平面单独存储,属于 Planar(平面型) 格式;
  • 内存布局:
    • Y:W×H 字节;
    • U:W/2×H/2 字节;
    • V:W/2×H/2 字节。

YV12

  • 与 I420 类似,但 U、V 平面顺序互换;
  • 存储顺序:Y 平面 → V 平面 → U 平面。

NV12

  • 存储顺序:Y 平面 → UV 交错平面;
  • 属于 Semi-Planar(半平面型) 格式;
  • 内存布局:
    • Y:W×H 字节;
    • UV:W×H/2 字节,其中 U、V 交错存储(U0V0U1V1...)。

NV21

  • 与 NV12 类似,但交错顺序为 VU;
  • 存储顺序:Y 平面 → VU 交错平面;
  • Android 摄像头 API 常用此格式。

NV12 与 YUV420 的比较

存储结构

  • I420/YV12:三个平面,存取灵活,便于单独处理 U、V 分量;
  • NV12/NV21:两个平面,内存访问更连续,适合硬件加速。

内存占用

假设分辨率为 1920×1080(Full HD):

  • Y:1920×1080 = 2073600 字节;
  • U:960×540 = 518400 字节;
  • V:960×540 = 518400 字节;
  • 总计 ≈ 3 MB(无论是 I420 还是 NV12,占用一致)。

硬件支持

  • NV12:广泛支持于 Intel QuickSync、NVIDIA NVDEC/NVENC、DirectX、VAAPI、FFmpeg;
  • NV21:Android 平台摄像头数据输出常用;
  • I420:软件编解码和跨平台通用。

典型应用场景

  • I420/YV12:图像处理、编解码中间数据、学术研究;
  • NV12:GPU 硬件编解码、Direct3D/OpenGL 渲染;
  • NV21:Android 摄像头数据采集。

优缺点总结

I420

  • 优点:通用性好,格式清晰;
  • 缺点:访存分散,对 GPU 加速不友好。

YV12

  • 优点:与 I420 类似,部分解码器历史兼容;
  • 缺点:V、U 顺序特殊,跨平台支持较弱。

NV12

  • 优点:连续内存布局,GPU 友好,硬件加速广泛支持;
  • 缺点:单独处理 U/V 不如 I420 方便。

NV21

  • 优点:Android 主流格式;
  • 缺点:跨平台兼容性差。

总结

NV12、YUV420 等像素格式作为视频处理中的基础环节,虽然只是底层数据存储方式,但对视频编解码效率、跨平台兼容性和最终渲染效果有着重要影响。随着 GPU 加速和移动端应用的发展,NV12 已成为硬件编解码与渲染的事实标准,而 I420 仍然在跨平台和软件处理场景中不可或缺。未来,随着 HDR、10bit/12bit 色深和 4:4:4 高质量视频的普及,YUV 格式可能会逐步向更高精度和更灵活的存储方式演进,但在高效视频传输与压缩领域,YUV420 家族仍将长期存在。

相关推荐
be or not to be1 天前
HTML入门系列:从图片到表单,再到音视频的完整实践
前端·html·音视频
LCG米1 天前
基于ESP32-S3与OV5640的高清低延迟无线视频传输系统构建教程
音视频
Angelina_Jolie1 天前
基于 Retinex 的 TempRetinex:适用于不同光照条件下低光视频的无监督增强方法
计算机视觉·音视频
山海青风1 天前
藏文TTS介绍:6 MMS 项目的多语言 TTS
人工智能·python·神经网络·音视频
Everbrilliant891 天前
FFmpeg解码OpenSL、ANativeWindow播放实现音视频同步
ffmpeg·音视频·opensl音视频同步播放·音视频同步播放·唇音同步·音视频时钟漂移·播放时钟同步
一点晖光1 天前
ffmpeg实现图片转视频效果
ffmpeg·音视频
咕噜船长1 天前
使用Qwen3-VL模型批量标注视频内容(视频理解)
人工智能·pytorch·深度学习·音视频·视频
音视频牛哥1 天前
内网RTSP直连 + 公网RTMP上云:基于SmartMediakit的 Android双引擎架构设计
音视频·安卓rtsp服务器·安卓轻量级rtsp服务·安卓rtsp摄像头推流·安卓摄像头rtmp推流·安卓 camera2 rtsp·安卓camera2 rtmp
二等饼干~za8986681 天前
碰一碰发视频系统源码开发搭建--技术分享
java·运维·服务器·重构·django·php·音视频
EasyCVR2 天前
视频汇聚平台EasyCVR筑牢消防领域可视化监控防线
运维·人工智能·音视频