From b1740c80205d9584738b1150f4122784c70bbe57 Mon Sep 17 00:00:00 2001
From: jiangping <jp@doumee.com>
Date: 星期二, 08 四月 2025 14:55:55 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'
---
 screen/src/views/SecurityControl.vue |  234 ++++++++++++++--------------------------------------------
 1 files changed, 57 insertions(+), 177 deletions(-)
diff --git a/screen/src/views/SecurityControl.vue b/screen/src/views/SecurityControl.vue
index 00f1180..48985ac 100644
--- a/screen/src/views/SecurityControl.vue
+++ b/screen/src/views/SecurityControl.vue
@@ -4,7 +4,7 @@
       <img src="@/assets/images/SecurityControl/bg@2x.png" class="main_bg" alt="" />
       <div class="main_header">
         <img src="@/assets/images/maintitle.gif" class="main_header_bg" alt="" />
-        <div class="title">瀹夋嘲鏅烘収鐗╂祦鍥尯-瀹夐槻鏅鸿兘鐩戞祴</div>
+        <div class="title">瀹夋嘲鏅烘収鐗╂祦鍥尯-鏅鸿兘瀹夐槻鐩戞祴</div>
         <div class="time_wrap">
           <span class="date">{{ date }}</span>
           <span class="week">{{ week }}</span>
@@ -111,7 +111,9 @@
           <div v-show="showJk" class="jiankong">
             <img class="jk_bg" src="@/assets/images/SecurityControl/jiankong_bg@2x.png" alt="">
             <div class="content">
-              <div class="player_bg" style="width: 100%;height: 100%;" id="playWnd"> </div>
+              <Video v-if="showJk && activeMenu && activeMenu.indexCode" :href="data.videoPluginUrl"
+                :indexCode="activeMenu.indexCode" />
+              <!-- <div class="player_bg" style="width: 100%;height: 100%;" id="playWnd"> </div> -->
             </div>
             <div class="right_wrap">
               <div class="menus">
@@ -162,7 +164,7 @@
                   <img src="@/assets/images/SecurityControl/title_short@2x.png" class="bg" alt="">
                 </div>
                 <div class="num_wrap">
-                  <div class="num">{{ data.internalCarTotal }}</div>
+                  <div class="num">{{ data.inParkCarTotal || 0 }}</div>
                   <img src="@/assets/images/SecurityControl/anfang_ic_data@2x.png" class="bg" alt="">
                 </div>
               </div>
@@ -218,8 +220,8 @@
                 <div class="content">
                   <div class="name">闀挎湡鐩稿叧鏂�</div>
                   <div class="num today"><span>{{ data.relatedTotal || 0
-                      }}</span> | {{ data.inParkTotal ? ((data.relatedTotal / data.inParkTotal) * 100).toFixed(1) : 0
-                    }}%</div>
+                  }}</span> | {{ data.inParkTotal ? ((data.relatedTotal / data.inParkTotal) * 100).toFixed(1) : 0
+                      }}%</div>
                 </div>
               </div>
               <div class="item">
@@ -247,7 +249,7 @@
               </div>
               <div class="spacing"></div>
               <div class="item">
-                <div class="name">宸茬櫥璁�</div>
+                <div class="name">宸茶闂�</div>
                 <div class="num_wrap">
                   <span class="num">{{ data4.registerVisitNum }}</span>
                   <span>浜�</span>
@@ -310,6 +312,7 @@
           </div>
         </div> -->
         <div class="safe_warning">
+          <Loading v-if="loading1" />
           <div class="com_header">
             <div class="title">
               <img src="@/assets/images/ic_title@2x.png" class="icon" alt="" />
@@ -372,7 +375,6 @@
                 </div>
               </div>
             </div>
-
           </div>
 
         </div>
@@ -384,7 +386,7 @@
             </div>
             <img src="@/assets/images/task/title@2x.png" class="bg" alt="" />
           </div>
