npm create vite@latest TUIRoom-demo -- --template vue
cd TUIRoom-demonpm installnpm run dev
// vue-cliをインストールします。Vue CLI 4.xはNode.jsのv10以上のバージョンが必要なのでご注意くださいnpm install -g @vue/cli::: Vue3 + Webpack + TSテンプレートプロジェクトの作成vue create TUIRoom-demo
cd TUIRoom-demonpm run serve
TUIRoom/Web/src/TUIRoom
フォルダを既存のプロジェクトsrc/ディレクトリにコピーします。App.vue
コンポーネントにインポートします。<template><room ref="TUIRoomRef"></room></template><script setup lang="ts">import { ref, onMounted } from 'vue';// TUIRoomコンポーネントをインポートします。インポートパスが正しいことを確認してくださいimport Room from './TUIRoom/index.vue';// TUIRoomコンポーネントのメソッドを呼び出すために、TUIRoomコンポーネント要素を取得しますconst TUIRoomRef = ref();onMounted(async () => {// TUIRoomコンポーネントの初期化// キャスターはルームを作成する前にTUIRoomコンポーネントを初期化してください// 一般メンバーは、ルームに参加する前にTUIRoomコンポーネントを初期化してくださいawait TUIRoomRef.value.init({// sdkAppIdを取得するにはステップ1をご参照くださいsdkAppId: 0,// ビジネスにおけるユーザーの一意の識別IDuserId: '',// ローカル開発デバッグは、userSigをhttps://console.tencentcloud.com/trtc/usersigtoolページにすばやく生成します。userSigとuserIdは1対1で対応していることに注意してくださいuserSig: '',// ユーザーがビジネスで使用するニックネームuserName: '',// ユーザーがビジネスで使用するアバターへのリンクuserAvatar: '',// 画面共有のためにユーザーが使用する一意のID。shareUserId=`share_${userId}`が必要です。画面共有機能が要求されない場合は渡す必要がありませんshareUserId: '',// このドキュメントのステップ1>3を参照し、sdkAppIdとshareUserIdを使用してshareUserSigを発行してくださいshareUserSig: '',})// デフォルトではルームの作成が実行され、実際のインポートはオンデマンドでhandleCreateRoomメソッドが実行されますawait handleCreateRoom();})// キャスターがルームを作成します。このメソッドはルームが作成されたときにのみ呼び出されますasync function handleCreateRoom() {// roomIdはユーザーが参加するルーム番号です。roomIdタイプはnumber型が必要です// roomModeは、'FreeSpeech'(自由発言モード)と'ApplySpeech'(举手発言モード)の2モードを含み、デフォルトは'FreeSpeech'です。現在、自由発言モードだけをサポートします// roomParamは、ユーザがルームに参加したときのデフォルトの動作を指定します(デフォルトでマイクをオンにするかどうか、デフォルトでカメラをオンにするかどうか、デフォルトのメディアデバイスID)const roomId = 123456;const roomMode = 'FreeSpeech';const roomParam = {isOpenCamera: true,isOpenMicrophone: true,}await TUIRoomRef.value.createRoom(roomId, roomMode, roomParam);}// 一般メンバーがルームに参加します。このメソッドは作成されたルームに一般メンバーが参加するときに呼び出されますasync function handleEnterRoom() {// roomIdはユーザーが参加するルーム番号です。roomIdタイプはnumber型が必要です// roomParamは、ユーザがルームに参加したときのデフォルトの動作を指定します(デフォルトでマイクをオンにするかどうか、デフォルトでカメラをオンにするかどうか、デフォルトのメディアデバイスID)const roomId = 123456;const roomParam = {isOpenCamera: true,isOpenMicrophone: true,}await TUIRoomRef.value.enterRoom(roomId, roomParam);}</script><style>html, body {width: 100%;height: 100%;margin: 0;}#app {width: 100%;height: 100%;}</style>
npm install sass typescript unplugin-auto-import unplugin-vue-components -S -D
npm install element-plus events mitt pinia rtc-beauty-plugin tim-js-sdk trtc-js-sdk tsignaling -S
src/main.ts
ファイルです。// src/main.tsファイルimport { createPinia } from 'pinia';const app = createApp(App);// pinia登録app.use(createPinia());app.mount('#app');
vite.config.ts
でelement-plusコンポーネントをオンデマンドでロードするように設定してください。// vite.config.tsimport AutoImport from 'unplugin-auto-import/vite';import Components from 'unplugin-vue-components/vite';import { ElementPlusResolver } from 'unplugin-vue-components/resolvers';export default defineConfig({// ...plugins: [AutoImport({resolvers: [ElementPlusResolver()],}),Components({resolvers: [ElementPlusResolver({importStyle: 'sass',})],}),],css: {preprocessorOptions: {scss: {// ...additionalData: `@use "./src/TUIRoom/assets/style/element.scss" as *;`,},},},});
src/main.ts
にelement-plusコンポーネントスタイルをロードしてください。// src/main.tsimport 'element-plus/theme-chalk/el-message.css';import 'element-plus/theme-chalk/el-message-box.css';
npm install sass sass-loader typescript unplugin-auto-import unplugin-vue-components unplugin-element-plus @types/events -S -D
npm install element-plus events mitt pinia rtc-beauty-plugin tim-js-sdk trtc-js-sdk tsignaling -S
src/main.ts
ファイルです。// src/main.tsファイルimport { createPinia } from 'pinia';const app = createApp(App);// pinia登録app.use(createPinia());app.mount('#app');
vue.config.js
で、element-plusコンポーネントを必要に応じてロードするように設定しておく必要があります。// vue.config.jsconst { defineConfig } = require('@vue/cli-service')const AutoImport = require('unplugin-auto-import/webpack')const Components = require('unplugin-vue-components/webpack')const { ElementPlusResolver } = require('unplugin-vue-components/resolvers')const ElementPlus = require('unplugin-element-plus/webpack')module.exports = defineConfig({transpileDependencies: true,css: {loaderOptions: {scss: {additionalData: '@use "./src/TUIRoom/assets/style/element.scss" as *;'}}},configureWebpack: {plugins: [AutoImport({resolvers: [ElementPlusResolver({ importStyle: 'sass' })]}),Components({resolvers: [ElementPlusResolver({ importStyle: 'sass' })]}),// 必要に応じてインポート時のテーマカラーをカスタマイズElementPlus({useSource: true})]}})
src/main.ts
にelement-plusコンポーネントスタイルをロードしてください。// src/main.tsimport 'element-plus/theme-chalk/el-message.css';import 'element-plus/theme-chalk/el-message-box.css';
src/shims-vue.d.ts
ファイルに以下の設定を追加します。declare module 'tsignaling/tsignaling-js' {import TSignaling from 'tsignaling/tsignaling-js';export default TSignaling;}declare module 'tim-js-sdk' {import TIM from 'tim-js-sdk';export default TIM;}declare const Aegis: any;
npm run dev
http://localhost:3000/
を開きます。npm run serve
http://localhost:8080/
のページを開きますnpm run build
TUIRoomRef.value.init(roomData);
パラメータ | タイプ | 意味 |
roomData | object | |
roomData.sdkAppId | number | お客様のSDKAppId |
roomData.userId | string | ユーザーの唯一ID |
roomData.userSig | string | ユーザーのUserSig |
roomData.userName | string | ユーザーのニックネーム |
roomData.userAvatar | string | ユーザーのプロフィール写真 |
roomData.shareUserId | string | 非必須。ユーザーが画面共有を行うUserIdです。shareUserId= share_${userId} が要求され、画面共有機能がない場合は渡されません |
roomData.shareUserSig | string | 非必須。ユーザーが画面共有を行うUserSig |
TUIRoomRef.value.createRoom(roomId, roomMode, roomParam);
パラメータ | タイプ | 意味 |
roomId | number | ルームID |
roomMode | string | ルームモードです。'FreeSpeech'(自由発言モード)と'ApplySpeech'(举手発言モード)を含み、デフォルトは'FreeSpeech'です。現在、自由発言モードだけをサポートします |
roomParam | Object | 非必須 |
roomParam.isOpenCamera | string | 非必須。入室はカメラをオンにするかどうか。デフォルトはオフです |
roomParam.isOpenMicrophone | string | 非必須。入室はマイクをオンにするかどうか。デフォルトはオフです |
roomParam.defaultCameraId | string | 非必須。デフォルトはカメラ装置のID |
roomParam.defaultMicrophoneId | string | 非必須。デフォルトはマイク装置のID |
roomParam.defaultSpeakerId | String | 非必須。デフォルトはスピーカー装置のID |
TUIRoomRef.value.enterRoom(roomId, roomParam);
パラメータ | タイプ | 意味 |
roomId | number | ルームID |
roomParam | Object | 非必須 |
roomParam.isOpenCamera | string | 非必須。入室はカメラをオンにするかどうか。デフォルトはオフです |
roomParam.isOpenMicrophone | string | 非必須。入室はマイクをオンにするかどうか。デフォルトはオフです |
roomParam.defaultCameraId | string | 非必須。デフォルトはカメラ装置のID |
roomParam.defaultMicrophoneId | string | 非必須。デフォルトはマイク装置のID |
roomParam.defaultSpeakerId | String | 非必須。デフォルトはスピーカー装置のID |
<template><room ref="TUIRoomRef" @on-room-create="handleRoomCreate"></room></template><script setup lang="ts">// TUIRoomコンポーネントをインポートします。インポートパスが正しいことを確認してくださいimport Room from './TUIRoom/index.vue';function handleRoomCreate(info) {if (info.code === 0) {console.log('ルーム作成成功')}}</script>
<template><room ref="TUIRoomRef" @on-room-enter="handleRoomEnter"></room></template><script setup lang="ts">// TUIRoomコンポーネントをインポートします。インポートパスが正しいことを確認してくださいimport Room from './TUIRoom/index.vue';function handleRoomEnter(info) {if (info.code === 0) {console.log('入室成功')}}</script>
<template><room ref="TUIRoomRef" @on-room-destory="handleRoomDestory"></room></template><script setup lang="ts">// TUIRoomコンポーネントをインポートします。インポートパスが正しいことを確認してくださいimport Room from './TUIRoom/index.vue';function handleRoomDestory(info) {if (info.code === 0) {console.log('キャスターが廃棄することに成功しました')}}</script>
<template><room ref="TUIRoomRef" @on-room-exit="handleRoomExit"></room></template><script setup lang="ts">// TUIRoomコンポーネントをインポートします。インポートパスが正しいことを確認してくださいimport Room from './TUIRoom/index.vue';function handleRoomExit(info) {if (info.code === 0) {console.log('一般メンバーが退室することに成功しました')}}</script>
<template><room ref="TUIRoomRef" @on-kick-off="handleKickOff"></room></template><script setup lang="ts">// TUIRoomコンポーネントをインポートします。インポートパスが正しいことを確認してくださいimport Room from './TUIRoom/index.vue';function handleKickOff(info) {if (info.code === 0) {console.log('一般メンバーがキャスターにルームからキックアウト')}}</script>
この記事はお役に立ちましたか?