tencent cloud

直播 SDK

动态与公告
TUILiveKit 产品动态
云直播推拉流 SDK 产品动态
新手指引
产品简介
产品概述
产品优势
性能数据
基本概念
购买指南
TRTC Live 价格总览
Live 视频直播计费说明
开通服务(TUILiveKit)
Demo 体验
Demo 体验指引
跑通 Demo(TUILiveKit)
接入指南
视频直播
准备工作
主播开播
观众观看
直播列表
语聊房
准备工作
主播开播
观众观看
直播列表
推流助手
推流助手(Electron 桌面应用)
推流助手(Web 桌面浏览器)
直播监播
监播页面(Web 桌面浏览器 React 版)
监播页面(Web 桌面浏览器 Vue 版)
UI 自定义
直播视频组件
视频源编辑组件
观众列表组件
聊天弹幕组件
媒体源配置面板
连麦管理面板
直播送礼组件
无 UI 集成
搭建视频直播
搭建语聊房
功能指南
关注主播(TUILiveKit)
至臻画质(TUILiveKit)
输入媒体流进房(TUILiveKit)
礼物系统(TUILiveKit)
客户端 API
Android
iOS
Web
服务端 API(TUILiveKit)
账号系统
REST API
第三方回调
错误码(TUILiveKit)
常见问题
平台编译
用户鉴权
云直播推拉流 SDK
产品简介
购买指南
Demo 体验
免费测试
SDK 下载
License 管理
高级功能
客户端 API
常见问题
无 UI 集成方案
API 文档
OSS information
OSS Attribution Notice
文档直播 SDKUI 自定义视频源编辑组件视频源编辑画板(Web 桌面浏览器)

视频源编辑画板(Web 桌面浏览器)

聚焦模式
字号
最后更新时间: 2026-01-14 21:07:31
本文对视频源编辑画板(StreamMixer)进行了详细的介绍,您可以在已有项目中直接参考本文示例集成我们开发好的组件,也可以根据您的需求按照文档中的组件定制化部分对样式,布局进行深度的定制。


核心功能

功能分类
具体能力
实时预览
提供所见即所得的编辑体验,主播可以直观地看到混流效果,支持对元素进行旋转、移动、缩放、镜像、层级调整等操作
模板布局
内置多种直播间布局模板,支持自动适配不同连麦场景,包括九宫格、1v6、浮窗等,帮助您快速切换不同风格的直播画面。
用户状态管理
智能感知连麦用户的加入和退出,自动调整布局,无需手动干预,确保了直播过程的流畅性,为主播提供无缝体验。
可定制化 UI
为了满足多样化的业务场景,视频源编辑画板提供组件 UI 自定义插槽,让您能够完全掌控连麦用户的视频流区域,重写其 UI 展示,灵活定义连麦用户的头像、昵称、状态等信息,轻松打造符合您 UI 风格的独特视觉体验。

组件接入

步骤1:环境配置及开通服务

在进行快速接入之前,您需要参见 准备工作,满足相关环境配置及开通对应服务。

步骤2: 安装依赖

npm
pnpm
yarn
npm install tuikit-atomicx-vue3 @tencentcloud/uikit-base-component-vue3 --save
pnpm add tuikit-atomicx-vue3 @tencentcloud/uikit-base-component-vue3
yarn add tuikit-atomicx-vue3 @tencentcloud/uikit-base-component-vue3

步骤3:加入直播间

在您的项目中引入并使用视频源编辑画板,可直接复制如下代码示例至您的项目中加入对应直播间。
<template>
<UIKitProvider theme="dark" language="zh-CN">
<div class="app">
<LiveScenePanel class="live-scene-panel" />
<StreamMixer class="live-stream-mixer" />
</div>
</UIKitProvider>
</template>

<script setup lang="ts">
import { onMounted } from 'vue';
import { UIKitProvider } from '@tencentcloud/uikit-base-component-vue3';
import { LiveScenePanel, StreamMixer, useLoginState, useLiveState, useCoGuestState } from 'tuikit-atomicx-vue3';

const { login } = useLoginState();
const { createLive } = useLiveState();
const { sendCoGuestRequest } = useCoGuestState();

async function initLogin() {
try {
await login({
sdkAppId: 0, // SDKAppID, 可以参考步骤 1 获取
userId: '', // UserID, 可以参考步骤 1 获取
userSig: '', // userSig, 可以参考步骤 1 获取
});
} catch (error) {
console.error('登录失败:', error);
}
}

onMounted(async () => {
await initLogin();
await createLive({ // 主播创建直播间之后, StreamMixer 自动将本地合图画面推流到直播间
liveId: `live_${loginUserInfo.value.userId}`,
liveName: `${loginUserInfo.value?.userName} 的直播间`,
});
await sendCoGuestRequest(); // 观众端通过调用相应方法即可加入直播间并根据需要上下麦,观众成功上麦之后,StreamMixer 自动播放实时音视频流
});
</script>

<style>.app {width: 100vw; height: 100vh; display: flex; justify-content: center; align-items: center}</style>
npm run dev


组件定制化

视频源编辑画板提供了灵活的组件自定义插槽,该插槽支持您根据自己需求调整头像、昵称、状态等元素的样式与布局,也支持定制视频流区域连麦 UI。下列分别给出插槽使用示例

组件插槽