-          <div class="monitoring" @click="showJk = !showJk">
+          <div class="monitoring" @click="changeMon">
             <img src="@/assets/images/SecurityControl/ic_jiankong@2x.png" class="icon" alt="">
             <div>鐩戞帶鍒楄〃</div>
             <img v-if="showJk" src="@/assets/images/SecurityControl/jiankong_ic_close@2x.png" class="top" alt="">
@@ -421,7 +423,7 @@
               </div>
               <div class="list two-swiper">
                 <div class="swiper-wrapper">
-                  <template v-for="item, i in dataList2">
+                  <template v-for="item, i in dataList2.filter(i => i.totalNum > 0)">
                     <div class="item two-swiper-slide swiper-slide">
                       <div class="line">
                         <div class="driver">{{ item.deviceType }}</div>
@@ -451,7 +453,7 @@
             <div class="line header">
               <div>濮撳悕</div>
               <div class="dept">鎷滆閮ㄩ棬</div>
-              <div class="dept">瓒呮椂鏃堕暱</div>
+              <div class="time">瓒呮椂鏃堕暱</div>
             </div>
             <div v-if="dataList3.length > 0" class="three-swiper list">
               <div class="swiper-wrapper">
@@ -459,7 +461,7 @@
                   <div class="line">
                     <div>{{ item.name }}</div>
                     <div class="dept">{{ item.companyName }}</div>
-                    <div class="dept">{{ item.timeOutMinuteT }}</div>
+                    <div class="time">{{ item.timeOutMinuteT }}</div>
                   </div>
                   <div class="separate"></div>
                 </div>
@@ -476,7 +478,7 @@
 </template>
 
 <script setup>
-import { ref, onMounted } from 'vue'
+import { ref, onMounted, nextTick } from 'vue'
 import VScaleScreen from 'v-scale-screen'
 import Percent from '@/components/percent.vue'
 import dayjs from 'dayjs'
@@ -485,6 +487,8 @@
 import * as echarts from 'echarts'
 import 'swiper/css/swiper.min.css'
 import Swiper from 'swiper'
+import Video from './videoUrl/Video.vue'
+import Loading from '@/components/Loading.vue'
 import {
   getEnergyCenterData,
   afgetCarmeraPreviemUrl,
@@ -507,138 +511,6 @@
   time.value = dayjs().format('HH:mm:ss')
 
 }, 1000)
