概述
本文对 TUILiveKit Demo 中的监播页面进行了详细的介绍,您可以在已有项目中直接参考本文档集成我们开发好的观看页面,也可以根据您的需求按照文档中的内容对页面的样式,布局以及功能项进行深度的定制。
功能概览
功能分类 | 具体能力 |
多路直播间同屏监播 | 支持同时展示8+路直播画面(具体数量可定制)。 |
低延迟播放 | 实时拉取直播流,画面延迟 ≤3秒。 |
独立音频控制 | 可单独开启/关闭任意一路直播间的声音,避免干扰。 |
一键查看详情 | 单击任意直播间窗口,快速进入详情页,查看主播信息等关键信息。 |
一键解散违规直播间 | 在详情页或监播面板直接操作,快速关停违规直播间,提升处置效率。 |
功能展示
监播页面提供默认行为和风格,但如果默认行为和样式不能完全满足您的需求,您也可以对 UI 进行自定义。其中主要包含直播多路直播间同屏监播、低延迟播放、独立音频控制、一键查看详情、一键解散违规直播间等。

快速跑通
步骤1:环境配置及开通服务
步骤2:下载 Demo
git clone https://github.com/Tencent-RTC/TUIKit_React.git
步骤3:安装依赖
cd TUIKit_React/demos/live-monitor-react && npm install && cd server && npm install
步骤4:启动服务端工程
// cd TUIKit_React/demos/live-monitor-react/server/config/index.jsconst Config = {SdkAppId: 0, // 输入您 TUILiveKit 服务的SDKAppID
SecretKey: '', // 输入您 TUILiveKit 服务的SDKSecretKey
Identifier: 'administrator',Protocol: 'https://',Domain: 'console.tim.qq.com',Port: 9000,};module.exports = { Config };
// 执行如下命令启动服务,默认访问地址为:http://localhost:9000/api
npm run start
步骤5:启动前端工程
// cd TUIKit_React/demos/live-monitor-react/src/config/index.tsimport { getBasicInfo } from './basic-info-config';const sdkAppId = 0; // 输入您 TUILiveKit 服务的SDKAppID
const secretKey = ''; // 输入您 TUILiveKit 服务的SDKSecretKey
const defaultCoverUrl = ''; // 配置您直播封面的默认图片地址const createBasicAccount = (userId?: string) => {return getBasicInfo(userId || `live_${Math.ceil(Math.random() * 10000000)}`, sdkAppId, secretKey);};export { sdkAppId, secretKey, createBasicAccount, defaultCoverUrl };
// cd TUIKit_React/demos/live-monitor-react/src/views/LiveMointor/index.tsximport React, { useLayoutEffect } from 'react';import { useNavigate } from 'react-router-dom';import { useLiveMonitorState } from 'tuikit-atomicx-react';import { safelyParse } from '../../utils';import { Header } from '../../components/Header';import { LiveList } from '../../components/LiveList';import { Pagination } from '../../components/Pagination';import { PaginationProvider } from '../../context/PaginationContext';import styles from './LiveMonitor.module.scss';const LiveMonitor: React.FC = () => {const { init, monitorLiveInfoList } = useLiveMonitorState();const navigate = useNavigate();useLayoutEffect(() => {const account = safelyParse(localStorage.getItem('tuiLiveMonitor-userInfo') || '');if (account) {init({baseUrl: 'http://localhost:9000/api', // 步骤4 中服务端默认访问地址account: {sdkAppId: 0, // 您 TUILiveKit 服务的SDKAppID
userId: '', //该用户在 步骤1 中的 userId
password: '', //该用户在 步骤1 中的 userSig
},});} else {navigate('/login');}}, [init, navigate]);return (<UIKitProvider theme="dark"><div className={styles['live-monitor']}><Header /><PaginationProvider><LiveList monitorLiveInfoList={monitorLiveInfoList} /><div className={styles['live-pagination']}><Pagination pageSize={10} /></div></PaginationProvider></div></UIKitProvider>);};export default LiveMonitor;
npm run start
自由定制
通过上述方式您已经成功运行起监播页面的 Demo,此时若您需要对 UI 进行定制,您可以参考如下方式进行实现。其中定制内容包括但不限于对源码中的颜色主题、字体、圆角、按钮、图标、输入框、弹框等内容,都可以进行增加、删除、修改等操作,下列分别给出颜色主题、按钮以及图标的定制示例,您可以参考实现方式通用到其他组件,满足您的 UI 定制需要。

颜色主题
<UIKitProvider theme="dark"> // theme 传入 dark 时,界面整体颜色主题为黑色主题xxx // theme 传入 light 时,界面整体颜色主题为白色主题</UIKitProvider>
按钮 Button
若您需要对按钮 Button 进行新增或替换等 UI 定制,您可以通过如下方式进行实现,以直播列表页面操作的三个按钮为例。参考下图,您可以找到对应 Button 指定位置源码,对当前部分的按钮进行增加、删除、替换等 UI 定制操作。
// 示例:您可以至 TUIKit_React/demos/live-monitor-react/src/components/Pagination/Pagination.tsx<Buttonicon={<IconChevronLeft />}className={`${styles.button} ${currentPage <= 1 ? styles.disabled : ''}`}onClick={() => goToPage(currentPage - 1)}>{t('Last Page')}</Button><Buttonicon={<IconHome />}className={`${styles.button} ${currentPage === 1 ? styles.disabled : ''}`}onClick={() => goToPage(1)}>{t('First Page')}</Button><Buttonicon={<IconChevronRight />}iconPosition='end'className={`${styles.button} ${!hasMoreData ? styles.disabled : ''}`}onClick={() => goToPage(currentPage + 1)}>{t('Next Page')}</Button>

图标 Icon
若您需要对图标 Icon 进行新增或替换等 UI 定制,您可以通过如下方式进行实现,以直播列表中的 Icon 为例。通过下述指引,您可以找到对应 Icon 位置,进行增加、删除、替换等 UI 定制操作。
// 示例:您可以至 TUIKit_React/demos/live-monitor-react/src/components/LiveList/LiveList.tsx<IconNotification /><IconChevronDown /><IconStopCircle />

生产环境部署
步骤1:部署服务端工程
说明:
1. 本地构建服务端代码。
# 进入 server 工程cdserver
# 构建产物
npm
run build
注意:
构建产物默认存放在 dist 目录。
2. 登录 Serverless 控制台,单击左侧导航栏到函数服务。
3. 在主界面上方单击新建,进入函数创建流程。
4. 选择从头开始来新建函数,并填写函数基础配置。如下图所示:

函数类型:选择 “Web 函数”。
函数名称:填写您自己的函数名称。
地域:填写您的函数部署地域。
运行环境:选择 “Node.js 18.15”。
5. 在函数服务中进入您刚刚创建的 Web 函数。
6. 在函数管理页面的函数代码的提交方法中选择本地上传文件夹,将步骤1构建的 dist 目录内的 src 文件夹上传后单击部署。

7. 等待函数代码加载完毕,检查 src/config/index.js 文件内的
SdkAppId
和 SecretKey
是否填写。
8. 按如下指引新建终端。

9. 进入
src
目录安装依赖。cd srcnpm install
10. 依赖安装完毕后单击部署。

11. 部署完成后单击左侧函数 URL,复制内网访问链接(http 或者 https 协议的链接均可)。

12. 进入接口测试工具(以 ApiFox 为例),在刚刚复制链接的最后加上
/api/test
,单击发送后查看响应结果。
步骤2:部署前端工程
1. 通过步骤1部署云函数成功后,假设您的函数 URL 访问链接为
https://live-monitor-test.tencentscf.com
。您只需调整 TUIKit_React/demos/live-monitor-react/src/views/live-monitor/index.tsx 组件中 init 方法内的 baseUrl 为上述 URL 访问链接即可。2. 构建前端代码。
# 进入live-monitor-react
目录cdTUIKit_React/demos/live-monitor-react
# 构建项目
npm
run build
其他文档
云函数新手指引