NERtcEngine 常用回调
更多...
#import <NERtcEngineDelegate.h>
◆ onNERtcEngineConnectionStateChangeWithState:reason:
SDK和服务端的连接状态已改变回调。 该回调在 SDK 和服务端的连接状态发生改变时触发,并告知用户当前的连接状态和引起状态改变的原因。
- 参数
-
◆ onNERtcEngineDidClientRoleChanged:newRole:
直播场景下用户角色已切换回调。
用户加入房间后,通过 INERtcEngine#setClientRole: 切换用户角色后会触发此回调。例如从主播切换为观众、从观众切换为主播。
- 注解
- 直播场景下,如果您在加入房间后调用该方法切换用户角色,调用成功后,会触发以下回调:
- 自从
- V4.5.0
- 参数
-
◆ onNERtcEngineDidDisconnectWithReason:
- (void) onNERtcEngineDidDisconnectWithReason: |
|
(NERtcError) |
reason |
|
|
optional |
与服务器连接中断,可能原因包括:网络连接失败、服务器关闭该房间、用户被踢出房间等。
- 注解
- SDK 在调用 joinChannel 加入房间成功后,如果和服务器失去连接,就会触发该回调。
- 参数
-
◆ onNERtcEngineDidError:
- (void) onNERtcEngineDidError: |
|
(NERtcError) |
errCode |
|
|
optional |
发生错误回调。 该回调方法表示 SDK 运行时出现了网络或媒体相关的错误。 通常情况下,SDK上报的错误意味着 SDK 无法自动恢复,需要 App 干预或提示用户。
- 参数
-
◆ onNERtcEngineDidLeaveChannelWithResult:
- (void) onNERtcEngineDidLeaveChannelWithResult: |
|
(NERtcError) |
result |
|
|
optional |
退出房间回调。 App 调用 leaveChannel 方法后,SDK 提示 App 退出房间是否成功。
- 参数
-
◆ onNERtcEngineDidWarning:msg:
- (void) onNERtcEngineDidWarning: |
|
(NERtcWarning) |
warnCode |
msg: |
|
(NSString *) |
msg |
|
|
| |
|
optional |
发生警告回调。 该回调方法表示 SDK 运行时出现了网络或媒体相关的警告。 通常情况下,SDK上报的警告意味着 SDK 无法自动适配,需要 App 干预或提示用户。
- 自从
- V4.3.0
- 参数
-
◆ onNERtcEngineMediaRightChangeWithAudio:video:
- (void) onNERtcEngineMediaRightChangeWithAudio: |
|
(BOOL) |
isAudioBannedByServer |
video: |
|
(BOOL) |
isVideoBannedByServer |
|
|
| |
|
optional |
服务端禁言音视频权限变化回调。
- 自从
- v4.6.0
- 参数
-
isAudioBannedByServer | 是否禁用音频。
|
isVideoBannedByServer | 是否禁用视频。
|
◆ onNERtcEngineReconnectingStart
- (void) onNERtcEngineReconnectingStart |
|
|
|
|
optional |
重连开始回调。 客户端和服务器断开连接时,SDK 会进行重连,重连开始时触发此回调。重连结果请参考 onNERtcEngineRejoinChannel 、onNERtcEngineDidDisconnectWithReason。
◆ onNERtcEngineRejoinChannel:
- (void) onNERtcEngineRejoinChannel: |
|
(NERtcError) |
result |
|
|
optional |
重新加入房间回调。 在弱网环境下,若客户端和服务器失去连接,SDK会自动重连。自动重连成功后触发此回调方法。
- 参数
-
◆ onNERtcEngineUser:subStreamAudioMuted:
- (void) onNERtcEngineUser: |
|
(uint64_t) |
userID |
subStreamAudioMuted: |
|
(BOOL) |
muted |
|
|
| |
|
optional |
远端用户暂停或恢复发送音频辅流的回调。
- 自从
- V4.6.10
- 参数
-
userID | 用户 ID,提示是哪个用户的音频辅流。 |
muted | 是否停止发送音频辅流。
- YES:该用户已暂停发送音频辅流。
- NO:该用户已恢复发送音频辅流。
|
◆ onNERtcEngineUserAudioDidStart:
- (void) onNERtcEngineUserAudioDidStart: |
|
(uint64_t) |
userID |
|
|
optional |
远端用户开启音频回调。
- 注解
- 该回调由远端用户调用 enableLocalAudio 方法开启音频采集和发送触发。
- 参数
-
◆ onNERtcEngineUserAudioDidStop:
- (void) onNERtcEngineUserAudioDidStop: |
|
(uint64_t) |
userID |
|
|
optional |
远端用户停用音频回调。
- 注解
- 该回调由远端用户调用 enableLocalAudio 方法关闭音频采集和发送触发。
- 参数
-
◆ onNERtcEngineUserDidJoinWithUserID:userName:
- (void) onNERtcEngineUserDidJoinWithUserID: |
|
(uint64_t) |
userID |
userName: |
|
(NSString *) |
userName |
|
|
| |
|
optional |
远端用户加入当前房间回调。 该回调提示有远端用户加入了房间,并返回新加入用户的 ID;如果加入之前,已经有其他用户在房间中了,新加入的用户也会收到这些已有用户加入房间的回调。
该回调在如下情况下会被触发:
- 远端用户调用 joinChannelWithToken 方法加入房间。
- 远端用户网络中断后重新加入房间。
- 注解
- 直播场景下:
- 主播间能相互收到新主播加入频道的回调,并能获得该主播的用户 ID。
- 观众也能收到新主播加入频道的回调,并能获得该主播的用户 ID。
- 当 Web 端加入直播频道时,只要 Web 端有推流,SDK 会默认该 Web 端为主播,并触发该回调。
- 参数
-
userID | 用户 ID。 |
userName | 新加入房间的远端用户名。废弃字段,无需关注。 |
◆ onNERtcEngineUserDidJoinWithUserID:userName:joinExtraInfo:
- (void) onNERtcEngineUserDidJoinWithUserID: |
|
(uint64_t) |
userID |
userName: |
|
(NSString *) |
userName |
joinExtraInfo: |
|
(nullable NERtcUserJoinExtraInfo *) |
joinExtraInfo |
|
|
| |
|
optional |
◆ onNERtcEngineUserDidLeaveWithUserID:reason:
远端用户离开当前房间回调。 提示有远端用户离开了房间(或掉线)。用户离开房间有两个原因,即正常离开和超时掉线:
- 正常离开的时候,远端用户会收到相关消息消息,判断用户离开房间。
- 超时掉线的依据是,在一定时间内(40~50s),用户没有收到对方的任何数据包,则判定为对方掉线。
- 参数
-
userID | 离开房间的远端用户 ID。 |
reason | 远端用户离开的原因。 |
- kNERtcSessionLeaveNormal(0):正常离开。
- kNERtcSessionLeaveForFailOver(1):用户断线导致离开房间。
- kNERTCSessionLeaveForUpdate(2):用户因 Failover 导致离开房间,仅 SDK 内部使用。
- kNERtcSessionLeaveForKick(3):用户被踢导致离开房间。
- kNERtcSessionLeaveTimeout(4):用户超时退出房间。
◆ onNERtcEngineUserDidLeaveWithUserID:reason:leaveExtraInfo:
◆ onNERtcEngineUserSubStreamAudioDidStart:
- (void) onNERtcEngineUserSubStreamAudioDidStart: |
|
(uint64_t) |
userID |
|
|
optional |
远端用户开启音频辅流回调。
- 自从
- V4.6.10
- 参数
-
◆ onNERtcEngineUserSubStreamAudioDidStop:
- (void) onNERtcEngineUserSubStreamAudioDidStop: |
|
(uint64_t) |
userID |
|
|
optional |
远端用户停用音频辅流回调。
- 自从
- V4.6.10
- 参数
-
◆ onNERtcEngineUserSubStreamDidStartWithUserID:subStreamProfile:
- (void) onNERtcEngineUserSubStreamDidStartWithUserID: |
|
(uint64_t) |
userID |
subStreamProfile: |
|
(NERtcVideoProfileType) |
profile |
|
|
| |
|
optional |
远端用户开启屏幕共享辅流通道的回调。
- 注解
- 纯音频 SDK 禁用该接口,如需使用请前往云信官网下载并替换成视频 SDK。
- 参数
-
◆ onNERtcEngineUserSubStreamDidStop:
- (void) onNERtcEngineUserSubStreamDidStop: |
|
(uint64_t) |
userID |
|
|
optional |
远端用户停止屏幕共享辅流通道的回调。
- 注解
- 纯音频 SDK 禁用该接口,如需使用请前往云信官网下载并替换成视频 SDK。
- 参数
-
◆ onNERtcEngineUserVideoDidStartWithUserID:videoProfile:
- (void) onNERtcEngineUserVideoDidStartWithUserID: |
|
(uint64_t) |
userID |
videoProfile: |
|
(NERtcVideoProfileType) |
profile |
|
|
| |
|
optional |
远端用户开启视频回调。
启用后,用户可以进行视频通话或直播。
- 注解
- 纯音频 SDK 禁用该接口,如需使用请前往云信官网下载并替换成视频 SDK。
- 参数
-
◆ onNERtcEngineUserVideoDidStop:
- (void) onNERtcEngineUserVideoDidStop: |
|
(uint64_t) |
userID |
|
|
optional |
远端用户停用视频回调。
关闭后,用户只能进行语音通话或者直播。
- 注解
- 纯音频 SDK 禁用该接口,如需使用请前往云信官网下载并替换成视频 SDK。
- 参数
-
该协议的文档由以下文件生成: