| 1 |
- {"ast":null,"code":"import \"core-js/modules/es.array.push.js\";\nimport { getUsersig } from '@/api/home';\nimport { getWidth, getHeight } from \"@/utils/utils\";\nimport roomFooter from './components/roomFooter.vue';\nimport TRTC from 'trtc-sdk-v5';\nconst trtc = TRTC.create();\nexport default {\n name: 'App',\n components: {\n roomFooter\n },\n data() {\n return {\n userClass: \"userVideo5\",\n userList: [],\n userHeight: '100%',\n userSign: \"\",\n roomId: \"\"\n };\n },\n methods: {\n async exitRoom() {\n await trtc.exitRoom();\n await trtc.updateLocalVideo({\n publish: false\n });\n await trtc.updateLocalAudio({\n publish: false\n });\n // await trtc.destroy();\n this.$router.push({\n name: \"Home\"\n });\n // this.$router.go(-1)\n }\n },\n\n async mounted() {\n let roomId = this.$route.query.roomId;\n this.roomId = this.$route.query.roomId;\n let userId = this.$route.query.userId;\n const sdkAppId = 1600011167;\n // 获取usersign\n await getUsersig(userId).then(res => {\n this.userSign = res.msg;\n });\n trtc.on(TRTC.EVENT.REMOTE_VIDEO_AVAILABLE, event => {\n const userId = event.userId;\n const streamType = event.streamType;\n this.userList.push(userId);\n this.userClass = getWidth(this.userList);\n this.userHeight = getHeight(this.userList);\n setTimeout(() => {\n trtc.startRemoteVideo({\n userId,\n streamType,\n view: `${userId}`\n });\n });\n });\n trtc.on(TRTC.EVENT.REMOTE_VIDEO_UNAVAILABLE, event => {\n const userId = event.userId;\n let deleteIndex = this.userList.indexOf(userId);\n this.userList = this.userList.filter(item => item !== userId);\n if (deleteIndex !== -1) {\n this.userList.splice(deleteIndex, 1);\n }\n });\n try {\n await trtc.enterRoom({\n roomId: Number(roomId),\n scene: 'rtc',\n sdkAppId,\n userId,\n userSig: this.userSign\n });\n await trtc.startLocalVideo({\n view: document.getElementById('localStream') // 在 DOM 中的 elementId 为 localStream 的标签上预览视频。\n });\n\n await trtc.startLocalAudio();\n console.log('进房成功');\n this.$message({\n message: \"进房成功\",\n type: 'success'\n });\n } catch (error) {\n console.error('进房失败 ' + error);\n this.$message({\n message: \"进房失败\",\n type: 'error'\n });\n this.$router.push({\n name: 'Home'\n });\n }\n },\n created() {}\n};","map":{"version":3,"names":["getUsersig","getWidth","getHeight","roomFooter","TRTC","trtc","create","name","components","data","userClass","userList","userHeight","userSign","roomId","methods","exitRoom","updateLocalVideo","publish","updateLocalAudio","$router","push","mounted","$route","query","userId","sdkAppId","then","res","msg","on","EVENT","REMOTE_VIDEO_AVAILABLE","event","streamType","setTimeout","startRemoteVideo","view","REMOTE_VIDEO_UNAVAILABLE","deleteIndex","indexOf","filter","item","splice","enterRoom","Number","scene","userSig","startLocalVideo","document","getElementById","startLocalAudio","console","log","$message","message","type","error","created"],"sources":["src/views/room.vue"],"sourcesContent":["<template>\n <div class=\"roompage\">\n <div :class=\"userClass\" :style=\"{ height: userHeight }\" id=\"localStream\"></div>\n <div :class=\"userClass\" :style=\"{ height: userHeight }\" v-for=\"(item, index) in userList\" :key=\"index\" :id=\"item\">\n </div>\n <div class=\"footer\">\n <roomFooter @exitRoom=\"exitRoom\" :roomId=\"roomId\"></roomFooter>\n </div>\n </div>\n</template>\n \n<script>\nimport { getUsersig } from '@/api/home';\nimport { getWidth, getHeight } from \"@/utils/utils\";\nimport roomFooter from './components/roomFooter.vue';\nimport TRTC from 'trtc-sdk-v5';\nconst trtc = TRTC.create();\nexport default {\n name: 'App',\n components: {\n roomFooter\n },\n data() {\n return {\n userClass: \"userVideo5\",\n userList: [],\n userHeight: '100%',\n userSign: \"\",\n roomId:\"\"\n };\n },\n methods: {\n async exitRoom(){\n await trtc.exitRoom();\n await trtc.updateLocalVideo({publish:false});\n await trtc.updateLocalAudio({publish:false});\n // await trtc.destroy();\n this.$router.push({\n name:\"Home\"\n })\n // this.$router.go(-1)\n }\n },\n async mounted() {\n let roomId = this.$route.query.roomId;\n this.roomId = this.$route.query.roomId;\n let userId = this.$route.query.userId;\n const sdkAppId = 1600011167;\n // 获取usersign\n await getUsersig(userId).then(res => {\n this.userSign = res.msg;\n })\n trtc.on(TRTC.EVENT.REMOTE_VIDEO_AVAILABLE, event => {\n const userId = event.userId;\n const streamType = event.streamType;\n this.userList.push(userId);\n this.userClass = getWidth(this.userList);\n this.userHeight = getHeight(this.userList);\n setTimeout(() => {\n trtc.startRemoteVideo({ userId, streamType, view: `${userId}` })\n })\n })\n trtc.on(TRTC.EVENT.REMOTE_VIDEO_UNAVAILABLE, event=>{\n const userId = event.userId;\n let deleteIndex = this.userList.indexOf(userId);\n this.userList = this.userList.filter(item=>item !== userId);\n if(deleteIndex !== -1){\n this.userList.splice(deleteIndex,1)\n }\n })\n try {\n await trtc.enterRoom({ roomId: Number(roomId), scene: 'rtc', sdkAppId, userId, userSig: this.userSign });\n await trtc.startLocalVideo({\n view: document.getElementById('localStream'), // 在 DOM 中的 elementId 为 localStream 的标签上预览视频。\n });\n await trtc.startLocalAudio();\n console.log('进房成功');\n this.$message({\n message:\"进房成功\",\n type:'success'\n })\n } catch (error) {\n console.error('进房失败 ' + error);\n this.$message({\n message:\"进房失败\",\n type:'error'\n });\n this.$router.push({\n name:'Home'\n })\n }\n },\n created() {\n \n },\n};\n</script>\n \n<style scoped>\n.roompage {\n width: 100%;\n height: 100vh;\n display: flex;\n align-items: center;\n justify-content: space-around;\n flex-wrap: wrap;\n position: relative;\n}\n\n.userVideo5 {\n width: 100%;\n background-color: yellow;\n}\n\n.userVideo {\n width: 48%;\n background-color: yellow;\n}\n\n.userVideo1 {\n width: 33%;\n background-color: yellow;\n}\n\n.userVideo2 {\n width: 33%;\n background-color: yellow;\n}\n\n.userVideo3 {\n width: 33%;\n background-color: yellow;\n}\n\n.userVideo4 {\n width: 100%;\n background-color: yellow;\n}\n.footer{\n width: 100%;\n height: 10%;\n background: rgb(46 43 43 / 90%);\n position: absolute;\n bottom: 0;\n}\n</style>\n \n \n "],"mappings":";AAYA,SAAAA,UAAA;AACA,SAAAC,QAAA,EAAAC,SAAA;AACA,OAAAC,UAAA;AACA,OAAAC,IAAA;AACA,MAAAC,IAAA,GAAAD,IAAA,CAAAE,MAAA;AACA;EACAC,IAAA;EACAC,UAAA;IACAL;EACA;EACAM,KAAA;IACA;MACAC,SAAA;MACAC,QAAA;MACAC,UAAA;MACAC,QAAA;MACAC,MAAA;IACA;EACA;EACAC,OAAA;IACA,MAAAC,SAAA;MACA,MAAAX,IAAA,CAAAW,QAAA;MACA,MAAAX,IAAA,CAAAY,gBAAA;QAAAC,OAAA;MAAA;MACA,MAAAb,IAAA,CAAAc,gBAAA;QAAAD,OAAA;MAAA;MACA;MACA,KAAAE,OAAA,CAAAC,IAAA;QACAd,IAAA;MACA;MACA;IACA;EACA;;EACA,MAAAe,QAAA;IACA,IAAAR,MAAA,QAAAS,MAAA,CAAAC,KAAA,CAAAV,MAAA;IACA,KAAAA,MAAA,QAAAS,MAAA,CAAAC,KAAA,CAAAV,MAAA;IACA,IAAAW,MAAA,QAAAF,MAAA,CAAAC,KAAA,CAAAC,MAAA;IACA,MAAAC,QAAA;IACA;IACA,MAAA1B,UAAA,CAAAyB,MAAA,EAAAE,IAAA,CAAAC,GAAA;MACA,KAAAf,QAAA,GAAAe,GAAA,CAAAC,GAAA;IACA;IACAxB,IAAA,CAAAyB,EAAA,CAAA1B,IAAA,CAAA2B,KAAA,CAAAC,sBAAA,EAAAC,KAAA;MACA,MAAAR,MAAA,GAAAQ,KAAA,CAAAR,MAAA;MACA,MAAAS,UAAA,GAAAD,KAAA,CAAAC,UAAA;MACA,KAAAvB,QAAA,CAAAU,IAAA,CAAAI,MAAA;MACA,KAAAf,SAAA,GAAAT,QAAA,MAAAU,QAAA;MACA,KAAAC,UAAA,GAAAV,SAAA,MAAAS,QAAA;MACAwB,UAAA;QACA9B,IAAA,CAAA+B,gBAAA;UAAAX,MAAA;UAAAS,UAAA;UAAAG,IAAA,KAAAZ,MAAA;QAAA;MACA;IACA;IACApB,IAAA,CAAAyB,EAAA,CAAA1B,IAAA,CAAA2B,KAAA,CAAAO,wBAAA,EAAAL,KAAA;MACA,MAAAR,MAAA,GAAAQ,KAAA,CAAAR,MAAA;MACA,IAAAc,WAAA,QAAA5B,QAAA,CAAA6B,OAAA,CAAAf,MAAA;MACA,KAAAd,QAAA,QAAAA,QAAA,CAAA8B,MAAA,CAAAC,IAAA,IAAAA,IAAA,KAAAjB,MAAA;MACA,IAAAc,WAAA;QACA,KAAA5B,QAAA,CAAAgC,MAAA,CAAAJ,WAAA;MACA;IACA;IACA;MACA,MAAAlC,IAAA,CAAAuC,SAAA;QAAA9B,MAAA,EAAA+B,MAAA,CAAA/B,MAAA;QAAAgC,KAAA;QAAApB,QAAA;QAAAD,MAAA;QAAAsB,OAAA,OAAAlC;MAAA;MACA,MAAAR,IAAA,CAAA2C,eAAA;QACAX,IAAA,EAAAY,QAAA,CAAAC,cAAA;MACA;;MACA,MAAA7C,IAAA,CAAA8C,eAAA;MACAC,OAAA,CAAAC,GAAA;MACA,KAAAC,QAAA;QACAC,OAAA;QACAC,IAAA;MACA;IACA,SAAAC,KAAA;MACAL,OAAA,CAAAK,KAAA,WAAAA,KAAA;MACA,KAAAH,QAAA;QACAC,OAAA;QACAC,IAAA;MACA;MACA,KAAApC,OAAA,CAAAC,IAAA;QACAd,IAAA;MACA;IACA;EACA;EACAmD,QAAA,GAEA;AACA"},"metadata":{},"sourceType":"module","externalDependencies":[]}
|