TRTC事件列表
通过 trtc.on(TRTC.EVENT.XXX) 监听指定的事件。您可以通过这些事件实现管理房间用户列表,以及管理用户的流状态,感知网络状态等功能,下面是事件的详细介绍。
注意:
- 事件需要在事件触发之前监听,这样才能收到相应的事件通知,因此建议在 trtc 进房前完成事件监听,这样才能确保不会漏掉事件通知。
Example
// 使用方式:
trtc.on(TRTC.EVENT.ERROR, () => {});
Members
(static) ERROR
- Default Value:
-
- 'error'
- See:
错误事件,非 API 调用错误,SDK 在运行过程中出现了不可恢复的错误时抛出。
- 错误码(error.code)为:ErrorCode.OPERATION_FAILED
- 可能的扩展错误码(error.extraCode):5501, 5502
Example
trtc.on(TRTC.EVENT.ERROR, error => {
console.error('trtc error observed: ' + error);
const errorCode = error.code;
const extraCode = error.extraCode;
});
(static) AUTOPLAY_FAILED
- Default Value:
-
- 'autoplay-failed'
自动播放失败,参考 自动播放处理建议
Example
trtc.on(TRTC.EVENT.AUTOPLAY_FAILED, event => {
// 引导用户点击页面,当用户点击页面时,SDK 会自动恢复播放。
// 自 v5.1.3+ 新增 userId 参数,表示哪个用户出现自动播放失败。
console.log(event.userId);
});
(static) KICKED_OUT
- Default Value:
-
- 'kicked-out'
被踢出房间,原因如下:
Example
trtc.on(TRTC.EVENT.KICKED_OUT, event => {
console.log(event.reason)
});
(static) REMOTE_USER_ENTER
- Default Value:
-
- 'remote-user-enter'
远端用户进房事件。
rtc
模式下,所有用户都会收到进退房通知。live
模式下,只有主播才有进退房通知,观众没有进退房通知,观众可以收到主播的进退房通知。
Example
trtc.on(TRTC.EVENT.REMOTE_USER_ENTER, event => {
const userId = event.userId;
});
(static) REMOTE_USER_EXIT
- Default Value:
-
- 'remote-user-exit'
远端用户退房事件。
rtc
模式下,所有用户都会收到进退房通知。live
模式下,只有主播才有进退房通知,观众没有进退房通知,观众可以收到主播的进退房通知。
Example
trtc.on(TRTC.EVENT.REMOTE_USER_EXIT, event => {
const userId = event.userId;
});
(static) REMOTE_AUDIO_AVAILABLE
- Default Value:
-
- 'remote-audio-available'
远端用户发布了音频。当远端用户打开麦克风后,您会收到该通知。参考:开关摄像头、麦克风
- 默认情况下,SDK 会自动播放远端音频,您无需调用 API 来播放远端音频。可以监听该事件及 REMOTE_AUDIO_UNAVAILABLE 来更新“远端是否开启麦克风”的 UI icon。
- 需要注意的是:如果用户在进房前没有与页面产生过交互,自动播放音频可能会因为【浏览器的自动播放策略限制】而失败,您需参考自动播放受限处理建议进行处理。
- 若您不希望 SDK 自动播放音频,您可以在 trtc.enterRoom() 时设置
autoReceiveAudio
为false
关闭自动播放音频。 - 监听 TRTC.EVENT.REMOTE_AUDIO_AVAILABLE 事件,记录有远端音频的 userId,在需要播放音频时,调用 trtc.muteRemoteAudio(userId, false) 方法。
Example
// 在进房前监听
trtc.on(TRTC.EVENT.REMOTE_AUDIO_AVAILABLE, event => {
const userId = event.userId;
});
(static) REMOTE_AUDIO_UNAVAILABLE
- Default Value:
-
- 'remote-audio-unavailable'
远端停止发布了音频。当远端用户关闭麦克风后,您会收到该通知。
Example
// 在进房前监听
trtc.on(TRTC.EVENT.REMOTE_AUDIO_UNAVAILABLE, event => {
const userId = event.userId;
});
(static) REMOTE_VIDEO_AVAILABLE
- Default Value:
-
- 'remote-video-available'
- See:
远端用户发布了视频,当远端用户开启摄像头后,您会收到该通知。参考:开关摄像头、麦克风
- 可以监听该事件及 REMOTE_VIDEO_UNAVAILABLE 来更新“远端是否开启摄像头”的 UI icon。
Example
// 在进房前监听
trtc.on(TRTC.EVENT.REMOTE_VIDEO_AVAILABLE, event => {
const userId = event.userId;
const streamType = event.streamType;
trtc.startRemoteVideo({userId, streamType, view});
});
(static) REMOTE_VIDEO_UNAVAILABLE
- Default Value:
-
- 'remote-video-unavailable'
远端用户停止发布视频,当远端用户关闭摄像头后,您会收到该通知。
Example
// 在进房前监听
trtc.on(TRTC.EVENT.REMOTE_VIDEO_UNAVAILABLE, event => {
const userId = event.userId;
const streamType = event.streamType;
// 此时 SDK 会自动停止播放,无需调用 stopRemoteVideo。
});
(static) AUDIO_VOLUME
- Default Value:
-
- 'audio-volume'
音量大小事件
调用 enableAudioVolumeEvaluation 接口开启音量大小回调后,SDK 会定时抛出该事件,通知每个 userId 的音量大小。
Note
- 回调中包含本地麦克风音量及远端用户的音量,无论是否有人说话,都会触发该回调。
- 回调 event.result 会根据音量大小,按大到小进行排序。
- 当 userId 为空串时,代表本地麦克风音量。
- volume 取值为0-100的正整数
Example
trtc.on(TRTC.EVENT.AUDIO_VOLUME, event => {
event.result.forEach(({ userId, volume }) => {
const isMe = userId === ''; // 当 userId 为空串时,代表本地麦克风音量。
if (isMe) {
console.log(`my volume: ${volume}`);
} else {
console.log(`user: ${userId} volume: ${volume}`);
}
})
});
// 开启音量回调,并设置每 1000ms 触发一次事件
trtc.enableAudioVolumeEvaluation(1000);
(static) NETWORK_QUALITY
- Default Value:
-
- 'network-quality'
网络质量统计数据事件,进房后开始统计,每两秒触发一次,该数据反映的是您本地的上、下行的网络质量。
-
上行网络质量(uplinkNetworkQuality)指的是您上传本地流的网络情况(SDK 到腾讯云的上行连接网络质量)
-
下行网络质量(downlinkNetworkQuality)指的是您下载所有流的平均网络情况(腾讯云到 SDK 的所有下行连接的平均网络质量)
其枚举值及含义如下表所示:
数值 含义 0 网络状况未知,表示当前 trtc 实例还没有建立上行/下行连接 1 网络状况极佳 2 网络状况较好 3 网络状况一般 4 网络状况差 5 网络状况极差 6 网络连接已断开
注意:若下行网络质量为此值,则表示所有下行连接都断开了 -
uplinkRTT,uplinkLoss 为上行 RTT(ms) 及上行丢包率。
-
downlinkRTT,downlinkLoss 为所有下行连接的平均 RTT(ms) 及平均丢包率。
Note
- 如果您想知道对方的上下行网络情况,需要把对方的网络质量情况通过 IM 广播出去。
Example
trtc.on(TRTC.EVENT.NETWORK_QUALITY, event => {
console.log(`network-quality, uplinkNetworkQuality:${event.uplinkNetworkQuality}, downlinkNetworkQuality: ${event.downlinkNetworkQuality}`)
console.log(`uplink rtt:${event.uplinkRTT} loss:${event.uplinkLoss}`)
console.log(`downlink rtt:${event.downlinkRTT} loss:${event.downlinkLoss}`)
})
(static) CONNECTION_STATE_CHANGED
- Default Value:
-
- 'connection-state-changed'
SDK 和腾讯云的连接状态变更事件,您可以利用该事件从总体上监听 SDK 与腾讯云的连接状态。
- 'DISCONNECTED':连接断开
- 'CONNECTING':正在连接中
- 'CONNECTED':已连接
不同状态变更的含义:
- DISCONNECTED -> CONNECTING: 正在尝试建立连接,调用进房接口或者 SDK 自动重连时触发。
- CONNECTING -> DISCONNECTED: 连接建立失败,当正在连接时调用退房接口中断连接或者经过 SDK 重试后任然连接失败时触发。
- CONNECTING -> CONNECTED: 连接建立成功,连接成功时触发。
- CONNECTED -> DISCONNECTED: 连接中断,调用退房接口或者当网络异常导致连接断开时触发。
处理建议:可以监听该事件,在不同状态显示不同的 UI,提醒用户当前的连接状态。
Example
trtc.on(TRTC.EVENT.CONNECTION_STATE_CHANGED, event => {
const prevState = event.prevState;
const curState = event.state;
});
(static) AUDIO_PLAY_STATE_CHANGED
- Default Value:
-
- 'audio-play-state-changed'
音频播放状态变更事件
event.userId 当 userId 为空串时,代表本地用户,非空串代表远端用户。
event.state 取值如下:
- 'PLAYING':开始播放
- event.reason 为 'playing' 或者 'unmute'。
- 'PAUSED':暂停播放
- event.reason 为 'pause' 时,由 <audio> element 的 pause 事件触发,如下几种情况会触发:
- 调用 HTMLMediaElement.pause 接口。
- event.reason 为 'mute' 时。详见事件 MediaStreamTrack.mute_event
- 若 userId 为自己时 触发该事件,表明音频采集暂停,通常是设备异常引起,如设备被其他应用抢占,此时需引导用户重新采集。
- 若 userId 为他人时 触发该事件,表明收到的音频数据不足以播放。通常是网络抖动引起,接入侧无需做任何处理。当收到的数据足以播放时,会自动恢复。
- event.reason 为 'pause' 时,由 <audio> element 的 pause 事件触发,如下几种情况会触发:
- 'STOPPED':停止播放
- event.reason 为 'ended'。
event.reason 状态变化的原因,取值如下:
- 'playing':开始播放,详见事件 HTMLMediaElement.playing_event
- 'mute':音频轨道暂时未能提供数据,详见事件 MediaStreamTrack.mute_event
- 'unmute':音频轨道恢复提供数据,详见事件 MediaStreamTrack.unmute_event
- 'ended':音频轨道已被关闭
- 'pause':播放暂停
Example
trtc.on(TRTC.EVENT.AUDIO_PLAY_STATE_CHANGED, event => {
console.log(`${event.userId} player is ${event.state} because of ${event.reason}`);
});
(static) VIDEO_PLAY_STATE_CHANGED
- Default Value:
-
- 'video-play-state-changed'
视频播放状态变更事件
event.userId 当 userId 为空串时,代表本地用户,非空串代表远端用户。
event.streamType 流类型,取值:TRTC.TYPE.STREAM_TYPE_MAIN TRTC.TYPE.STREAM_TYPE_SUB
event.state 取值如下:
- 'PLAYING':开始播放
- event.reason 为 'playing' 或者 'unmute'。
- 'PAUSED':暂停播放
- event.reason 为 'pause' 时,由 <video> element 的 pause 事件触发,如下几种情况会触发:
- 调用 HTMLMediaElement.pause 接口。
- 在播放成功后,从 DOM 中移除了播放视频的 view 容器。
- event.reason 为 'mute' 时。详见事件 MediaStreamTrack.mute_event
- 若 userId 为自己时 触发该事件,表明视频采集暂停,通常是设备异常引起,如设备被其他应用抢占,此时需引导用户重新采集。
- 若 userId 为他人时 触发该事件,表明收到的视频数据不足以播放。通常是网络抖动引起,接入侧无需做任何处理。当收到的数据足以播放时,会自动恢复。
- event.reason 为 'pause' 时,由 <video> element 的 pause 事件触发,如下几种情况会触发:
- 'STOPPED':停止播放
- event.reason 为 'ended'。
event.reason 状态变化的原因,取值如下:
- 'playing':开始播放,详见事件 HTMLMediaElement.playing_event
- 'mute':视频轨道暂时未能提供数据,详见事件 MediaStreamTrack.mute_event
- 'unmute':视频轨道恢复提供数据,详见事件 MediaStreamTrack.unmute_event
- 'ended':视频轨道已被关闭
- 'pause':播放暂停
Example
trtc.on(TRTC.EVENT.VIDEO_PLAY_STATE_CHANGED, event => {
console.log(`${event.userId} ${event.streamType} video player is ${event.state} because of ${event.reason}`);
});
(static) SCREEN_SHARE_STOPPED
- Default Value:
-
- 'screen-share-stopped'
本地屏幕分享停止事件通知,仅对本地屏幕分享流有效。
Example
trtc.on(TRTC.EVENT.SCREEN_SHARE_STOPPED, () => {
console.log('screen sharing was stopped');
});
(static) DEVICE_CHANGED
- Default Value:
-
- 'device-changed'
摄像头、麦克风等设备变化的通知事件。
- event.device 是一个 MediaDeviceInfo 对象,属性:
- deviceId:设备 Id
- label:设备描述信息
- groupId:设备 groupId
- event.type 值:
'camera'|'microphone'|'speaker'
- event.action 值:
- 'add' 设备已添加。
- 'remove' 设备已被移除。
- 'active' 设备已启动,例如:startLocalVideo 成功后,会触发该事件。
Example
trtc.on(TRTC.EVENT.DEVICE_CHANGED, (event) => {
console.log(`${event.type}(${event.device.label}) ${event.action}`);
});
(static) PUBLISH_STATE_CHANGED
- Default Value:
-
- 'publish-state-changed'
推流状态变更事件。
- event.mediaType 媒体类型,值:
'audio'|'video'|'screen'
。 - event.state 当前的推流状态,值:
'starting'
正在尝试推流'started'
推流成功'stopped'
推流停止,原因见 event.reason 字段
- event.prevState 上一次事件触发时的推流状态,值和 event.state 相同。
- event.reason 推流状态变为
'stopped'
的原因,值:'timeout'
推流超时,一般是由于网络抖动、防火墙拦截导致。SDK 会不断进行重试,业务侧可以在此时引导用户检查网络、更换网络。'error'
推流出错,此时可从 event.error 中获取到具体错误信息,一般是由于浏览器不支持 H264 编码导致。'api-call'
业务侧 api 调用导致推流停止,例如在 startLocalVideo 推流成功前,调用了 stopLocalVideo 停止了推流,属于正常行为,业务侧无需关注。
- event.error event.reason 为
'error'
时的错误信息。
Example
trtc.on(TRTC.EVENT.PUBLISH_STATE_CHANGED, (event) => {
console.log(`${event.mediaType} ${event.state} ${event.reason}`);
});
(static) TRACK
- Since:
-
- v5.3.0
- Default Value:
-
- 'track'
收到新的 MediaStreamTrack 对象
Example
trtc.on(TRTC.EVENT.TRACK, event => {
const isLocal = event.userId === ''; // userId === '' means event.track is a local track, otherwise it's a remote track
const isSubStream = event.streamType === TRTC.TYPE.STREAM_TYPE_SUB; // Usually the sub stream is a screen-sharing video stream.
const mediaStreamTrack = event.track;
const kind = event.track.kind; // audio or video
})
(static) STATISTICS
- Since:
-
- v5.2.0
- Default Value:
-
- 'statistics'
通话相关数据指标。
- 监听该事件后,SDK 会以 2s 一次的频率定时抛出该事件。
- 您可以从该事件中可以获取通话的网络质量(rtt、丢包率)、上行和下行的音视频统计信息(音量大小、宽高、帧率、码率)等信息。详细参数说明请参考:TRTCStatistics
Example
trtc.on(TRTC.EVENT.STATISTICS, statistics => {
console.warn(statistics.rtt, statistics.upLoss, statistics.downLoss);
})
(static) SEI_MESSAGE
- Since:
-
- v5.3.0
- Default Value:
-
- 'sei-message'
收到 SEI message
Example
trtc.on(TRTC.EVENT.SEI_MESSAGE, event => {
console.log(`收到 ${event.userId} 的 sei message: ${event.data}`)
})
(static) CUSTOM_MESSAGE
- Since:
-
- v5.6.0
- Default Value:
-
- 'custom-message'
收到自定义消息
Example
trtc.on(TRTC.EVENT.CUSTOM_MESSAGE, event => {
// event.userId: 远端发消息的 userId
// event.cmdId: 您自定义的消息 Id
// event.seq: 消息的序号
// event.data: 消息内容,ArrayBuffer 类型
})