-
-
-const oWebControl = ref(null)
-const initCount = ref()
-const pubKey = ref('')
-const initPlugin = () => {
-  oWebControl.value = new WebControl({
-    szPluginContainer: "playWnd",                       // 鎸囧畾瀹瑰櫒id
-    iServicePortStart: 15900,                           // 鎸囧畾璧锋绔彛鍙凤紝寤鸿浣跨敤璇ュ��
-    iServicePortEnd: 15900,
-    szClassId: "23BF3B0A-2C56-4D97-9C03-0CB103AA8F11",   // 鐢ㄤ簬IE10浣跨敤ActiveX鐨刢lsid
-    cbConnectSuccess: function () {
-      // 鍒涘缓WebControl瀹炰緥鎴愬姛
-      oWebControl.value.JS_StartService("window", {         // WebControl瀹炰緥鍒涘缓鎴愬姛鍚庨渶瑕佸惎鍔ㄦ湇鍔�
-        dllPath: "./VideoPluginConnect.dll"         // 鍊�"./VideoPluginConnect.dll"鍐欐
-      }).then(function () {
-        oWebControl.value.JS_SetWindowControlCallback({   // 璁剧疆娑堟伅鍥炶皟
-          cbIntegrationCallBack: cbIntegrationCallBack
-        })// 鍚姩鎻掍欢鏈嶅姟鎴愬姛
-        // oWebControl.value.JS_CreateWnd("playWnd", that.boxWidth, that.boxHeight).then(function () { //JS_CreateWnd鍒涘缓瑙嗛鎾斁绐楀彛锛屽楂樺彲璁惧畾锛宐oxWidth, boxHeight瀹瑰櫒
-        oWebControl.value.JS_CreateWnd("playWnd").then(function () { //JS_CreateWnd鍒涘缓瑙嗛鎾斁绐楀彛锛屽楂樺彲璁惧畾锛宐oxWidth, boxHeight瀹瑰櫒
-          init()  // 鍒涘缓鎾斁瀹炰緥鎴愬姛鍚庡垵濮嬪寲
-        })
-      }, function () { // 鍚姩鎻掍欢鏈嶅姟澶辫触
-      })
-    },
-    cbConnectError: function () { // 鍒涘缓WebControl瀹炰緥澶辫触
-      oWebControl.value = null
-      $("#playWnd").html("鎻掍欢鏈惎鍔紝姝e湪灏濊瘯鍚姩锛岃绋嶅��...")
-      WebControl.JS_WakeUp("VideoWebPlugin://") // 绋嬪簭鏈惎鍔ㄦ椂鎵цerror鍑芥暟锛岄噰鐢╳akeup鏉ュ惎鍔ㄧ▼搴�
-      initCount.value++
-      if (initCount.value < 3) {
-        setTimeout(function () {
-          initPlugin()
-        }, 3000)
-      } else {
-        $("#playWnd").html("鎻掍欢鍚姩澶辫触锛岃妫�鏌ユ彃浠舵槸鍚﹀畨瑁咃紒鎴栭噸鏂颁笅杞� <a href='./videoUrl/VideoWebPlugin.exe' target='_blank'>涓嬭浇a<a>")
-      }
-    },
-    cbConnectClose: function (bNormalClose) {
-      // 寮傚父鏂紑锛歜NormalClose = false
-      // JS_Disconnect姝e父鏂紑锛歜NormalClose = true
-      oWebControl.value = null
-      $("#playWnd").html("鎻掍欢鏈惎鍔紝姝e湪灏濊瘯鍚姩锛岃绋嶅��...")
-      WebControl.JS_WakeUp("VideoWebPlugin://")
-      initCount.value++
-      if (initCount.value < 3) {
-        setTimeout(function () {
-          initPlugin()
-        }, 3000)
-      } else {
-        $("#playWnd").html("鎻掍欢鍚姩澶辫触锛岃妫�鏌ユ彃浠舵槸鍚﹀畨瑁咃紒鎴栭噸鏂颁笅杞� <a href='https://img0.baidu.com/it/u=3867022436,608124672&fm=253&fmt=auto&app=138&f=JPEG?w=800&h=1422' target='_blank'>涓嬭浇b<a>")
-      }
-    }
-  })
-}
-function fileDown (){
-  window.open('./videoUrl/VideoWebPlugin.exe')
-}
-// 娑堟伅鍥炶皟
-const cbIntegrationCallBack = (oData) => {
-  let response = oData.responseMsg
-  // response.type=1  閫変腑绐楀彛娑堟伅  type=2 鎾斁娑堟伅
-}
-// 鐩戞帶
-
-
-
-
-// 鍒濆鍖�
-const init = () => {
-  getPubKey(function () {
-    ////////////////////////////////// 璇疯嚜琛屼慨鏀逛互涓嬪彉閲忓��   ////////////////////////////////////
-    let appkey = "28631222"                           //缁煎悎瀹夐槻绠$悊骞冲彴鎻愪緵鐨刟ppkey锛屽繀濉�
-    let secret = setEncrypt("vRfUmiilCd4EpLmtZKoT")   //缁煎悎瀹夐槻绠$悊骞冲彴鎻愪緵鐨剆ecret锛屽繀濉�
-    let ip = "112.48.8.98"                           //缁煎悎瀹夐槻绠$悊骞冲彴IP鍦板潃锛屽繀濉�
-    let playMode = 0                                  //鍒濆鎾斁妯″紡锛�0-棰勮(瀹炴椂娴�)锛�1-鍥炴斁(瑙嗛)
-    let port = 10443                                    //缁煎悎瀹夐槻绠$悊骞冲彴绔彛锛岃嫢鍚敤HTTPS鍗忚锛岄粯璁�443
-    let snapDir = "D:\\SnapDir"                       //鎶撳浘瀛樺偍璺緞
-    let videoDir = "D:\\VideoDir"                     //绱ф�ュ綍鍍忔垨褰曞儚鍓緫瀛樺偍璺緞
-    let layout = "4x1"                                //playMode鎸囧畾妯″紡鐨勫竷灞�
-    let enableHTTPS = 1                               //鏄惁鍚敤HTTPS鍗忚涓庣患鍚堝畨闃茬鐞嗗钩鍙颁氦浜掞紝杩欓噷鎬绘槸濉�1
-    let encryptedFields = 'secret'                    //鍔犲瘑瀛楁锛岄粯璁ゅ姞瀵嗛鍩熶负secret
-    let showToolbar = 1                               //鏄惁鏄剧ず宸ュ叿鏍忥紝0-涓嶆樉绀猴紝闈�0-鏄剧ず
-    let showSmart = 1                                 //鏄惁鏄剧ず鏅鸿兘淇℃伅锛堝閰嶇疆绉诲姩渚︽祴鍚庣敾闈笂鐨勭嚎妗嗭級锛�0-涓嶆樉绀猴紝闈�0-鏄剧ず
-    let buttonIDs = "0,16,256,257,258,259,260,513,514,515,516,517,768"  //鑷畾涔夊伐鍏锋潯鎸夐挳
-    oWebControl.value.JS_RequestInterface({
-      funcName: "init",
-      argument: JSON.stringify({
-        appkey: appkey,                            //API缃戝叧鎻愪緵鐨刟ppkey
-        secret: secret,                            //API缃戝叧鎻愪緵鐨剆ecret
-        ip: ip,                                    //API缃戝叧IP鍦板潃
-        playMode: playMode,                        //鎾斁妯″紡锛堝喅瀹氭樉绀洪瑙堣繕鏄洖鏀剧晫闈級
-        port: port,                                //绔彛
-        snapDir: snapDir,                          //鎶撳浘瀛樺偍璺緞
-        videoDir: videoDir,                        //绱ф�ュ綍鍍忔垨褰曞儚鍓緫瀛樺偍璺緞
-        layout: layout,                            //甯冨眬
-        enableHTTPS: enableHTTPS,                  //鏄惁鍚敤HTTPS鍗忚
-        encryptedFields: encryptedFields,          //鍔犲瘑瀛楁
-        showToolbar: showToolbar,                  //鏄惁鏄剧ず宸ュ叿鏍�
-        showSmart: showSmart,                      //鏄惁鏄剧ず鏅鸿兘淇℃伅
-        buttonIDs: buttonIDs                       //鑷畾涔夊伐鍏锋潯鎸夐挳
-      })
-    }).then(function (oData) {
-      // oWebControl.value.JS_Resize(that.boxWidth, that.boxHeight)  // 鍒濆鍖栧悗resize涓�娆★紝瑙勯伩firefox涓嬮娆℃樉绀虹獥鍙e悗鎻掍欢绐楀彛鏈笌DIV绐楀彛閲嶅悎闂
-    })
-  })
-}
-
-// 鑾峰彇鍏挜
-function getPubKey(callback) {
-  oWebControl.value.JS_RequestInterface({
-    funcName: 'getRSAPubKey',
-    argument: JSON.stringify({
-      keyLength: 1024,
-    }),
-  }).then((oData) => {
-    if (oData.responseMsg.data) {
-      pubKey.value = oData.responseMsg.data
-      callback()
-    }
-  })
-}
-
-// RSA鍔犲瘑
-function setEncrypt(value) {
-  let that = this
-  let encrypt = new JSEncrypt()
-  encrypt.setPublicKey(pubKey.value)
-  return encrypt.encrypt(value)
-}
-
 
 const arr = ['#68e2e3', '#50afd3', '#377cdb', '#d5ae3a']
 const initEnergy = () => {
@@ -740,7 +612,7 @@
   })
 }
 
