hanbaoshan
2020-10-27 1e84774c0c0752c61e60592e7f7fc1c0d25a1dab
首页加入算法
6个文件已修改
174 ■■■■ 已修改文件
src/components/subComponents/FileUpload/btn.vue 7 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/components/subComponents/FileUpload/index.vue 8 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/components/subComponents/FileUpload/uploader.vue 13 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/pages/ai/index/App.vue 16 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/pages/desktop/index/components/ToolsEntry.vue 95 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/pages/labelMark/components/RightSide.vue 35 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
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
    }
src/components/subComponents/FileUpload/index.vue
@@ -81,11 +81,11 @@
    },
    attrs: {
      type: Object,
      // default () {
      //   return {
      default () {
        return {
      //   }
      // }
        }
      }
    }
  },
  data() {
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
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({
src/pages/desktop/index/components/ToolsEntry.vue
@@ -1,8 +1,32 @@
<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)">
      <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 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" />
@@ -10,7 +34,21 @@
            <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>
        </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() {
    return {
      publicPath: process.env.BASE_URL,
      loading: true,
      localApps: []
      //carousels: [],
      localApps: [],
      installedSdk: [],
      sdkList: [
        {
          src: '',
          title: '个体静止'
        },
        {
          src: '',
          title: '人员跟踪'
        }
      ]
    }
  },
  computed: {
    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() {
    this.getAllSdk();
    //this.carousels =
    window.addEventListener('message', e => {
      if (e.data && e.data.msg) {
        let msg = e.data.msg;
@@ -53,6 +114,27 @@
  },
  methods: {
    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);
@@ -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;
src/pages/labelMark/components/RightSide.vue
@@ -1,16 +1,6 @@
<template>
  <div class="right-side">
    <div class="tool-bar">
      <div>
        <!-- <input type="color" ref="colorPicker" v-model="color"> -->
        <label for>拾色器:</label>
        <el-color-picker v-model="colorPick" show-alpha size="mini"></el-color-picker>
      </div>
      <div style="width:250px;">
        <label for>笔触:</label>
        <el-slider v-model="dotSize" :min="1" :max="20"></el-slider>
      </div>
    </div>
    <div class="figure">
    <div class="action-bar">
      <el-button
        class="drawboard-trigger"
@@ -70,6 +60,18 @@
      </div>
    </div>
  </div>
    <div class="tool-bar">
      <div>
        <!-- <input type="color" ref="colorPicker" v-model="color"> -->
        <label for>拾色器:</label>
        <el-color-picker v-model="colorPick" show-alpha size="mini"></el-color-picker>
      </div>
      <div style="width:250px;">
        <label for>笔触:</label>
        <el-slider v-model="dotSize" :min="1" :max="20"></el-slider>
      </div>
    </div>
  </div>
</template>
<script>
@@ -109,6 +111,7 @@
  watch: {
    'TreeDataPool.selectedNode': {
      handler(n, o) {
        debugger
        let curCamera = this.cameraData.find(item => item.id == n.id);
        this.snapshot_url = curCamera.snapshot_url;
      },
@@ -126,6 +129,7 @@
    getAllCameraData() {
      getCamerasByServer().then(res => {
        if (res.success) {
          debugger
          this.cameraData = res.data;
        }
      }).catch(e => {
@@ -153,6 +157,7 @@
      this.isNewLabel = true;
    },
    editLabel(label) {
      debugger
      if (!this.isEdit) return;
      this.isShowPop = true;
      this.curLabel = JSON.parse(JSON.stringify(label));
@@ -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);