在视频通话或视频互动直播场景下,视频画面是否清晰流畅,很大程度上决定了用户体验。视频编码属性包含视频分辨率、帧率、码率等影响视频质量的参数设置。你可以通过设置视频编码属性,控制视频流在不同网络条件下的展示方式。百家云 SDK 提供了 setVideoEncoderParam 方法设置视频编码属性。此方法可以在任何阶段调用。如果在加入房间后不需要重新设置视频编码属性,百家云建议在 startLocalPreview 前调用 setVideoEncoderParam,以加快首帧出图的时间。相关函数接口在 ios-sdk 2.5.5 及以上版本支持
视频编码属性的参数如下所示:
上述参数设置的均为理想情况下的最大值。当视频因网络环境等原因无法达到设置的分辨率、帧率或码率的最大值时,取值会尽量接近最大值。
BRTCVideoEncParam videoEncParams; videoEncParams.bandWidth = 400; videoEncParams.fps = 15; videoEncParams.width = 640; videoEncParams.height = 360; // 设置视频编码参数 m_pBrtc->setVideoEncoderParam(videoEncParams);
通常来讲,视频编码参数的选择要根据产品实际情况和场景来确定。比如,在一对一教学场景下,老师和学生的窗口比较大,要求分辨率会高一点,随之帧率和码率也要高一点; 如果是一对四场景, 老师和学生的窗口都比较小,分辨率可以低一点,对应的码率帧率也会低一点,以减少编解码的资源消耗和缓解下行带宽压力。
一般可按下列场景中的推荐值进行设置。
在视频旋转场景中,我们主要关注播放端的行为。setVideoEncoderRotation 设置不影响本地画面的预览方向,但会影响房间中其他用户所观看到(以及云端录制文件)的画面方向。
m_pBrtc->setVideoEncoderRotation(BRTCVideoRotation_0);
默认情况下,SDK 在编码时不对视频作镜像操作。你可以通过 setVideoEncoderMirror 参数来设置视频编码的镜像模式决定远端用户看到的视频画面。
m_pBrtc->setVideoEncoderMirror(true);
在网络带宽比较充裕的情况下,清晰和流畅是可以兼顾的,但当用户的网络并不理想时,究竟是优先保证清晰还是优先保证流畅?您可以通过指定 setNetworkQosParam 中的 BRTCDef.BRTCNetworkQosParam 参数来做出选择。
BRTCNetworkQosParam qosParams; qosParams.preference = BRTCVideoQosPreferenceClear; // 设置网络 qos 参数,弱网情况下保清晰 m_pBrtc->setNetworkQosParam(qosParams);
本功能需要在推流前设定,独立设置小流的分辨率、帧率和码率等信息。
在拉流端,使用函数 setRemoteVideoStreamType 选定远端用户的大小画面。
// 发布端打开双路编码功能 BRTCVideoEncParam param; param.fps = 15; param.bandWidth = 100; param.width = 160; param.height = 120; m_pBrtc->enableEncSmallVideoStream(true, param); // 订阅端拉流逻辑 m_pBrtc->muteRemoteAudio(userId, false); m_pBrtc->muteRemoteVideoStream(userId, false); // 在开始拉流远端音视频流前,指定大流 m_pBrtc->setRemoteVideoStreamType(userId, BRTCVideoStreamTypeBig); // 指定小流 // m_pBrtc->setRemoteVideoStreamType(userId, BRTCVideoStreamTypeSmall); m_pBrtc->startRemoteView(userId, BRTCVideoStreamTypeBig, view);
设置弱网条件下流是否开启自适应回退机制。 当开启时,网络不理想的环境下,自动大流关闭保留小流,如果网络条件还不好就关闭视频,只留音频。如果网络变好,会从只留音频变成恢复推小流,如果网络还很宽裕,再恢复成推大小流。当视频流自动关闭和恢复时,您会通过此回调 onLocalVideoFallback 收到通知。
class BRTCCore : public BRTCCallback, public BRTCAudioFrameCallback { public: // interface BRTCCallback void onLocalVideoFallback(bool isFallbackOrRecover) override; private: BRTC* m_pBrtc = nullptr; } void BRTCCore::onLocalVideoFallback(bool isFallbackOrRecover) { LOG(INFO) << "video fallback[" << isFallbackOrRecover << "]"; // 添加视频回退处理逻辑 } BRTCCore::BRTCCore() { m_pBrtc = getBRTCShareInstance(); m_pBrtc->setCallback(this); m_pBrtc->setVideoFallbackEnable(true); }
设置视频编码参数
在视频通话或视频互动直播场景下,视频画面是否清晰流畅,很大程度上决定了用户体验。
视频编码属性包含视频分辨率、帧率、码率等影响视频质量的参数设置。你可以通过设置视频编码属性,控制视频流在不同网络条件下的展示方式。
百家云 SDK 提供了 setVideoEncoderParam 方法设置视频编码属性。此方法可以在任何阶段调用。
如果在加入房间后不需要重新设置视频编码属性,百家云建议在 startLocalPreview 前调用 setVideoEncoderParam,以加快首帧出图的时间。
相关函数接口在 ios-sdk 2.5.5 及以上版本支持
分辨率、帧率和码率
视频编码属性的参数如下所示:
上述参数设置的均为理想情况下的最大值。当视频因网络环境等原因无法达到设置的分辨率、帧率或码率的最大值时,取值会尽量接近最大值。
视频参数推荐值
通常来讲,视频编码参数的选择要根据产品实际情况和场景来确定。比如,在一对一教学场景下,老师和学生的窗口比较大,要求分辨率会高一点,随之帧率和码率也要高一点; 如果是一对四场景, 老师和学生的窗口都比较小,分辨率可以低一点,对应的码率帧率也会低一点,以减少编解码的资源消耗和缓解下行带宽压力。
一般可按下列场景中的推荐值进行设置。
编码器输出方向设置
在视频旋转场景中,我们主要关注播放端的行为。setVideoEncoderRotation 设置不影响本地画面的预览方向,但会影响房间中其他用户所观看到(以及云端录制文件)的画面方向。
镜像模式
默认情况下,SDK 在编码时不对视频作镜像操作。你可以通过 setVideoEncoderMirror 参数来设置视频编码的镜像模式决定远端用户看到的视频画面。
Qos 策略设定
在网络带宽比较充裕的情况下,清晰和流畅是可以兼顾的,但当用户的网络并不理想时,究竟是优先保证清晰还是优先保证流畅?您可以通过指定 setNetworkQosParam 中的 BRTCDef.BRTCNetworkQosParam 参数来做出选择。
大小流编码
本功能需要在推流前设定,独立设置小流的分辨率、帧率和码率等信息。
在拉流端,使用函数 setRemoteVideoStreamType 选定远端用户的大小画面。
视频自动回退机制
设置弱网条件下流是否开启自适应回退机制。 当开启时,网络不理想的环境下,自动大流关闭保留小流,如果网络条件还不好就关闭视频,只留音频。如果网络变好,会从只留音频变成恢复推小流,如果网络还很宽裕,再恢复成推大小流。
当视频流自动关闭和恢复时,您会通过此回调 onLocalVideoFallback 收到通知。