名称
参数
说明
seatViewUI
seatInfo: SeatInfo
自定义麦位的显示 UI
// seatViewUI 插槽使用示例
<StreamMixer>
<CustomSeatViewUI #seatViewUI></CustomSeatViewUI>
</StreamMixer>
1. SeatInfo 定义了直播房间中每个麦位的基本信息和状态:
参数
类型
属性
说明
index
number
必填
麦位的索引号,从0开始递增,用于标识麦位在房间中的位置。
isLocked
boolean
必填
麦位锁定状态,true 表示麦位被锁定,其他用户无法进入;false 表示麦位开放。
userInfo
SeatUserInfo
非必填
当前坐在该麦位上的用户信息,如果麦位为空则为 undefined
region
RegionInfo
非必填
麦位在视频画布中的显示区域信息,用于多路视频布局。
interface SeatInfo {
index: number; // 麦位索引
isLocked: boolean; // 麦位是否被锁定
userInfo?: SeatUserInfo; // 麦位上的用户信息(可选)
region?: RegionInfo; // 麦位在画布中的区域信息(可选)
}
2. SeatUserInfo 定义了直播房间中每个麦位上的用户详细信息:
参数
类型
属性
说明
roomId
string
必填
当前直播房间的唯一标识符,用于区分不同的直播房间。
userId
string
必填
用户的唯一标识符,在整个系统中保持唯一性。
userName
string
必填
用户在直播中显示的名称,支持中文、英文等字符。
avatarUrl
string
必填
用户头像的完整URL地址,支持 HTTPS 协议。
microphoneStatus
DeviceStatus
必填
麦克风的当前状态。
microphoneStatusReason
DeviceStatusReason
必填
麦克风状态变更的原因,用于区分是用户主动操作还是管理员操作。
cameraStatus
DeviceStatus
必填
摄像头的当前状态。
cameraStatusReason
DeviceStatusReason
必填
摄像头状态变更的原因,用于区分是用户主动操作还是管理员操作。
interface SeatUserInfo {
roomId: string; // 直播房间ID
userId: string; // 用户唯一标识
userName: string; // 用户显示名称
avatarUrl: string; // 用户头像URL
microphoneStatus: DeviceStatus; // 麦克风状态
allowOpenMicrophone: boolean; // 是否允许打开麦克风
cameraStatus: DeviceStatus; // 摄像头状态
allowOpenCamera: boolean; // 是否允许打开摄像头
}

export type SeatUserInfo = {
liveId: string; // 直播房间ID
userId: string; // 用户唯一标识
userName: string; // 用户显示名称
avatarUrl: string; // 用户头像URL
microphoneStatus: DeviceStatus; // 麦克风状态
microphoneStatusReason: DeviceStatusReason; // 麦克风状态变更原因
cameraStatus: DeviceStatus; // 摄像头状态
cameraStatusReason: DeviceStatusReason; // 摄像头状态变更原因
}
3. RegionInfo 定义了麦位在视频画布中的显示区域和层级信息:
参数
类型
属性
说明
x
number
必填
区域左上角相对于画布左上角的X坐标(像素值)。
y
number
必填
区域左上角相对于画布左上角的Y坐标(像素值)。
w
number
必填
区域的宽度(像素值),必须大于0。
h
number
必填
区域的高度(像素值),必须大于0。
zOrder
number
必填
层级顺序,数值越大越靠前显示,用于处理重叠区域的显示优先级。
interface RegionInfo {
x: number; // 区域左上角X坐标
y: number; // 区域左上角Y坐标
w: number; // 区域宽度
h: number; // 区域高度
zOrder: number; // 层级顺序
}

自定义插槽示例

为了更好地让您体验及理解视频源编辑画板 组件的 seatViewUI 插槽定制化能力,我们提供了直播连麦场景示例场景供您参考,您可以参考上述步骤3将以下代码增量复制至您的项目中实现类似场景的效果。
<template>
<StreamMixer>
<template #seatViewUI="{ userInfo }">
<div
class="live-stream-view"
:class="{ 'is-anchor': isAnchor(userInfo), 'is-guest': !isAnchor(userInfo) }"
>
<!-- 用户信息覆盖层 -->
<div class="user-overlay">
<div class="user-badge" :class="{ 'anchor-badge': isAnchor(userInfo) }">
{{ isAnchor(userInfo) ? '主播' : '观众' }}
</div>
<div class="user-name">{{ userInfo.userName }}</div>
<div class="device-status">
<span :class="['mic', userInfo.microphoneStatus]"></span>
<span :class="['camera', userInfo.cameraStatus]"></span>
</div>
</div>
</div>
</template>
</StreamMixer>
</template>

<script setup lang="ts">
import { StreamMixer } from 'tuikit-atomicx-vue3';
import type { SeatUserInfo } from 'tuikit-atomicx-vue3';

// 判断是否为主播(根据业务逻辑)
const isAnchor = (userInfo: SeatUserInfo) => {
// 这里可以根据用户ID、角色等判断
return userInfo.userId.includes('anchor') || userInfo.userName.includes('主播');
};
</script>

<style scoped>.live-stream-view{position:relative;width:100%;height:100%;border-radius:8px;overflow:hidden}.live-stream-view.is-anchor{border:3px solid #ff6b35;box-shadow:0 0 20px rgba(255,107,53,.3)}.live-stream-view.is-guest{border:1px solid #ddd}.video-area{width:100%;height:100%;background:#000}.user-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(0,0,0,.8));padding:10px;color:#fff}.user-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:12px;margin-bottom:5px;background:#666}.anchor-badge{background:#ff6b35;color:#fff}.user-name{font-weight:700;margin-bottom:5px}.device-status span{margin-right:5px;opacity:.8}.device-status .camera.Off,.device-status .mic.Off{opacity:.3}</style>

帮助和支持

本页内容是否解决了您的问题?

填写满意度调查问卷,共创更好文档体验。

文档反馈