-const colors = ['#FEAF01', '#01ABFE', '#51F9E4']
+const colors = ['#01ABFE', '#FEAF01', '#51F9E4']
 const initEchart2 = () => {
   const myChart = echarts.init(document.getElementById('echart2'))
   const option = {
@@ -803,10 +675,20 @@
     }]),
   ]
   const data = []
-  data.push({ name: '寰呰闂�', value: data4.value.waitVisitNum, rate: (data4.value.waitVisitNum / data4.value.total).toFixed(1) })
-  data.push({ name: '宸茬櫥璁�', value: data4.value.registerVisitNum, rate: (data4.value.registerVisitNum / data4.value.total).toFixed(1) })
-  data.push({ name: '宸茬寮�', value: data4.value.levelNum, rate: (data4.value.levelNum / data4.value.total).toFixed(1) })
-  data.push({ name: '婊炵暀', value: data4.value.retentionNum, rate: (data4.value.retentionNum / data4.value.total).toFixed(1) })
+  if (data4.value.total) {
+    data.push({ name: '寰呰闂�', value: data4.value.waitVisitNum, rate: (data4.value.waitVisitNum / data4.value.total).toFixed(3) })
+    data.push({ name: '宸茶闂�', value: data4.value.registerVisitNum, rate: (data4.value.registerVisitNum / data4.value.total).toFixed(3) })
+    data.push({ name: '宸茬寮�', value: data4.value.levelNum, rate: (data4.value.levelNum / data4.value.total).toFixed(3) })
+    data.push({ name: '婊炵暀', value: data4.value.retentionNum, rate: (data4.value.retentionNum / data4.value.total).toFixed(3) })
+  } else {
+    data.push({ name: '寰呰闂�', value: data4.value.waitVisitNum, rate: 0 })
+    data.push({ name: '宸茶闂�', value: data4.value.registerVisitNum, rate: 0 })
+    data.push({ name: '宸茬寮�', value: data4.value.levelNum, rate: 0 })
+    data.push({ name: '婊炵暀', value: data4.value.retentionNum, rate: 0 })
+  }
+  data.sort((a, b) => (b.value - a.value))
+  // console.log('data', data);
+
   const option = {
     color: colors,
     tooltip: {
@@ -872,7 +754,7 @@
           position: 'outside',
           formatter: (params) => {
             const index = params.dataIndex
-            return `{color${index}|${params.data.name} ${params.data.rate}%}`
+            return `{color${index}|${params.data.name} ${(params.data.rate * 100).toFixed(1)}%}`
             // return `<div>${params.data.name}</div>`
           },
           rich: {
@@ -946,6 +828,8 @@
         }
         return item
       })
