本章节为您介绍了iOS SDK和Mac SDK回调及监听的接口详情。

目录

AliRtcEngineDelegate回调如下所示。

说明 回调接口都在子线程。
API 描述 以上版本支持
onRemoteUserOnLineNotify 远端用户上线回调 1.1
onRemoteUserOffLineNotify 远端用户下线回调 1.1
onRemoteTrackAvailableNotify 远端用户音视频流发生变化时回调 1.1
onSubscribeChangedNotify 订阅结果回调 1.1
onNetworkQualityChanged 网络质量变化回调 1.4
onOccurWarning 警告回调 1.1
onOccurError 错误回调 1.1
onBye 被服务器踢出或者频道关闭时回调 1.1
onFirstPacketSentWithAudioTrack 首帧数据发送成功回调 1.11
onFirstRemoteVideoFrameDrawn 首帧渲染完回调 1.1
onFirstPacketReceivedWithAudioTrack 首包数据接收成功回调 1.13
onVideoDetectCallback RTC采集视频数据回调(仅iOS) 1.14
onUserAudioMuted 用户muteAudio通知回调(仅iOS) 1.14
onUserVideoMuted 用户muteVideo通知回调(仅iOS) 1.14
onUserAudioInterruptedBegin 用户音频被中断通知回调(仅iOS) 1.14
onUserAudioInterruptedEnded 用户音频中断结束通知回调(仅iOS) 1.14
onConnectionLost 网络连接断开回调 1.14
onTryToReconnect 网络连接正在尝试重连中回调 1.14
onConnectionRecovery 网络连接重连成功回调 1.14
onLeaveChannelResult 离开频道结果回调 1.15
onUserWillResignActive 远端用户应用退到后台回调(仅iOS) 1.15
onUserWillBecomeActive 远端用户应用返回前台回调(仅iOS) 1.15
onAliRtcStats 实时数据回调(2s触发一次) 1.16
onPerformanceLow 当前设备性能不足回调 1.16
onPerformanceRecovery 当前设备性能恢复回调 1.16
onUpdateRoleNotifyWithOldRole 用户角色发生变化化时通知 1.16

