From 1e84774c0c0752c61e60592e7f7fc1c0d25a1dab Mon Sep 17 00:00:00 2001
From: hanbaoshan <hanbaoshan@aiotlink.com>
Date: 星期二, 27 十月 2020 16:38:48 +0800
Subject: [PATCH] 首页加入算法
---
src/pages/ai/index/App.vue | 16 +-
src/pages/labelMark/components/RightSide.vue | 149 +++++++++++++-----------
src/pages/desktop/index/components/ToolsEntry.vue | 119 +++++++++++++++++--
src/components/subComponents/FileUpload/uploader.vue | 13 +
src/components/subComponents/FileUpload/index.vue | 8
src/components/subComponents/FileUpload/btn.vue | 7
6 files changed, 207 insertions(+), 105 deletions(-)
diff --git a/src/components/subComponents/FileUpload/btn.vue b/src/components/subComponents/FileUpload/btn.vue
index 7638874..d624a23 100644
--- a/src/components/subComponents/FileUpload/btn.vue
+++ b/src/components/subComponents/FileUpload/btn.vue
@@ -26,14 +26,15 @@
default() {
return {}
}
- }
+ },
+
},
watch: {
attrs: {
handler(n, o) {
- this.$nextTick(() => {
+ //this.$nextTick(() => {
this.uploader.uploader.assignBrowse(this.$refs.btn, this.directory, this.single, n)
- })
+ //})
},
deep: true
}
diff --git a/src/components/subComponents/FileUpload/index.vue b/src/components/subComponents/FileUpload/index.vue
index 1512cf3..35d8293 100644
--- a/src/components/subComponents/FileUpload/index.vue
+++ b/src/components/subComponents/FileUpload/index.vue
@@ -81,11 +81,11 @@
},
attrs: {
type: Object,
- // default () {
- // return {
+ default () {
+ return {
- // }
- // }
+ }
+ }
}
},
data() {
diff --git a/src/components/subComponents/FileUpload/uploader.vue b/src/components/subComponents/FileUpload/uploader.vue
index 41fb54c..ddcedb9 100644
--- a/src/components/subComponents/FileUpload/uploader.vue
+++ b/src/components/subComponents/FileUpload/uploader.vue
@@ -5,8 +5,8 @@
<uploader-unsupport></uploader-unsupport>
<uploader-drop>
<!-- <p>鎷栧姩鏂囦欢鍒拌鍖哄煙涓婁紶</p> -->
- <uploader-btn :attrs="attrs">閫夋嫨鏂囦欢</uploader-btn>
- <uploader-btn :directory="true" :attrs="attrs">閫夋嫨鏂囦欢澶�</uploader-btn>
+ <uploader-btn >閫夋嫨鏂囦欢</uploader-btn>
+ <uploader-btn :directory="true" >閫夋嫨鏂囦欢澶�</uploader-btn>
</uploader-drop>
<uploader-list></uploader-list>
</slot>
@@ -37,10 +37,10 @@
attrs:{
handler(n,o){
console.log('uploader attrs update',n)
- this.$nextTick(()=>{
- //this.unBindUploader();
+ //this.$nextTick(()=>{
+ this.unBindUploader();
this.bindUploader();
- })
+ //})
},
deep: true
},
@@ -168,6 +168,9 @@
// uploader.on('fileRemoved', this.fileRemoved)
// uploader.on('filesSubmitted', this.filesSubmitted)
},
+ mounted(){
+ //this.bindUploader();
+ },
destroyed() {
this.unBindUploader();
// const uploader = this.uploader
diff --git a/src/pages/ai/index/App.vue b/src/pages/ai/index/App.vue
index c836d3e..236b9d4 100644
--- a/src/pages/ai/index/App.vue
+++ b/src/pages/ai/index/App.vue
@@ -624,16 +624,16 @@
setTimeout(() => {
if (action == 'upgrade') {
app.upgradeLoading = false;
- _this.$notify({
- type: 'success',
- message: '鍗囩骇鎴愬姛'
- });
+ // _this.$notify({
+ // type: 'success',
+ // message: '鍗囩骇鎴愬姛'
+ // });
} else {
app.installLoading = false;
- _this.$notify({
- type: 'success',
- message: '瀹夎鎴愬姛'
- });
+ // _this.$notify({
+ // type: 'success',
+ // message: '瀹夎鎴愬姛'
+ // });
}
_this.getAllApps();
window.parent.postMessage({
diff --git a/src/pages/desktop/index/components/ToolsEntry.vue b/src/pages/desktop/index/components/ToolsEntry.vue
index 13de460..d519f72 100644
--- a/src/pages/desktop/index/components/ToolsEntry.vue
+++ b/src/pages/desktop/index/components/ToolsEntry.vue
@@ -1,16 +1,54 @@
<template>
<div class="tools-entry">
<div class="entry-wrap">
- <div class="app-list clearFix">
- <div class="app" v-for="dock in stateDocks" :key="dock.id" @click="dockClick(dock)">
- <div class="wrap">
- <div class="app-icon">
- <img :src="dock.src" :alt="dock.alt" />
+ <el-carousel height="600px" :autoplay="false" >
+ <el-carousel-item v-for="(carousel,index) in carousels" :key="index">
+ <div class="app-list clearFix sdk-list" >
+ <div v-for="item in carousel" :key="item.id">
+ <div class="app" v-if="item.url" @click="dockClick(item)">
+ <div class="wrap">
+ <div class="app-icon">
+ <img :src="item.src" :alt="item.alt" />
+ </div>
+ <div class="app-name">{{item.title}}</div>
+ </div>
</div>
- <div class="app-name">{{dock.title}}</div>
+ <div class="app sdk" v-if="item.sdk_name">
+ <div class="wrap">
+ <div class="app-icon">
+ <img
+ :src="item.iconBlob.indexOf(',')>0? item.iconBlob:`data:image/png;base64,${item.iconBlob}`"
+ style="width:82%"
+ />
+ </div>
+ <div class="app-name">{{item.sdk_name}}</div>
+ </div>
+ </div>
+ </div>
+
+ <!-- <div class="app" v-for="dock in stateDocks" :key="dock.id" @click="dockClick(dock)">
+ <div class="wrap">
+ <div class="app-icon">
+ <img :src="dock.src" :alt="dock.alt" />
+ </div>
+ <div class="app-name">{{dock.title}}</div>
+ </div>
+ </div>
+ <div class="app sdk" v-for="(item,index) in sdkList" :key="index+'sdk'">
+ <div class="wrap">
+ <div class="app-icon">
+ <img
+ :src="item.iconBlob.indexOf(',')>0? item.iconBlob:`data:image/png;base64,${item.iconBlob}`"
+ style="width:82%"
+ />
+ </div>
+ <div class="app-name">{{item.sdk_name}}</div>
+ </div>
+ </div> -->
</div>
- </div>
- </div>
+ </el-carousel-item>
+ </el-carousel>
+
<div class="logo">
<img :src="`${publicPath}images/desktop/desk-logo.png`" alt />
</div>
@@ -19,21 +57,44 @@
</template>
<script>
+import { findAllSdk } from '@/api/taskMange';
export default {
name: 'toolsEntry',
- data() {
+ data () {
return {
publicPath: process.env.BASE_URL,
loading: true,
- localApps: []
+ //carousels: [],
+ localApps: [],
+ installedSdk: [],
+ sdkList: [
+ {
+ src: '',
+ title: '涓綋闈欐'
+ },
+ {
+ src: '',
+ title: '浜哄憳璺熻釜'
+ }
+ ]
}
},
computed: {
- stateDocks() {
+ stateDocks () {
return this.$store.state.desktop.docks
+ },
+ carousels () {
+ let pages = 0;
+ let tempArr = this.stateDocks.concat(this.installedSdk);
+
+ let arr = this.chunk(tempArr,18);
+ console.log(arr)
+ return arr
}
},
- mounted() {
+ mounted () {
+ this.getAllSdk();
+ //this.carousels =
window.addEventListener('message', e => {
if (e.data && e.data.msg) {
let msg = e.data.msg;
@@ -53,7 +114,28 @@
},
methods: {
- dockClick(dock) {
+ chunk(arr,size){
+ size = Math.max(size,0);
+ const len = arr == null ? 0: arr.length;
+ if(!len || size <1){
+ return []
+ }
+ let index = 0;
+ let resIndex = 0;
+ const result = new Array(Math.ceil(len/size))
+ while(index<len){
+ result[resIndex++] = arr.slice(index,index+=size)
+ }
+ return result
+ },
+ getAllSdk () {
+ findAllSdk().then(res => {
+ this.installedSdk = res.data.filter(item => item.installed)
+ }).catch(e => {
+ console.log(e)
+ })
+ },
+ dockClick (dock) {
if (dock.type === '1') {
window.open(dock.url);
} else if (dock.type === '2' && !dock.isOpen) {
@@ -83,7 +165,7 @@
this.$store.commit('desktop/resetMinFrame', dock.id);
}
},
- resetDockItem() {
+ resetDockItem () {
const dockItems = document.getElementsByClassName('dock-item');
const dockMask = document.getElementsByClassName('dock-mask')[0];
for (let i = 0; i < dockItems.length; i++) {
@@ -94,7 +176,7 @@
}
dockMask.style.width = dockItems.length * 60 + 40 + 'px';
},
- addFrameByName(name, params) {
+ addFrameByName (name, params) {
let dock = null;
this.$store.state.desktop.docks.forEach(app => {
@@ -127,6 +209,12 @@
</script>
<style lang="scss">
+.el-carousel__arrow--left{
+ left: 0 !important;
+}
+.el-carousel__arrow--right{
+ right: 0 !important;
+}
.tools-entry {
//margin-top: 130px;
position: absolute;
@@ -187,6 +275,7 @@
text-align: right;
padding-right: 50px;
user-select: none;
+ margin-top: -100px;
img {
user-select: none;
-webkit-user-drag: none;
diff --git a/src/pages/labelMark/components/RightSide.vue b/src/pages/labelMark/components/RightSide.vue
index 741a5c2..7e94302 100644
--- a/src/pages/labelMark/components/RightSide.vue
+++ b/src/pages/labelMark/components/RightSide.vue
@@ -1,5 +1,65 @@
<template>
<div class="right-side">
+ <div class="figure">
+ <div class="action-bar">
+ <el-button
+ class="drawboard-trigger"
+ size="small"
+ @click="isEdit=!isEdit"
+ :icon="isEdit?'el-icon-lock':'el-icon-edit'"
+ >{{isEdit?'閿佸畾':'缂栬緫'}}</el-button>
+ </div>
+ <div class="drawboard">
+ <div class="mask" :class="{'edit-status-mask':isEdit}" ref="editBoard">
+ <div
+ class="label"
+ @click="editLabel(item)"
+ v-for="(item,index) in labels"
+ :key="index"
+ :style="{left:`${item.x}px`, top:`${item.y}px`, backgroundColor: colorPick, width: `${dotSize}px`, height: `${dotSize}px` }"
+ ></div>
+ </div>
+ <img :src="`/httpImage/${snapshot_url}`" alt />
+ <div
+ class="popBox"
+ v-show="isShowPop"
+ :style="`top:${curLabel.y + 22}px;left:${curLabel.x}px`"
+ >
+ <div class="title">鏍囨敞淇℃伅</div>
+ <div class="details">
+ <div class="detail-item">
+ <div class="left">
+ <label for>骞抽潰鍧愭爣X:</label>
+ <span class="fix-width">{{curLabel.x}}</span>
+ <i>px</i>
+ </div>
+ <span class="devide"></span>
+ <div class="right">
+ <label for>瀹為檯鍧愭爣X:</label>
+ <el-input type="text" size="mini" style="width:90px" v-model="curLabel.posX"></el-input>
+ </div>
+ </div>
+ <div class="detail-item">
+ <div class="left">
+ <label for>骞抽潰鍧愭爣Y:</label>
+ <span class="fix-width">{{curLabel.y}}</span>
+ <i>px</i>
+ </div>
+ <span class="devide"></span>
+ <div class="right">
+ <label for>瀹為檯鍧愭爣Y:</label>
+ <el-input type="text" size="mini" style="width:90px" v-model="curLabel.posY"></el-input>
+ </div>
+ </div>
+ <div class="btns">
+ <el-button size="mini" type="danger" @click="deleteLabel">鍒犻櫎</el-button>
+ <el-button size="mini" type="primary" @click="cancle">鍙栨秷</el-button>
+ <el-button size="mini" type="success" @click="submitInfo">纭畾</el-button>
+ </div>
+ </div>
+ </div>
+ </div>
+ </div>
<div class="tool-bar">
<div>
<!-- <input type="color" ref="colorPicker" v-model="color"> -->
@@ -9,64 +69,6 @@
<div style="width:250px;">
<label for>绗旇Е:</label>
<el-slider v-model="dotSize" :min="1" :max="20"></el-slider>
- </div>
- </div>
- <div class="action-bar">
- <el-button
- class="drawboard-trigger"
- size="small"
- @click="isEdit=!isEdit"
- :icon="isEdit?'el-icon-lock':'el-icon-edit'"
- >{{isEdit?'閿佸畾':'缂栬緫'}}</el-button>
- </div>
- <div class="drawboard">
- <div class="mask" :class="{'edit-status-mask':isEdit}" ref="editBoard">
- <div
- class="label"
- @click="editLabel(item)"
- v-for="(item,index) in labels"
- :key="index"
- :style="{left:`${item.x}px`, top:`${item.y}px`, backgroundColor: colorPick, width: `${dotSize}px`, height: `${dotSize}px` }"
- ></div>
- </div>
- <img :src="`/httpImage/${snapshot_url}`" alt />
- <div
- class="popBox"
- v-show="isShowPop"
- :style="`top:${curLabel.y + 22}px;left:${curLabel.x}px`"
- >
- <div class="title">鏍囨敞淇℃伅</div>
- <div class="details">
- <div class="detail-item">
- <div class="left">
- <label for>骞抽潰鍧愭爣X:</label>
- <span class="fix-width">{{curLabel.x}}</span>
- <i>px</i>
- </div>
- <span class="devide"></span>
- <div class="right">
- <label for>瀹為檯鍧愭爣X:</label>
- <el-input type="text" size="mini" style="width:90px" v-model="curLabel.posX"></el-input>
- </div>
- </div>
- <div class="detail-item">
- <div class="left">
- <label for>骞抽潰鍧愭爣Y:</label>
- <span class="fix-width">{{curLabel.y}}</span>
- <i>px</i>
- </div>
- <span class="devide"></span>
- <div class="right">
- <label for>瀹為檯鍧愭爣Y:</label>
- <el-input type="text" size="mini" style="width:90px" v-model="curLabel.posY"></el-input>
- </div>
- </div>
- <div class="btns">
- <el-button size="mini" type="danger" @click="deleteLabel">鍒犻櫎</el-button>
- <el-button size="mini" type="primary" @click="cancle">鍙栨秷</el-button>
- <el-button size="mini" type="success" @click="submitInfo">纭畾</el-button>
- </div>
- </div>
</div>
</div>
</div>
@@ -99,7 +101,7 @@
computed: {
},
- mounted() {
+ mounted () {
this.getAllCameraData();
setTimeout(() => {
let mockData = [{ id: 'a1', x: 15, y: 33, posX: 150, posY: 330 }, { id: 'b2', x: 56, y: 87, posX: 560, posY: 870 }];
@@ -108,13 +110,14 @@
},
watch: {
'TreeDataPool.selectedNode': {
- handler(n, o) {
+ handler (n, o) {
+ debugger
let curCamera = this.cameraData.find(item => item.id == n.id);
this.snapshot_url = curCamera.snapshot_url;
},
deep: true
},
- isEdit(n, o) {
+ isEdit (n, o) {
if (n) {
this.$refs['editBoard'].addEventListener('click', this.bindListen);
} else {
@@ -123,19 +126,20 @@
}
},
methods: {
- getAllCameraData() {
+ getAllCameraData () {
getCamerasByServer().then(res => {
if (res.success) {
+ debugger
this.cameraData = res.data;
}
}).catch(e => {
console.log(e)
})
},
- bindListen(e) {
+ bindListen (e) {
this.newLabel(e);
},
- newLabel(e) {
+ newLabel (e) {
console.log('鐐瑰嚮浜嗙敾鏉�')
if (this.isShowPop) return;
//鑾峰彇榧犳爣鐩稿浜庣敾鏉跨殑瀹氫綅
@@ -152,19 +156,20 @@
this.isShowPop = true;
this.isNewLabel = true;
},
- editLabel(label) {
+ editLabel (label) {
+ debugger
if (!this.isEdit) return;
this.isShowPop = true;
this.curLabel = JSON.parse(JSON.stringify(label));
},
- cancle() {
+ cancle () {
this.isShowPop = false;
//濡傛灉鏄湭淇濆瓨杩囩殑label鐩存帴鍒犻櫎(鏈繚瀛樼殑灏辨槸labels鏁扮粍涓渶鍚庝竴涓�)
if (!this.curLabel.id) {
this.labels.pop();
}
},
- deleteLabel() {
+ deleteLabel () {
if (this.curLabel.id) {
//璇锋眰鍚庡彴鍒犻櫎
} else {
@@ -172,7 +177,7 @@
this.isShowPop = false;
}
},
- submitInfo() {
+ submitInfo () {
}
}
@@ -183,9 +188,13 @@
.right-side {
height: 100%;
background: #d2dcea;
+ .figure{
+ float: left;
+ }
.tool-bar {
- width: 100%;
- height: 60px;
+ float: right;
+ width: 40px;
+ height: 100%;
padding: 10px 20px;
box-sizing: border-box;
background: rgb(250, 250, 250);
--
Gitblit v1.8.0