多房间管理
更新时间: 2024/04/07 18:17:53
在娱乐社交与在线教育场景中,App 用户往往需要同时加入多个房间,接收多个房间的音视频流。网易云信 NERTC SDK 提供多房间管理功能,隔离多个房间的消息和回调,在跨房间连麦场景和超级小班课场景都可以实现更灵活的房间管理业务。
功能概述
在 V4.5.0 及之后版本中,NERTC SDK 支持多房间管理功能,App 用户可以同时加入多个房间,接收多个房间的音视频流,且房间数量无限制。 多房间管理功能通常用于以下场景:
-
跨房间连麦与PK
跨房间连麦场景中,主播 A 房间中的用户和主播 B 可以同时加入彼此的房间进行连麦,与主播们另外加入一个公共房间的方案相比,同时加入多房间方案可以避免房间切换的复杂操作,直播体验更加友好。
-
超级小班课
超级小班课场景中,教师端加入大班房间,通过 RTC 或旁路推流实现课程直播,大班房间中的学生们各自加入小班房间,教师端也同时登录小班房间与学生端进行实时音视频互动,回答学生提问或组织讨论。根据场景需要,也可以配备一名助教老师登录小组房间,协助维持课堂秩序或解答学生问题。
V5.3.0 及之后版本,子房间支持调用 NERtcChannel#setExternalVideoSource
和 NERtcChannel#pushExternalVideoFrame
设置外部视频输入,详细的使用方法请参见 自定义视频采集。
V5.3.0 及之后版本,子房间支持调用 NERtcChannel#enableAudioVolumeIndication
监测子房间用户的实时音量,详细的使用方法请参见 监测发言者音量。
V5.3.0 及之后版本,子房间支持调用 NERtcChannel#switchCamera
或 NERtcChannel#switchCameraWithPosition
切换摄像头,详细的使用方法请参见 视频设备管理。
注意事项
- SDK 仅支持用户同一时间在一个房间内发布媒体流。如果用户已在房间 1 内发流,在房间 2 内调用发流相关方法时,这些方法会调用失败并返回 30005 错误码。
- 您可以在直播场景或通信场景中使用多房间功能,且房间数量无限制。
- 调用
NERtc#leaveChannel
离开第一个加入的房间(主房间)时,会同时退出所有子房间。如果要离开单个子房间,请调用NERtcChannel#leaveChannel
接口。
实现方法
多房间管理功能通过 NERtcChannel
类和 NERtcChannelCallback
类实现多房间控制。
通过 NERtc
接口类的 createChannel
方法加入第一个房间之后,如果需要同时加入其他房间,可以多次调用 NERtcEx 接口类的 createChannel
,再通过不同的 channel_name
创建多个 NERtcChannel
对象。每个 NERtcChannel
对象对应一个房间,然后分别调用 NERtcChannel
中的 joinChannel
方法加入对应的房间。
API 时序
加入多房间
实现多房间功能的主要步骤如下:
-
初始化引擎。
调用
init
方法,创建并初始化引擎。 -
创建并加入主房间 1(主房间)。
调用
NERtc
接口类的joinChannel
方法创建并加入房间 1。 -
创建并加入房间 2(子房间)。
- 调用
NERtcEx
接口类的createChannel
方法,通过channelName
创建一个NERtcChannel
对象。 - 调用
NERtcChannel
类的setChannelCallback
方法,接收房间 2 的回调通知。 - 调用
NERtcChannel
类的joinChannel
方法加入房间。
加入子房间时,您可以设置单独的 uid,该 uid 可以跟主房间的 uid 不一样。
用户加入子房间后,音视频流的状态如下:
- 音频:默认自动订阅房间内所有其他用户的音频流,但不发布本地音频流。如果您没有在其他房间发布音频流,您可以在加入房间后调用
NERtcChannel
类的enableLocalAudio
方法,设置参数为true
,发布音频流。 - 视频:默认不订阅房间内其他用户的视频流,也不发布本地视频流。您可以调用
NERtcChannel
类的相关接口,修改视频流的发布和订阅状态。
- 调用
-
创建并加入其他房间。
如果需要加入更多的房间,重复步骤 3 即可。
- 加入多个房间时,请确保每个房间的房间名不同。
- 同一时间,本地的音视频流只能发布到一个房间。如果需要调整发流的状态,请参考多房间时修改发流状态。
-
离开房间。
离开主房间时,会自动离开所有子房间。离开房间时请务必注意您离开的是主房间还是子房间,选择对应接口类中的方法,以免误操作。
例如本地用户加入了房间 1(主房间)、房间 2(子房间)、房间 3(子房间),用户可以随时离开任意一个子房间,不影响其他几个房间,但一旦离开了主房间,所有房间会自动离开。
- 调用
NERtcChannel#leaveChannel
离开子房间。 - 调用
NERtc#leaveChannel
离开主房间。
- 调用
修改发流状态
同一时间,本地的音视频流只能发布到一个房间。 如果用户加入房间 1 并在房间 1 中发布音频或视频流,后续在其他房间中无法发布流,调用发流相关方法会报错 30005。例如,如果用户加入房间 1 后,如果使用默认配置,加入房间后 SDK 自动采集并发送本地音频流到房间 1。后续即使以音频发送开启的状态加入其他房间,也只能在房间 1 中发流。
如果需要调整发流的状态,请在发流的房间中停止发布音频流或视频流,然后在需要发流的房间中,开始发布音频流或视频流即可。
示例代码
java//初始化
NERtcOption option = new NERtcOption();
option.logLevel = NERtcConstants.LogLevel.INFO;
NERtcEx.getInstance().init(mActivity.getApplicationContext(), appKey, this, option);
//加入主房间
NERtcEx.getInstance().joinChannel(token, mChannelName, mUid);
//收到主房间 onJoinChannel 成功的回调后才能加入子房间
NERtcChannel channel = NERtcEx.getInstance().createChannel(subChannelName);
channel.joinChannel(subToken);
// 如果需要单独指定指定子房间的uid , 不指定默认用主房间的uid
// channel.joinChannel(subToken,userId );