智密腾讯云直播组建--直播间事件监听--ZhimiTRTCRoomEvent

事件名 描述
onSelfInfoUpdated 用户信息更新事件
onNetworkQuality 网络状态变更
onRoomDestroy 房间销毁
onRoomTextMessage 收到聊天消息
onRoomOnlinesUpdate 房间人数变更
onBeKickout 用户被踢出直播间
onGiftRev 收到礼物消息
onExitJoinAnchor 连麦结束
onRequestJoinAnchorRev 观众请求连麦
onResponseJoinAnchorRev 主播响应连麦
onKickoutJoinAnchorRev 观众连麦被断开
onEnterJoinAnchor 进入连麦状态

onSelfInfoUpdated - 用户信息更新事件

该事件用于反馈用户信息更新,开发者通过 setProfile 的 api 或者通过腾讯云官方接口调用更新用户的信息时候会触发。

调用例子
javascript 复制代码
import { ZhimiTRTCRoomEvent } from '@/utils/ZhimiTRTCLiveRoom'

ZhimiTRTCRoomEvent.onSelfInfoUpdated(userInfo => {
  console.log('用户信息变更', userInfo)
})

onNetworkQuality - 网络状态变更

该事件用于反馈 trtc 网络状态,主要体现主播,连麦的网络质量。该事件会按秒级别触发!请开发者谨慎使用。

调用例子
javascript 复制代码
import { ZhimiTRTCRoomEvent } from '@/utils/ZhimiTRTCLiveRoom'

ZhimiTRTCRoomEvent.onNetworkQuality(userInfo => {
  console.log('网络状态', userInfo)
})

onRoomDestroy - 房间销毁

该事件用于监听房间销毁,常见与主播退出直播间或者销毁直播间。接收到该事件之后开发者应该让用户退出该直播间,并且停止推流拉流操作。

调用例子
javascript 复制代码
import { ZhimiTRTCRoomEvent } from '@/utils/ZhimiTRTCLiveRoom'

ZhimiTRTCRoomEvent.onRoomDestroy(() => {
  console.log('直播结束,直播间已经销毁')
})

onRoomTextMessage - 收到聊天消息

该事件用于监听收到直播间聊天消息。

调用例子
javascript 复制代码
import { ZhimiTRTCRoomEvent } from '@/utils/ZhimiTRTCLiveRoom'

ZhimiTRTCRoomEvent.onRoomTextMessage((data) => {
  console.log('收到聊天消息', data.nick, '发了', data.text)
})

onRoomOnlinesUpdate - 房间人数变更

该事件用于监听房间在线人数变更,请注意,该事件有且只有在腾讯云 IM 旗舰版有准确的统计结果。具体原因参考以下连接。

即时通信 IM 获取直播群在线成员列表-服务端 API-文档中心-腾讯云

调用例子
javascript 复制代码
import { ZhimiTRTCRoomEvent } from '@/utils/ZhimiTRTCLiveRoom'

ZhimiTRTCRoomEvent.onRoomOnlinesUpdate(({ count, list }) => {
  console.log('当前在线人数', count)
  console.log('当前在线列表', list)
})

onBeKickout - 用户被踢出直播间

该事件用于监听当前用户被踢出直播间。

调用例子
javascript 复制代码
import { ZhimiTRTCRoomEvent } from '@/utils/ZhimiTRTCLiveRoom'

ZhimiTRTCRoomEvent.onBeKickout(() => {
  console.log('您已经被踢出直播间')
})

onGiftRev - 收到礼物消息

该事件用于监听房间内的礼物消息,该消息一般是其他用户发出的,自己发出的请根据sendGift反馈进行处理。

注意:这里的礼物数据不一定和实际业务一致,这里只根据demo默认的进行编写调用例子,实际开发中请开发者自行处理。

调用例子
javascript 复制代码
import { ZhimiTRTCRoomEvent } from '@/utils/ZhimiTRTCLiveRoom'

ZhimiTRTCRoomEvent.onGiftRev(({ url, nick, label }) => {
  console.log('礼物svga连接', url)
  console.log('发送人员昵称', nick)
  console.log('发送礼物名称', label)
})

onExitJoinAnchor - 连麦结束

该事件用于监听观众断开/主播踢掉连麦从而导致的连麦结束。

调用例子
javascript 复制代码
import { ZhimiTRTCRoomEvent } from '@/utils/ZhimiTRTCLiveRoom'

ZhimiTRTCRoomEvent.onExitJoinAnchor(() => {
  console.log('连麦已经结束')
})

onRequestJoinAnchorRev - 观众请求连麦

该事件用于监听观众发起连麦请求,开发者需要在此处做处理确定是否同意连麦。

调用例子
javascript 复制代码
import { ZhimiTRTCRoomEvent } from '@/utils/ZhimiTRTCLiveRoom'

ZhimiTRTCRoomEvent.onRequestJoinAnchorRev(({ userName, type, userId }) => {
  console.log('观众Id', userId)
  console.log(userName, '请求连麦,连麦类型 -> ', type)
})

onResponseJoinAnchorRev - 主播响应连麦

该事件用于监听观众发起连麦请求之后,主播对于连麦请求的响应。

调用例子
javascript 复制代码
import { ZhimiTRTCRoomEvent } from '@/utils/ZhimiTRTCLiveRoom'

ZhimiTRTCRoomEvent.onResponseJoinAnchorRev(({ agree, type }) => {
  console.log('主播响应连麦结果 = ', agree)
  console.log('连麦类型 = ', type)
})

onKickoutJoinAnchorRev - 观众连麦被断开

该事件用于监听主播主动断开观众连麦。

调用例子
javascript 复制代码
import { ZhimiTRTCRoomEvent } from '@/utils/ZhimiTRTCLiveRoom'

ZhimiTRTCRoomEvent.onKickoutJoinAnchorRev(() => {
  console.log('主播已经断开与您的连麦')
})

onEnterJoinAnchor - 进入连麦状态

该事件用于监听主播观众进入连麦的状态,这里可以调用对应的api将视频流切成trtc流,从而得到优质的连麦体验。

调用例子
javascript 复制代码
import { ZhimiTRTCRoomEvent } from '@/utils/ZhimiTRTCLiveRoom'

ZhimiTRTCRoomEvent.onEnterJoinAnchor(() => {
  console.log('开始进入连麦')
})
相关推荐
GSDjisidi5 分钟前
日本IT|车载C#开发工程师的前途及职业发展
开发语言·c#
卓豪终端管理7 分钟前
如何安全地管理固定功能设备?
java·大数据·开发语言·网络·人工智能·安全
进阶的小木桩29 分钟前
VSTO幻灯片退出播放(C#模拟键盘鼠标的事件)
开发语言·c#·计算机外设
代码程序猿RIP41 分钟前
C++(22)—内存管理
开发语言·数据结构·c++·算法
灏瀚星空1 小时前
AI 模型高效化:推理加速与训练优化的技术原理与理论解析
开发语言·人工智能·深度学习·程序人生·机器人·智慧城市·量子计算
孞㐑¥1 小时前
C++之哈希
开发语言·c++·经验分享·笔记
勇敢牛牛_1 小时前
【Rust基础】crossbeam带来的阻塞问题
开发语言·笔记·rust
东雁西飞1 小时前
MATLAB 控制系统设计与仿真 - 34
开发语言·单片机·算法·matlab·工业机器人
奇树谦1 小时前
C/C++语言常见问题-智能指针、多态原理
c语言·开发语言·c++
桃子叔叔2 小时前
python学习从0到专家(8)容器之列表、元组、字典、集合、字符串小结
开发语言·python·学习