webrtc支持的最小宽度和高度

代码在:h264/sps_parser.cc

cpp 复制代码
//
// IMPORTANT ONES! Now we're getting to resolution. First we read the pic
// width/height in macroblocks (16x16), which gives us the base resolution,
// and then we continue on until we hit the frame crop offsets, which are used
// to signify resolutions that aren't multiples of 16.
//
// pic_width_in_mbs_minus1: ue(v)
sps.width = 16 * (reader.ReadExponentialGolomb() + 1);
cpp 复制代码
// Figure out the crop units in pixels. That's based on the chroma format's
// sampling, which is indicated by chroma_format_idc.
if (sps.separate_colour_plane_flag || chroma_format_idc == 0) {
  frame_crop_bottom_offset *= (2 - sps.frame_mbs_only_flag);
  frame_crop_top_offset *= (2 - sps.frame_mbs_only_flag);
} else if (!sps.separate_colour_plane_flag && chroma_format_idc > 0) {
  // Width multipliers for formats 1 (4:2:0) and 2 (4:2:2).
  if (chroma_format_idc == 1 || chroma_format_idc == 2) {
    frame_crop_left_offset *= 2;
    frame_crop_right_offset *= 2;
  }
  // Height multipliers for format 1 (4:2:0).
  if (chroma_format_idc == 1) {
    frame_crop_top_offset *= 2;
    frame_crop_bottom_offset *= 2;
  }
}
// Subtract the crop for each dimension.
sps.width -= (frame_crop_left_offset + frame_crop_right_offset);
sps.height -= (frame_crop_top_offset + frame_crop_bottom_offset);

读取图像的宽度和高度,以宏块(16x16)为单位,这给出了基本分辨率。然后,继续读取直到遇到帧裁剪偏移量,这些偏移量用于表示不是16的倍数的分辨率。

在这段代码中,"pic_width_in_mbs_minus1" 是一个无符号指数哥伦布编码(ue(v)),用于计算图像的宽度。最后一行代码则将图像的宽度设置为16乘以读取的值加1。

根据色度格式和色度平面标志来调整帧的裁剪偏移量,然后根据计算得到的偏移量来调整图像的宽度和高度,以实现正确的裁剪。

即支持16x16的块,然后按2的倍数做裁减。

相关推荐
许彰午29 分钟前
WebRTC只管流不管控——自研信令服务器的状态机设计
运维·服务器·webrtc
ltlovezh11 小时前
WebRTC SFU 架构:角色、推拉流与清晰度处理逻辑
webrtc
RTC老炮1 天前
WebRTC AEC3 算法原理分析
算法·webrtc
格林黄2 天前
WebSocket vs WebRTC 音频处理对比
websocket·音视频·webrtc
Fisher3Star2 天前
Mediasoup WebRtcTransport创建全流程解析
webrtc
Soari3 天前
挑战 100ms 延迟极限:深度拆解 dograh,构建企业级开源 WebRTC 实时语音智能体平台
开源·大模型·webrtc·实时音视频·voiceagent·语音智能体·dograh
被考核重击3 天前
WebRTC技术解析
webrtc
喵了几个咪4 天前
Kratos WebRTC 传输中间件:H5游戏P2P实时音视频与数据通信实战
游戏·微服务·中间件·golang·webrtc·实时音视频·kratos
喵个咪5 天前
Kratos + WebRTC 实战:实现浏览器 P2P 音视频通话与实时数据通信
后端·微服务·webrtc
肖爱Kun6 天前
Webrtc本端发candidate给对端
webrtc