+      console.log('dataList2', dataList2.value)
+
       data2.value = total
       if (online >= outline) {
         temp.push({ name: '鍦ㄧ嚎', value: online, rate: ((online / (online + outline)) * 100).toFixed(1) })
@@ -969,6 +853,7 @@
     data4.value = res.data || {}
     let obj = data4.value
     data4.value.total = obj.levelNum + obj.retentionNum + obj.registerVisitNum + obj.waitVisitNum
+
     const result = res.data?.visitRetentionDataList || []
     dataList3.value = result.map(i => {
       if (i.timeOutMinute) {
@@ -979,7 +864,7 @@
       } else if (i.timeOutMinute > 60) {
         i.timeOutMinuteT = dayjs.duration(i.timeOutMinute * 60 * 1000).format('H鏃秏鍒�')
       } else {
-        i.timeOutMinuteT = item.timeOutMinuteT + '鍒�'
+        i.timeOutMinuteT = i.timeOutMinute + '鍒�'
       }
 
       return i
@@ -988,11 +873,14 @@
   })
 }
 
+const loading1 = ref(false)
 const warningTab = ref('0')
 const warningNum = ref(0)
 const warningList = ref([])
 const getWarning = () => {
+  loading1.value = true
   afwarningEventData({ type: warningTab.value }).then(res => {
+    loading1.value = false
     if (!res.data) return
     const result = res.data.list || []
     warningNum.value = res.data.total
@@ -1015,6 +903,8 @@
     })
     warningList.value = temp
     // console.log('temp', warningList.value);
+  }, () => {
+    loading1.value = false
   })
 }
 const tasClick = (val) => {
@@ -1038,6 +928,13 @@
     data5.value = result.filter(item => item.carmeraList && item.carmeraList.length > 0)
   })
 }
