本文介绍如何创建一个 Web RTC 项目,实现音视频通话功能。
参考示例项目。
满足以下条件的计算机
查看 Web SDK 的浏览器兼容性。
下载 RTC Web SDK 包。
将 SDK 解压到项目文件目录下。
. ├── index.html ├── package.json ├── index.js ├── lib └── index.min.js
import VERTC from '@volcengine/rtc';
引入。<script src="${文件路径}/index.min.js"></script>
引入。例如,<script src="./lib/index.min.js" type="text/javascript"></script>
。一次简单的音视频通话的流程图如下:
实现一次简单的音视频通话主要包含以下步骤:
调用 createEngine 创建一个本地 Engine 引擎对象。
import VERTC,{IRTCEngine} from '@volcengine/rtc'; // 创建 RTC 引擎 const engine:IRTCEngine = VERTC.createEngine(appId);
调用 engine.joinRoom 加入房间,配置音视频流是否自动发布、订阅
进房后,你可以调用 subscribeStream 修改订阅设置。
import { RoomProfileType } from '@volcengine/rtc'; const config = { appId: '填写项目的 appID', roomId: '填写 roomId', uid:'填写 uid', token: '填写 token', }; const join = async () => { try { await engine .joinRoom( config.token, config.roomId, { userId: config.uid, }, { isAutoPublish: true, // 采集音视频时自动发布到房间 isAutoSubscribeAudio: true, // 自动订阅音频 isAutoSubscribeVideo: true, // 自动订阅视频 roomProfileType:RoomProfileType.communication // 普通音视频通话模式,例如,语音聊天室 } ) } catch(e) { console.error('进房错误:', (e as { code: typeof VERTC.ErrorCode; message: string; }).message); } };
调用 startAudioCapture 、startVideoCapture 采集本地音视频后设置本地播放器,并发布。
import { StreamIndex,MediaType } from '@volcengine/rtc'; async createLocalStream(){ // 开启本地采集 await engine.startAudioCapture(); await engine.startVideoCapture(); // 设置本地播放器 engine.setLocalVideoPlayer(StreamIndex.STREAM_INDEX_MAIN, { // renderDom 为容器元素的 id。可以为一个空的 div 标签,如 <div id="local-player"></div> renderDom: 'local-player' }); // 如果调用 joinRoom 时在 config 中设置了自动发布,这里就不需要发布了 await engine.publishStream(MediaType.AUDIO_AND_VIDEO) } createLocalStream()
监听 onUserPublishStream 事件。以下两种情况你都会收到该事件:
上述事件触发后,远端音视频流对象信息将传入handleUserPublishStream
。
调用 setRemoteVideoPlayer 设置远端音视频流播放器。
import { MediaType, StreamIndex } from '@volcengine/rtc'; engine.on(VERTC.events.onUserPublishStream, handleUserPublishStream); // 收到 VERTC.events.onUserPublishStream 事件后进行相应处理 async function handleUserPublishStream(e: { userId: string; mediaType: MediaType; }){ const player = document.querySelector('#video-container'); await engine.setRemoteVideoPlayer(VERTC.StreamIndex.STREAM_INDEX_MAIN, { userId: remoteUser.userId, renderDom: player, }); }
成功离开房间后,将不会收到房间内任何消息通知,音视频流的发布和接收也将停止。
await engine.leaveRoom();
至此,我们实现了基础的音视频通话。
Web RTC API 概述
Web RTC API 详情
Web RTC API 事件
Web RTC API 错误码
Web RTC API 类型详情