为方便开发者快速接入,降低开发者接入门槛,即构实时音视频SDK 通过大量线上数据验证,沉淀出多种场景化配置方案。开发者可根据所需场景,选择对应的房间模式,SDK 将自动应用适合该场景的音视频编解码器、音视频参数、流控策略等配置,从而快速实现该场景下的最佳效果。当前支持场景包括秀场直播、KTV、标准 1v1 音视频通话、高画质 1v1 音视频通话、标准语聊房、高音质语聊房。
看到以上介绍是不是非常期待,有了场景化音视频配置这个功能,提升50%效率不为过,下面我们来详细介绍一下。
调用方式
在创建引擎的 profile
(ZegoEngineProfile) 参数中的 scenario
(ZegoScenario) 字段需要指定一个场景,您可以根据实际音视频业务场景来选择。
目前 实时音视频SDK 支持下列场景:
同一个房间内的用户,建议使用同一种房间场景,以获得最佳效果。
场景(支持版本:3.0.0 及以上) | 场景描述 | 关键配置说明 |
---|---|---|
Broadcast | 直播场景,适用于秀场、游戏、电商、教育大班课等一对多直播的场景,对音画质量、流畅度、兼容性进行了优化。 注意:即便是直播场景,SDK 也没有业务上的 “角色” 之分(例如主播、观众),房间内的所有用户均可推拉流。 | 分辨率:540p。帧率:24 fps。音频编码器兼容:与 Web SDK 互通时需要服务端转码。 |
StandardVideoCall | 标准音视频通话场景,适用于 1 V 1 视频或语音通话场景。 | 分辨率:360p。帧率:15 fps。音频编码器兼容:仅可用于 RTC 推流,转推 CDN 时需要服务端转码。 |
HighQualityVideoCall | 高品质音视频通话场景,与 StandardVideoCall 场景类似,但该场景默认采用了比 StandardVideoCall 场景更高的视频帧率、码率、分辨率 ,适用于对画质要求较高的视频通话场景。 | 分辨率:540p。帧率:24 fps。音频编码器兼容:仅可用于 RTC 推流,转推 CDN 时需要服务端转码。 |
StandardChatroom | 标准语聊房场景,适用于多人纯语音通话。(节省流量) 注意:在实时音视频 (ExpressVideo) SDK 上,此场景默认不开启摄像头。 | 音频编码器兼容:仅可用于 RTC 推流,转推 CDN 时需要服务端转码。 |
HighQualityChatroom | 高品质语聊房场景,与 StandardChatroom 场景类似,但此场景默认采用了比 StandardChatroom 场景下更高的音频码率。适用于对音质要求较高的多人纯语音通话场景。 注意:在实时音视频 (ExpressVideo)SDK 上,此场景默认不开启摄像头。 | 音频编码器兼容:仅可用于 RTC 推流,转推 CDN 时需要服务端转码。 |
Karaoke | 卡拉 OK (KTV)场景,适用于实时合唱、在线 K 歌场景,对延迟、音质、耳返、回声消除等进行了优化,同时还保障了多人合唱时的精准对齐和超低时延。 注意:在实时音视频(ExpressVideo)SDK 上,此场景默认不开启摄像头。 | 音频编码器兼容:仅可用于 RTC 推流,转推 CDN 时需要服务端转码。 |
Default | 默认(通用)场景,若上述场景枚举均不符合开发者的实际应用场景,可以使用此默认场景。 | 分辨率:360p。帧率:15 fps。音频编码器兼容:与 Web SDK 互通时需要服务端转码。 |
若指定场景后,开发者有对 SDK 音视频配置精细化控制的需求,可通过其他 API 进行配置,优先级高于场景化配置,详情请参考 常用视频配置、流量控制 文档。
若您的 App 有多种音视频业务场景,例如,同时有 1v1 音视频通话场景和秀场直播场景。您可以在不销毁引擎 (destroyEngine) 的前提下,在退出房间后,通过调用 setRoomScenario 切换场景,然后再登录其他房间。
- 登录房间后,不再允许修改房间场景。如需进行场景切换,需先退出房间,若登录了多个房间,则需要退出所有房间后才能进行场景切换。若在已登录房间的情况下调用 setRoomScenario ,该次调用无效,并会通过 onDebugError 回调错误码 1000067。
- 在退出房间后,一旦通过 setRoomScenario 进行切换场景,此前通过上方 API 所有进行过的相关音视频的精细化配置,都会被重置为新场景的默认值,因此建议先设置场景后,再通过其他 API 调整音视频配置。
- 若有其他场景的设置需求或配置疑问,请联系 ZEGO 技术支持。
本文来自作者投稿,如需转载,请注明出处:实时互动网https://www.nxrte.com/jishu/yinshipin/6877.html