From 217eeea846af5d11a77df5390964a886c83116dd Mon Sep 17 00:00:00 2001 From: heyujie <516346543@qq.com> Date: 星期四, 04 十一月 2021 16:25:54 +0800 Subject: [PATCH] desk sdk play video --- src/pages/desktop/index/components/ToolsEntry.vue | 221 ++++++++++++++++++++++++++++++++++++++----------------- 1 files changed, 152 insertions(+), 69 deletions(-) diff --git a/src/pages/desktop/index/components/ToolsEntry.vue b/src/pages/desktop/index/components/ToolsEntry.vue index 6c84eb8..f116062 100644 --- a/src/pages/desktop/index/components/ToolsEntry.vue +++ b/src/pages/desktop/index/components/ToolsEntry.vue @@ -2,35 +2,49 @@ <div class="tools-entry"> <div class="entry-wrap"> <el-carousel - :height="rowSize==3?'600px':'770px'" + :height="rowSize == 3 ? '600px' : '770px'" :autoplay="false" arrow="never" - :indicator-position="carousels.length==1?'none':''" + :indicator-position="carousels.length == 1 ? 'none' : ''" > - <el-carousel-item v-for="(carousel,index) in carousels" :key="index"> + <el-carousel-item v-for="(carousel, index) in carousels" :key="index"> <div class="app-list clearFix sdk-list"> <!-- <draggable v-model="carousel" @start="drag=true" @end="drag=false"> --> <div v-for="item in carousel" :key="item.id"> - <div class="app" v-if="item.url" @click="dockClick(item)"> + <div + class="app" + v-if="item.url && !item.sdk_name" + @click="dockClick(item)" + > <div class="wrap"> <div class="app-icon"> <div class="badge" - v-if="item.name=='algorithmManage' && badgeNum > 0" - >{{badgeNum}}</div> + v-if="item.name == 'algorithmManage' && badgeNum > 0" + > + {{ badgeNum }} + </div> <img :src="item.src" :alt="item.alt" /> </div> - <div class="app-name">{{item.title}}</div> + <div class="app-name">{{ item.title }}</div> </div> </div> - <div class="app sdk" v-if="item.sdk_name"> + <div + class="app sdk" + v-if="item.sdk_name" + @click="openSdkVideo(item)" + > <div class="wrap"> <div class="app-icon"> <img - :src="item.iconBlob.indexOf(',')>0? item.iconBlob:`data:image/png;base64,${item.iconBlob}`" + :src=" + item.iconBlob.indexOf(',') > 0 + ? item.iconBlob + : `data:image/png;base64,${item.iconBlob}` + " /> </div> - <div class="app-name">{{item.sdk_name}}</div> + <div class="app-name">{{ item.sdk_name }}</div> </div> </div> </div> @@ -42,45 +56,67 @@ <img :src="`${publicPath}images/desktop/desk-logo.png`" alt /> </div> </div> + + <div class="videolist_appbox" v-if="showVideo"> + <div class="video_t"> + <video + width="1164" + height="655" + :src="videoUrl" + type="video/mp4" + poster="" + controls="controls" + preload="none" + autoplay="autoplay" + controlslist="nodownload" + ></video> + </div> + <!-- <div class="mask"></div> --> + <div class="video_close" @click="showVideo = false"> + <!-- <img src="../../assets/img/about_dot18.png"> --> + <span class="icon iconfont"></span> + </div> + </div> </div> </template> <script> -import draggable from "vuedraggable" -import { findAllSdk } from '@/api/taskMange'; -import { chunkArr } from '@/scripts/util'; -import bus from '@/plugin/bus' +import draggable from "vuedraggable"; +import { findAllSdk } from "@/api/taskMange"; +import { chunkArr } from "@/scripts/util"; +import bus from "@/plugin/bus"; export default { - name: 'toolsEntry', + name: "toolsEntry", data() { return { publicPath: process.env.BASE_URL, loading: true, - //carousels: [], + showVideo: false, localApps: [], installedSdk: [], + videoUrl: "", sdkList: [ { - src: '', - title: '涓綋闈欐' + src: + "", + title: "涓綋闈欐", }, { - src: '', - title: '浜哄憳璺熻釜' - } + src: + "", + title: "浜哄憳璺熻釜", + }, ], - //rowSize: 3, - // badgeNum: 0, - } + }; }, computed: { stateDocks() { - return this.$store.state.desktop.docks + return this.$store.state.desktop.docks; }, carousels() { let pages = 0; let tempArr = this.stateDocks.concat(this.installedSdk); - let upgradeArr = tempArr.filter(item => item.isUpgrade); + let upgradeArr = tempArr.filter((item) => item.isUpgrade); let arr = null; //鏍规嵁灞忓箷楂樺害鏉ュ垽鏂槸灞曠ず3鎺掕繕鏄�4鎺� 闃堝��:970 if (window.innerHeight >= 930) { @@ -90,11 +126,11 @@ //this.rowSize = 3; arr = this.chunk(tempArr, 18); } - return arr + return arr; }, badgeNum() { let tempArr = this.stateDocks.concat(this.installedSdk); - return tempArr.filter(item => item.isUpgrade).length; + return tempArr.filter((item) => item.isUpgrade).length; }, rowSize() { if (window.innerHeight >= 930) { @@ -102,12 +138,12 @@ } else { return 3; } - } + }, }, mounted() { this.getAllSdk(); - //this.carousels = - window.addEventListener('message', e => { + //this.carousels = + window.addEventListener("message", (e) => { if (e.data && e.data.msg) { let msg = e.data.msg; // token 涓嶅悎娉�, 閫�鍑� @@ -117,125 +153,132 @@ } if (msg.indexOf("toSearch") >= 0) { let params = msg.substring(7); - this.addFrameByName("search", params) + this.addFrameByName("search", params); } if (msg.indexOf("toCluster") >= 0) { let params = msg.substring(8); - this.addFrameByName("searchForCluster", params) + this.addFrameByName("searchForCluster", params); } if (msg.indexOf("toOpenApp") >= 0) { let id = msg.substring(10); console.log(id); - this.addFrameByID(id) + this.addFrameByID(id); } } }); - }, methods: { chunk(arr, size) { size = Math.max(size, 0); const len = arr == null ? 0 : arr.length; if (!len || size < 1) { - return [] + return []; } let index = 0; let resIndex = 0; - const result = new Array(Math.ceil(len / size)) + const result = new Array(Math.ceil(len / size)); while (index < len) { - result[resIndex++] = arr.slice(index, index += size) + result[resIndex++] = arr.slice(index, (index += size)); } - return result + return result; }, getAllSdk() { - findAllSdk().then(res => { - this.installedSdk = res.data.filter(item => item.installed) - }).catch(e => { - console.log(e) - }) + findAllSdk() + .then((res) => { + this.installedSdk = res.data.filter((item) => item.installed); + }) + .catch((e) => { + console.log(e); + }); }, dockClick(dock) { - if (dock.type === '1') { + debugger; + if (dock.type === "1") { window.open(dock.url); - } else if (dock.type === '2' && !dock.isOpen) { - this.$store.dispatch('desktop/addFrame', { + } else if (dock.type === "2" && !dock.isOpen) { + this.$store.dispatch("desktop/addFrame", { id: dock.id, icon: dock.src, title: dock.title, - url: dock.url + url: dock.url, }); - this.$store.commit('desktop/addMinDock', { + this.$store.commit("desktop/addMinDock", { id: dock.id, src: dock.src, alt: dock.title, type: "3", highlight: true, url: dock.url, - screenshot: '' + screenshot: "", }); //鎵撳紑搴旂敤鍚庡紓姝ユ姄鎷�,涔嬪悗鐨勬姄鎷嶉噰鐢ㄨ繖寮犲浐瀹氱殑 //if(dock.name=='cameraVideo'||dock.name=='search'||dock.name=='library'||dock.name=='cameraAccess'||dock.name=='dataStack'){ setTimeout(() => { this.$parent.screenShot(dock); - }, 1500) + }, 1500); //} - } else if (dock.type === '2' && dock.isOpen) { - this.$store.commit('desktop/resetMinFrame', dock.id); + } else if (dock.type === "2" && dock.isOpen) { + this.$store.commit("desktop/resetMinFrame", dock.id); } - + }, + openSdkVideo(dock) { + if (dock.url && dock.sdk_name) { + this.videoUrl = dock.url; + this.showVideo = true; + } }, resetDockItem() { - const dockItems = document.getElementsByClassName('dock-item'); - const dockMask = document.getElementsByClassName('dock-mask')[0]; + const dockItems = document.getElementsByClassName("dock-item"); + const dockMask = document.getElementsByClassName("dock-mask")[0]; for (let i = 0; i < dockItems.length; i++) { dockItems[i].width = 60; if (dockItems[i].parentNode.nextElementSibling) { dockItems[i].parentNode.nextElementSibling.style.marginLeft = "-35px"; } } - dockMask.style.width = dockItems.length * 60 + 40 + 'px'; + dockMask.style.width = dockItems.length * 60 + 40 + "px"; }, addFrameByName(name, params) { let dock = null; - this.$store.state.desktop.docks.forEach(app => { + this.$store.state.desktop.docks.forEach((app) => { if (app.name === name) { dock = app; } }); if (dock.isOpen) { - this.$store.dispatch('desktop/closeFrame', dock); + this.$store.dispatch("desktop/closeFrame", dock); } - this.$store.dispatch('desktop/addFrame', { + this.$store.dispatch("desktop/addFrame", { id: dock.id, icon: dock.src, title: dock.title, - url: dock.url + "?" + params + url: dock.url + "?" + params, }); - this.$store.commit('desktop/addMinDock', { + this.$store.commit("desktop/addMinDock", { id: dock.id, src: dock.src, alt: dock.title, type: "3", highlight: true, url: dock.url, - screenshot: '' + screenshot: "", }); }, addFrameByID(id, params) { let dock = null; - let toClose = null - this.$store.state.desktop.docks.forEach(app => { + let toClose = null; + this.$store.state.desktop.docks.forEach((app) => { if (app.id == id) { dock = app; } if (app.name == "algorithmManage") { - toClose = app + toClose = app; } }); - this.dockClick(dock) - } - } + this.dockClick(dock); + }, + }, }; </script> @@ -335,5 +378,45 @@ } } } + .videolist_appbox { + position: fixed; + width: 100%; + height: 100%; + top: 0; + left: 0; + z-index: 9999999; + } + + .videolist_appbox .video_t { + // left: 19%; + // top: 15%; + // position: absolute; + // height: 655px; + // width: 1164px; + z-index: 2; + // background: #000; + } + + .videolist_appbox .mask { + position: absolute; + z-index: 1; + left: 0; + top: 0; + width: 100%; + height: 100%; + background: rgba(0, 0, 0, 0.5); + } + + .video_close { + position: absolute; + top: 0; + right: 0; + cursor: pointer; + z-index: 3; + color: #fff; + background: lightgray; + padding: 10px; + border-radius: 20px; + } } </style> \ No newline at end of file -- Gitblit v1.8.0