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

在音视频处理领域,像素格式(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 家族仍将长期存在。

相关推荐
上海合宙LuatOS14 小时前
LuatOS核心库API——【audio 】
java·网络·单片机·嵌入式硬件·物联网·音视频·硬件工程
Android系统攻城狮16 小时前
Android16进阶之音频播放定位MediaPlayer.seekTo调用流程与实战(二百二十七)
音视频·mediaplayer·android16·音频进阶·音频性能实战
晚霞的不甘17 小时前
Flutter for OpenHarmony 可视化教学:A* 寻路算法的交互式演示
人工智能·算法·flutter·架构·开源·音视频
听麟17 小时前
HarmonyOS 6.0+ 跨端智慧政务服务平台开发实战:多端协同办理与电子证照管理落地
笔记·华为·wpf·音视频·harmonyos·政务
晚霞的不甘18 小时前
Flutter for OpenHarmony 实现计算几何:Graham Scan 凸包算法的可视化演示
人工智能·算法·flutter·架构·开源·音视频
零一iTEM18 小时前
MAX98357A_音频输出测试
单片机·嵌入式硬件·开源·音视频·硬件工程
Android系统攻城狮20 小时前
Android16进阶之获取播放位置MediaPlayer.getCurrentPosition调用流程与实战(二百二十八)
音视频·android16·音频进阶·音频性能实战
愚公搬代码1 天前
【愚公系列】《AI短视频创作一本通》020-AI短视频创作实例精解(文旅宣传AI短视频实例精解)
人工智能·音视频
有位神秘人1 天前
Android获取设备中本地音频
android·音视频
硫酸锌011 天前
使用ffmpeg合并文件夹内的所有*.mp4格式视频
ffmpeg·音视频