内容提要
最近项目中遇到一个问题,用户上传一个 H.265 编码的视频,在 iOS 平台上解码时出现异常。经过调研分析,发现问题出在视频格式的解码处理流程上,特别是在 Open-GOP 格式下。解决办法是丢弃 B 帧,需要用到 H.265 相关的知识内容来确定 B 帧。
关键要点
-
用户上传的 H.265 编码视频在 iOS 平台解码时出现异常。
-
问题出在 Open-GOP 格式的视频解码处理流程上。
-
使用 AssetReader 解码时在频繁 Seek 场景下会出现卡死。
-
VideoToolBox 解码在 iOS 16 上出现花屏,iOS 17 上解码失败,错误码为 -12909。
-
AssetReader 解码被认为是黑盒,开发者可操作空间小,重点放在 VideoToolBox 上。
-
VideoToolBox 解码流程与 MediaCodec 不同,需要前置操作,如判断 NALU 类型和提取 VPS、SPS、PPS。
-
H.265 视频需要多提取一个 VPS 的 NALU,确认 VideoToolBox 使用流程无误后,问题在于视频格式的解码处理流程。
-
Open-GOP 格式的 GOP 结构导致 Seek 到 I 帧后 B 帧缺少参考内容,解码失败。
-
解决办法是丢弃 B 帧,第一种补上参考帧的方法耗时不可取。
-
需要用到 H.265 的 NALU 类型知识来确定 B 帧。
延伸问答
在 iOS 平台上解码 H.265 视频时遇到什么问题?
在 iOS 平台上解码 H.265 视频时,特别是 Open-GOP 格式的视频,可能会出现卡死、花屏或解码失败的情况。
为什么 Open-GOP 格式的视频在解码时会失败?
Open-GOP 格式的视频在解码时失败是因为 I 帧后面的 B 帧缺少参考内容,导致解码器无法正常工作。
如何解决 H.265 Open-GOP 视频解码中的 B 帧问题?
解决 H.265 Open-GOP 视频解码中的 B 帧问题的方法是丢弃 B 帧,而不是尝试补充参考帧。
VideoToolBox 解码与 AssetReader 解码有什么不同?
VideoToolBox 解码需要更多的前置操作,如判断 NALU 类型和提取 VPS、SPS、PPS,而 AssetReader 解码被视为黑盒,开发者可操作空间较小。
在 iOS 16 和 iOS 17 上解码 H.265 视频时分别会出现什么错误?
在 iOS 16 上解码 H.265 视频时可能出现花屏,而在 iOS 17 上则会解码失败,错误码为 -12909。
解码 H.265 视频时需要提取哪些 NALU 类型?
解码 H.265 视频时需要提取 VPS、SPS、PPS 和一个额外的 VPS NALU 类型。