+const changeMon = () => {
+  showJk.value = !showJk.value
+  if (!showJk.value) {
+    activeJkIndex.value = -1
+    activeMenu.value = {}
+  }
+}
 const menuClick = (val) => {
   if (val == activeJkIndex.value) {
     activeJkIndex.value = -1
@@ -1046,27 +943,9 @@
   }
 }
 const menuItemClick = (val) => {
-  initPlugin()
   activeMenu.value = val
-  oWebControl.value.JS_RequestInterface({
-    funcName: "startPreview",
-    argument: JSON.stringify({
-      cameraIndexCode: val.indexCode,            //鐩戞帶鐐圭紪鍙�
-      streamMode: 0,                   //涓诲瓙鐮佹祦鏍囪瘑锛�0-涓荤爜娴侊紝1-瀛愮爜娴�
-      transMode: 1,                    //浼犺緭鍗忚锛�0-UDP锛�1-TCP
-      gpuMode: 0,                      //鏄惁鍚敤GPU纭В锛�0-涓嶅惎鐢紝1-鍚敤
-      wndId: -1                         //鎾斁绐楀彛搴忓彿锛堝湪2x2浠ヤ笂甯冨眬涓嬪彲鎸囧畾鎾斁绐楀彛锛�
-    })
-  }).then((oData) => {
-    if (oData.responseMsg.code === 1) {
-      console.log('success')
-    }
-  })
-  // afgetCarmeraPreviemUrl({ indexCode: val.indexCode }).then(res => {
-  //   activeVideo.value = res.data
-  // })
-}
 
+}
 const autoplayFlag = (list = [], leng = 4, time = 2000) => {
   if (list.length > leng) {
     return { delay: time, disableOnInteraction: false }
@@ -1089,7 +968,7 @@
     initialSlide: 0,
     direction: 'vertical', //绔栫洿鏂瑰悜
     slidesPerView: 3,
-    autoplay: autoplayFlag(dataList2.value, 3, 4000),
+    autoplay: autoplayFlag(dataList2.value.filter(i => i.totalNum > 0), 3, 4000),
     observer: true, //淇敼swiper鑷繁鎴栧瓙鍏冪礌鏃讹紝鑷姩鍒濆鍖杝wiper
   })
 }
@@ -1114,7 +993,6 @@
   getData3()
   getData5()
   getWarning()
-
 
   setInterval(() => {
     getData1()
@@ -1723,6 +1601,7 @@
   .safe_warning {
     width: 786px;
     margin-right: 20px;
+    position: relative;
 
     /* one-swiper */
     .one_swiper_wrap {
@@ -1830,7 +1709,8 @@
         display: flex;
         justify-content: center;
         align-items: center;
-        padding: 16px 24px;
+        padding-top: 16px;
+        padding-left: 24px;
 
         .echart_wrap {
           position: relative;
@@ -1866,7 +1746,7 @@
         }
 
         .list {
-          margin-left: 36px;
+          margin-left: 32px;
           flex: 1;
           display: flex;
           flex-direction: column;
@@ -2054,11 +1934,11 @@
     }
 
     .dept {
-      flex: 5;
+      flex: 8;
     }
 
     .time {
-      flex: 4;
+      flex: 5;
     }
   }
 
@@ -2151,4 +2031,4 @@
   object-fit: cover;
   z-index: -1;
 }
-</style>
\ No newline at end of file
+</style>
--
Gitblit v1.9.3