接口详情

  • onRemoteUserOnLineNotify:远端用户上线回调。

    - (void)onRemoteUserOnLineNotify:(NSString *)uid;          

    参数:

    参数 类型 描述
    uid NSString * 远端用户ID
  • onRemoteUserOffLineNotify:远端用户下线回调。

    - (void)onRemoteUserOffLineNotify:(NSString *)uid;         

    参数:

    参数 类型 描述
    uid NSString * 远端用户ID
  • onRemoteTrackAvailableNotify:远端用户音视频流发生变化时回调。

    - (void)onRemoteTrackAvailableNotify:(NSString *)uid audioTrack:(AliRtcAudioTrack)audioTrack videoTrack:(AliRtcVideoTrack)videoTrack;              

    参数:

    参数 类型 描述
    uid NSString * 远端用户ID
    audioTrack AliRtcAudioTrack 远端用户发生变化后的音频流
    videoTrack AliRtcVideoTrack 远端用户发生变化后的视频流
  • onSubscribeChangedNotify:订阅结果回调。

    - (void)onSubscribeChangedNotify:(NSString *)uid audioTrack:(AliRtcAudioTrack)audioTrack videoTrack:(AliRtcVideoTrack)videoTrack;                   

    参数:

    参数 类型 描述
    uid NSString * 远端用户ID
    audioTrack AliRtcAudioTrack 订阅成功的音频流
    videoTrack AliRtcVideoTrack 订阅成功的视频流
  • onNetworkQualityChanged:网络质量变化时回调,建议在网络质量较差的时候可以在界面上提示用户。

    - (void)onNetworkQualityChanged:(NSString *)uid 
            upNetworkQuality:(AliRtcNetworkQuality)upQuality             
            downNetworkQuality:(AliRtcNetworkQuality)downQuality;

    参数:

    参数 类型 描述
    uid NSString * 网络质量发生变化的用户ID
    upQuality AliRtcNetworkQuality 上行网络质量
    downQuality AliRtcNetworkQuality 下行网络质量
  • onOccurWarning:警告回调。目前警告回调可以忽略,不会影响正常使用 。

    - (void)onOccurWarning:(int)warn;

    参数:

    参数 类型 描述
    warn int 警告类型
  • onOccurError:错误回调。当回调的中参数error0x0102020C0x02010105时,需要先leaveChannel,再重新创建SDK实例,然后重新joinChannel。

    - (void)onOccurError:(int)error;

    参数:

    参数 类型 描述
    error int 错误类型
  • onBye:被服务器踢出或者频道关闭时回调。

    - (void)onBye:(int)code;

    参数:

    参数 类型 描述
    code int 消息类型
    • 1:被服务器踢出
    • 2:频道关闭
    • 3:同一个用户ID在其他端登录,被服务器踢出
  • onFirstPacketSentWithAudioTrack:首帧数据发送成功。

    - (void)onFirstPacketSentWithAudioTrack:(AliRtcAudioTrack)audioTrack videoTrack:(AliRtcVideoTrack)videoTrack;

    参数:

    参数 类型 描述
    audioTrack AliRtcAudioTrack 发送成功的音频流类型
    videoTrack AliRtcVideoTrack 发送成功的视频流类型
  • onFirstRemoteVideoFrameDrawn:远端视频流首帧渲染完回调。

    - (void)onFirstRemoteVideoFrameDrawn:(NSString *)uid videoTrack:(AliRtcVideoTrack)videoTrack;

    参数:

    参数 类型 描述
    uid NSString * 远端用户ID
    videoTrack AliRtcVideoTrack 渲染的流类型
  • onFirstPacketReceivedWithAudioTrack:首包数据接收成功。

    - (void)onFirstPacketReceivedWithAudioTrack:(AliRtcAudioTrack)audioTrack videoTrack:(AliRtcVideoTrack)videoTrack;

    参数:

    参数 类型 描述
    audioTrack AliRtcAudioTrack 发送成功的音频流类型
    videoTrack AliRtcVideoTrack 发送成功的视频流类型
  • onVideoDetectCallback(仅iOS可用):RTC采集视频数据回调。

    - (long)onVideoDetectCallback:(AliRtcVideoSource)type videoFrame:(AliRtcVideoDataSample *)videoFrame;

    参数:

    参数 类型 描述
    type AliRtcVideoSource 视频流类型
    videoFrame AliRtcVideoDataSample * 视频数据帧
  • onUserAudioMuted(仅iOS可用):用户muteAudio通知。

    - (void)onUserAudioMuted:(NSString *)uid audioMuted:(BOOL)isMute;

    参数:

    参数 类型 描述
    uid NSString * 执行muteAudio的用户ID
    isMute BOOL YES:静音;NO:未静音
  • onUserVideoMuted(仅iOS可用):用户muteVideo通知。

    - (void)onUserVideoMuted:(NSString *)uid videoMuted:(BOOL)isMute;

    参数:

    参数 类型 描述
    uid NSString * 执行muteVideo的用户ID
    isMute BOOL YES:推流黑帧;NO:正常推流
  • onUserAudioInterruptedBegin(仅iOS可用):用户音频被中断通知(一般用户打电话等音频被抢占场景)。

    - (void)onUserAudioInterruptedBegin:(NSString *)uid;

    参数:

    参数 类型 描述
    uid NSString * 音频被中断的用户ID
  • onUserAudioInterruptedEnded(仅iOS可用):用户音频中断结束通知(对应onUserAudioInterruptedBegin)。

    - (void)onUserAudioInterruptedEnded:(NSString *)uid;

    参数:

    参数 类型 描述
    uid NSString * 音频中断结束的用户ID
  • onConnectionLost:网络连接断开。Mac环境从1.15版本开始支持该回调。

    - (void)onConnectionLost;
  • onTryToReconnect:网络连接正在尝试重连中。Mac环境从1.15版本开始支持该回调。

    - (void)onTryToReconnect;
  • onConnectionRecovery:网络连接重连成功。Mac环境从1.15版本开始支持该回调。

    - (void)onConnectionRecovery;
  • onLeaveChannelResult:离开频道结果。调用leaveChannel接口后返回,如果调用leaveChannel后直接调用destroy,将不会收到此回调。

    - (void)onLeaveChannelResult:(int)result;

    参数:

    参数 类型 描述
    result int 成功返回0,失败返回错误码
  • onUserWillResignActive:远端用户应用退到后台。

    (void)onUserWillResignActive:(NSString *)uid

    参数:

    参数 类型 描述
    uid NSString * 用户ID
  • onUserWillBecomeActive:远端用户应用返回前台。

    (void)onUserWillBecomeActive:(NSString *)uid

    参数:

    参数 类型 描述
    uid NSString * 用户ID
  • onAliRtcStats:实时数据回调(2s触发一次)。

    - (void)onAliRtcStats:(AliRtcStats)stats;
    参数 类型 描述
    stats AliRtcStats 用户实时数据
  • onPerformanceLow:当前设备性能不足回调。

    - (void)onPerformanceLow;
  • onPerformanceRecovery:当前设备性能恢复回调。

    - (void)onPerformanceRecovery;
  • onUpdateRoleNotifyWithOldRole:当用户角色发生变化化时通知(调用setClientRole方法切换角色成功时触发此回调)。

    - (void)onUpdateRoleNotifyWithOldRole:(AliRtcClientRole)oldRole newRole:(AliRtcClientRole)newRole;
    参数 类型 描述
    oldRole AliRtcClientRole 变化前角色类型
    newRole AliRtcClientRole 变化前角色类型