From b6d0ad0e7e57a77d1983009494b09aa1da5fbfc4 Mon Sep 17 00:00:00 2001
From: liukangdong <898885815@qq.com>
Date: 星期四, 12 十二月 2024 16:03:26 +0800
Subject: [PATCH] ll

---
 screen/src/views/SecurityControl.vue |  423 ++++++++++++++++++++++++++++++++++++++--------------
 1 files changed, 310 insertions(+), 113 deletions(-)

diff --git a/screen/src/views/SecurityControl.vue b/screen/src/views/SecurityControl.vue
index 282403c..00f1180 100644
--- a/screen/src/views/SecurityControl.vue
+++ b/screen/src/views/SecurityControl.vue
@@ -3,7 +3,7 @@
     <div class="main_app">
       <img src="@/assets/images/SecurityControl/bg@2x.png" class="main_bg" alt="" />
       <div class="main_header">
-        <img src="@/assets/images/maintitle@2x.png" class="main_header_bg" alt="" />
+        <img src="@/assets/images/maintitle.gif" class="main_header_bg" alt="" />
         <div class="title">瀹夋嘲鏅烘収鐗╂祦鍥尯-瀹夐槻鏅鸿兘鐩戞祴</div>
         <div class="time_wrap">
           <span class="date">{{ date }}</span>
@@ -19,7 +19,7 @@
                 <img src="@/assets/images/ic_title@2x.png" class="icon" alt="" />
                 <div>瀹炴椂鍥尯杞﹁締</div>
               </div>
-              <img src="@/assets/images/title@2x.png" class="bg" alt="" />
+              <img src="@/assets/images/task/title@2x.png" class="bg" alt="" />
             </div>
             <div class="second_title">
               <div class="title">
@@ -43,7 +43,7 @@
               <div class="rate">
                 <div class="la">
                   <span>杞︿綅浣跨敤鐜�</span>
-                  <span v-if="data.inParkCarTotal && data.parkingLotTotal" class="num">{{ data.parkingUseRate }}%</span>
+                  <span class="num">{{ data.parkingUseRate }}%</span>
                 </div>
                 <div class="val">
                   <Percent :rate="data.parkingUseRate" />
@@ -88,7 +88,8 @@
             <div class="car_static">
               <div class="echart_wrap">
                 <div class="pie_text">
-                  <div class="fs30"><strong v-if="data.visitJobCarTotal || data.visitJobCarTotal == 0">{{ data.internalJobCarTotal +
+                  <div class="fs30"><strong v-if="data.visitJobCarTotal || data.visitJobCarTotal == 0">{{
+                    data.internalJobCarTotal +
                     data.relatedJobCarTotal + data.visitJobCarTotal }}</strong></div>
                   <div>璐ц溅</div>
                 </div>
@@ -107,16 +108,17 @@
           </div>
         </div>
         <div class="center_box">
-          <div v-if="showJk" class="jiankong">
+          <div v-show="showJk" class="jiankong">
             <img class="jk_bg" src="@/assets/images/SecurityControl/jiankong_bg@2x.png" alt="">
             <div class="content">
-              <video :src="activeVideo" class="video"></video>
+              <div class="player_bg" style="width: 100%;height: 100%;" id="playWnd"> </div>
             </div>
             <div class="right_wrap">
               <div class="menus">
                 <div class="search_wrap">
                   <img class="search" src="@/assets/images/SecurityControl/ic_search@2x.png" alt="">
-                  <input v-model="dataValue5" @blur="getData5" @keyup.enter="getData5" class="input" type="text" placeholder="鎼滅储鐩戞帶鍚嶇О">
+                  <input v-model="dataValue5" @blur="getData5" @keyup.enter="getData5" class="input" type="text"
+                    placeholder="鎼滅储鐩戞帶鍚嶇О">
                 </div>
                 <div class="menu_wrap">
                   <div class="menu" v-for="menu, i in data5">
@@ -142,7 +144,7 @@
             </div>
 
           </div>
-          <div v-else class="center_box_one">
+          <div v-show="!showJk" class="center_box_one">
             <div class="list">
               <div class="item">
                 <div class="name_wrap">
@@ -194,7 +196,7 @@
                 <img src="@/assets/images/ic_title@2x.png" class="icon" alt="" />
                 <div>鍦ㄥ洯浜哄憳鍒嗘瀽</div>
               </div>
-              <img src="@/assets/images/title@2x.png" class="bg" alt="" />
+              <img src="@/assets/images/task/title@2x.png" class="bg" alt="" />
             </div>
             <div class="second_title">
               <div class="title">
@@ -285,7 +287,7 @@
               <img src="@/assets/images/ic_title@2x.png" class="icon" alt="" />
               <div>褰撳墠杞﹁締婊炵暀棰勮</div>
             </div>
-            <img src="@/assets/images/title@2x.png" class="bg" alt="" />
+            <img src="@/assets/images/task/title@2x.png" class="bg" alt="" />
           </div>
           <div class="table">
             <div class="line header">
@@ -320,33 +322,59 @@
               <div class="separate"></div>
               <div class="tab" :class="{ active: warningTab == '2' }" @click="tasClick('2')">琛屼负鍛婅</div>
             </div>
-            <img src="@/assets/images/title@2x.png" class="bg" alt="" />
+            <img src="@/assets/images/task/title@2x.png" class="bg" alt="" />
           </div>
-          <div class="list one-swiper">
-            <div class="swiper-wrapper">
-              <div class="one-swiper-slide swiper-slide item" v-for="item in warningList">
-                <div class="item_wrap">
-                  <img :src="item.img" class="avatar" alt="">
-                  <div class="content">
-                    <div class="header">
-                      <div class="name">{{ item.title }}</div>
-                      <div class="have_time">宸茬粡鍙戠敓{{ item.haveTime }}</div>
-                    </div>
-                    <div class="wrap">
-                      <div class="line addr">
-                        <img class="icon" src="@/assets/images/SecurityControl/xiaofang_ic_weizhi@2x.png" alt="">
-                        <span>{{ item.addr }}</span>
+          <div class="one_swiper_wrap">
+            <div class="list one-swiper">
+              <div class="swiper-wrapper">
+                <div class="one-swiper-slide swiper-slide item" v-for="item in warningList">
+                  <div class="item_wrap">
+                    <img :src="item.img" class="avatar" alt="">
+                    <div class="content">
+                      <div class="header">
+                        <div class="name">{{ item.title }}</div>
+                        <div class="have_time">宸茬粡鍙戠敓{{ item.haveTime }}</div>
                       </div>
-                      <div class="line time">
-                        <img class="icon" src="@/assets/images/SecurityControl/clock.png" alt="">
-                        <span>{{ item.createDate }}</span>
+                      <div class="wrap">
+                        <div class="line addr">
+                          <img class="icon" src="@/assets/images/SecurityControl/xiaofang_ic_weizhi@2x.png" alt="">
+                          <span>{{ item.addr }}</span>
+                        </div>
+                        <div class="line time">
+                          <img class="icon" src="@/assets/images/SecurityControl/clock.png" alt="">
+                          <span>{{ item.createDate }}</span>
+                        </div>
+                      </div>
+                    </div>
+                  </div>
+                  <div v-if="item.title0 && item.createDate0" class="item_wrap">
+                    <img :src="item.img0" class="avatar" alt="">
+                    <div class="content">
+                      <div class="header">
+                        <div class="name">{{ item.title0 }}</div>
+                        <div class="have_time">宸茬粡鍙戠敓{{ item.haveTime0 }}</div>
+                      </div>
+                      <div class="wrap">
+                        <div class="line addr">
+                          <img class="icon" src="@/assets/images/SecurityControl/xiaofang_ic_weizhi@2x.png" alt="">
+                          <span>{{ item.addr0 }}</span>
+                        </div>
+                        <div class="line time">
+                          <img class="icon" src="@/assets/images/SecurityControl/clock.png" alt="">
+                          <span>{{ item.createDate0 }}</span>
+                        </div>
                       </div>
                     </div>
                   </div>
                 </div>
+                <div v-if="warningList.length == 0" class="empty_wrap">
+                  <img src="@/assets/images/default_empty.png" alt="">
+                </div>
               </div>
             </div>
+
           </div>
+
         </div>
         <div class="garden_warning">
           <div class="com_header">
@@ -354,7 +382,7 @@
               <img src="@/assets/images/ic_title@2x.png" class="icon" alt="" />
               <div>鍥尯瀹夐槻璁惧</div>
             </div>
-            <img src="@/assets/images/title@2x.png" class="bg" alt="" />
+            <img src="@/assets/images/task/title@2x.png" class="bg" alt="" />
           </div>
           <div class="monitoring" @click="showJk = !showJk">
             <img src="@/assets/images/SecurityControl/ic_jiankong@2x.png" class="icon" alt="">
@@ -417,7 +445,7 @@
               <img src="@/assets/images/ic_title@2x.png" class="icon" alt="" />
               <div>浠婃棩璁垮婊炵暀鎯呭喌</div>
             </div>
-            <img src="@/assets/images/title@2x.png" class="bg" alt="" />
+            <img src="@/assets/images/task/title@2x.png" class="bg" alt="" />
           </div>
           <div class="table">
             <div class="line header">
@@ -425,7 +453,7 @@
               <div class="dept">鎷滆閮ㄩ棬</div>
               <div class="dept">瓒呮椂鏃堕暱</div>
             </div>
-            <div class="three-swiper list">
+            <div v-if="dataList3.length > 0" class="three-swiper list">
               <div class="swiper-wrapper">
                 <div class="item swiper-slide three-swiper-slide" v-for="item in dataList3">
                   <div class="line">
@@ -437,7 +465,9 @@
                 </div>
               </div>
             </div>
-
+            <div v-if="dataList3.length == 0" class="empty_wrap">
+              <img src="@/assets/images/default_empty.png" alt="">
+            </div>
           </div>
         </div>
       </div>
@@ -478,6 +508,136 @@
 
 }, 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']
@@ -629,23 +789,24 @@
     }]),
     new echarts.graphic.LinearGradient(0, 1, 0, 0, [{
       offset: 0,
+      color: '#4370f2'
+    }, {
+      offset: 1,
+      color: '#61d3f9'
+    }]),
+    new echarts.graphic.LinearGradient(0, 1, 0, 0, [{
+      offset: 0,
       color: '#4679f6'
     }, {
       offset: 1,
       color: '#4674f6'
     }]),
-    new echarts.graphic.LinearGradient(0, 1, 0, 0, [{
-      offset: 0,
-      color: '#4370f2'
-    }, {
-      offset: 1,
-      color: '#61d3f9'
-    }])]
+  ]
   const data = []
-  data.push({ name: '寰呰闂�', value: data4.value.waitVisitNum, rate: data4.value.waitVisitNum / data4.value.total })
-  data.push({ name: '宸茬櫥璁�', value: data4.value.registerVisitNum, rate: data4.value.registerVisitNum / data4.value.total  })
-  data.push({ name: '宸茬寮�', value: data4.value.levelNum, rate: data4.value.levelNum / data4.value.total  })
-  data.push({ name: '婊炵暀', value: data4.value.retentionNum, rate: data4.value.retentionNum / data4.value.total  })
+  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) })
   const option = {
     color: colors,
     tooltip: {
@@ -683,6 +844,9 @@
         gap: 4,
         label: {
           show: false,
+          formatter: '',
+          lineHeight: 0,
+          position: 'inside'
         },
         tooltip: {
           trigger: 'none', // 褰撻紶鏍囨偓娴湪鏌愪釜鏁版嵁椤逛笂鏃惰Е鍙�
@@ -706,12 +870,16 @@
         label: {
           show: true,
           position: 'outside',
-          formatter: '{a|{b}}  {a|{d}%}',
+          formatter: (params) => {
+            const index = params.dataIndex
+            return `{color${index}|${params.data.name} ${params.data.rate}%}`
+            // return `<div>${params.data.name}</div>`
+          },
           rich: {
-            a: {
-              color: '#869CC9',
-              fontSize: 13
-            },
+            color0: { color: 'orange', fontSize: 14 },
+            color1: { color: '#869CC9', fontSize: 13 },
+            color2: { color: '#869CC9', fontSize: 13 },
+            color3: { color: '#869CC9', fontSize: 13 }
           }
         },
         labelLine: {
@@ -790,7 +958,6 @@
       dataListT2.value = temp
     }
     initEchart2()
-    loopFn2()
   })
 }
 
@@ -798,11 +965,11 @@
 const data4 = ref({})
 const getData3 = () => {
   visitSecurityData().then(res => {
-    if( !res.code == 200) return
+    if (!res.code == 200) return
     data4.value = res.data || {}
     let obj = data4.value
-    data4.value.total = obj.levelNum + obj.retentionNum + obj.registerVisitNum + obj.waitVisitNum    
-    const result = res.data.visitRetentionDataList || []
+    data4.value.total = obj.levelNum + obj.retentionNum + obj.registerVisitNum + obj.waitVisitNum
+    const result = res.data?.visitRetentionDataList || []
     dataList3.value = result.map(i => {
       if (i.timeOutMinute) {
         i.timeOutMinute = Math.abs(i.timeOutMinute)
@@ -818,36 +985,8 @@
       return i
     })
     initEchart3()
-    loopFn3()
   })
-
-  // getVisitRetentionData().then(res => {
-  //   const result = res.data || []
-  //   dataList3.value = result.map(i => {
-  //     if (i.timeOutMinute) {
-  //       i.timeOutMinute = Math.abs(i.timeOutMinute)
-  //     }
-  //     if (i.timeOutMinute > 60 * 24) {
-  //       i.timeOutMinuteT = dayjs.duration(i.timeOutMinute * 60 * 1000).format('D澶〩鏃秏鍒�')
-  //     } else if (i.timeOutMinute > 60) {
-  //       i.timeOutMinuteT = dayjs.duration(i.timeOutMinute * 60 * 1000).format('H鏃秏鍒�')
-  //     } else {
-  //       i.timeOutMinuteT = item.timeOutMinuteT + '鍒�'
-  //     }
-
-  //     return i
-  //   })
-  //   loopFn3()
-  // })
 }
-// const data4 = ref({})
-// const getData4 = () => {
-//   afgetVisitData().then(res => {
-//     const result = res.data || {}
-//     data4.value = result
-//     initEchart3()
-//   })
-// }
 
 const warningTab = ref('0')
 const warningNum = ref(0)
@@ -861,7 +1000,21 @@
       item.haveTime = dayjs.duration(new Date().getTime() - new Date(item.createDate).getTime()).format('HH灏忔椂mm鍒嗛挓')
       return item
     })
-    // loopFn1()
+    let temp = []
+    warningList.value.forEach((item, i) => {
+      // console.log(i);
+      if (i == 0 || i % 2 == 0) {
+        temp.push(item)
+      } else {
+        temp[temp.length - 1].addr0 = item.addr
+        temp[temp.length - 1].createDate0 = item.createDate
+        temp[temp.length - 1].haveTime0 = item.haveTime
+        temp[temp.length - 1].img0 = item.img
+        temp[temp.length - 1].title0 = item.title
+      }
+    })
+    warningList.value = temp
+    // console.log('temp', warningList.value);
   })
 }
 const tasClick = (val) => {
@@ -893,10 +1046,25 @@
   }
 }
 const menuItemClick = (val) => {
+  initPlugin()
   activeMenu.value = val
-  afgetCarmeraPreviemUrl({ indexCode: val.indexCode }).then(res => {
-    activeVideo.value = res.data
+  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) => {
@@ -909,13 +1077,10 @@
 const loopFn1 = () => {
   var newSwiper1 = new Swiper('.one-swiper', {
     initialSlide: 0,
-    loop: true, // 寰幆妯″紡閫夐」
+    // loop: true, // 寰幆妯″紡閫夐」
     direction: 'vertical', //绔栫洿鏂瑰悜
-    slidesPerView: 1,
-    slidesPerGroup: 2,
-    slidesPerColumn: 2,
-    // autoplay: { delay: 500, disableOnInteraction: false },
-    autoplay: warningList.value.length > 2 ? { delay: 500, disableOnInteraction: false } : false,
+    slidesPerView: 2,
+    autoplay: warningList.value.length > 1 ? { delay: 4000, disableOnInteraction: false } : false,
     observer: true, //淇敼swiper鑷繁鎴栧瓙鍏冪礌鏃讹紝鑷姩鍒濆鍖杝wiper
   })
 }
@@ -924,7 +1089,7 @@
     initialSlide: 0,
     direction: 'vertical', //绔栫洿鏂瑰悜
     slidesPerView: 3,
-    autoplay: autoplayFlag(dataList2.value, 3, 2000),
+    autoplay: autoplayFlag(dataList2.value, 3, 4000),
     observer: true, //淇敼swiper鑷繁鎴栧瓙鍏冪礌鏃讹紝鑷姩鍒濆鍖杝wiper
   })
 }
@@ -942,15 +1107,32 @@
 
 
 
+
 onMounted(() => {
   getData1()
   getData2()
   getData3()
-  // getData4()
   getData5()
   getWarning()
 
-  // initEchart1()
+
+  setInterval(() => {
+    getData1()
+    getData2()
+    getData3()
+    getWarning()
+  }, 1000 * 60)
+
+  setInterval(() => {
+    getData5()
+  }, 1000 * 60 * 60)
+
+  setTimeout(() => {
+    loopFn1()
+    loopFn2()
+    loopFn3()
+  }, 12000)
+
 })
 
 
@@ -978,6 +1160,8 @@
       margin-bottom: 20px;
       font-size: 14px;
       color: #D2E0FF;
+      background: rgba(0, 86, 255, 0.05);
+      backdrop-filter: blur(5px);
 
       .second_title {
         margin-top: 24px;
@@ -1326,6 +1510,8 @@
 
     .right_box_one {
       margin-bottom: 20px;
+      background: rgba(0, 86, 255, 0.05);
+      backdrop-filter: blur(5px);
 
       .second_title {
         margin-top: 20px;
@@ -1408,9 +1594,15 @@
       }
     }
 
-    .right_box_two {}
+    .right_box_two {
+      background: rgba(0, 86, 255, 0.05);
+      backdrop-filter: blur(5px);
+    }
 
-    .right_box_three {}
+    .right_box_three {
+      background: rgba(0, 86, 255, 0.05);
+      backdrop-filter: blur(5px);
+    }
   }
 }
 
@@ -1533,9 +1725,16 @@
     margin-right: 20px;
 
     /* one-swiper */
+    .one_swiper_wrap {
+      height: 140px;
+      overflow: hidden;
+      background: rgba(0, 86, 255, 0.05);
+      backdrop-filter: blur(5px);
+    }
+
     .list {
-      height: 124px;
-      overflow: auto;
+      height: 204px;
+      overflow: hidden;
       margin-top: 15px;
       scrollbar-width: none;
       display: flex;
@@ -1543,24 +1742,25 @@
       margin-left: 20px;
 
       .item {
-        width: 366px;
-        /* width: 50%; */
-        float: left;
+        width: 736px;
         height: 102px !important;
         font-size: 13px;
         color: #D2E0FF;
-        margin-right: 10px;
+        display: flex;
 
-        &:nth-of-type(2n) {
-          margin-right: 0;
-        }
-
+        /* border: 1px solid; */
         .item_wrap {
+          width: 368px;
           height: 90px;
           padding: 10px;
           background: linear-gradient(270deg, rgba(1, 217, 254, 0) 0%, rgba(1, 217, 254, 0.19) 100%);
           border: 1px solid #006E81;
           display: flex;
+          margin-right: 10px;
+
+          &:nth-of-type(2n) {
+            margin-right: 0;
+          }
         }
 
 
@@ -1618,6 +1818,8 @@
     flex: 1;
     margin-right: 20px;
     position: relative;
+    background: rgba(0, 86, 255, 0.05);
+    backdrop-filter: blur(5px);
 
     .content {
       display: flex;
@@ -1699,7 +1901,7 @@
       .table {
         .list {
           height: 102px !important;
-          overflow: auto;
+          overflow: hidden;
 
           .item {
             height: 34px !important;
@@ -1762,11 +1964,13 @@
 
   .visitor_warning {
     width: 360px;
+    background: rgba(0, 86, 255, 0.05);
+    backdrop-filter: blur(5px);
 
     .table {
       .list {
         height: 102px !important;
-        overflow: auto;
+        overflow: hidden;
 
         .item {
           height: 34px !important;
@@ -1797,13 +2001,6 @@
     align-items: center;
     font-weight: bold;
     font-size: 16px;
-    background-image: -webkit-linear-gradient(top,
-        #ffffff 0%,
-        #c8ddff 66%,
-        #85b4ff 72%,
-        #74a9ff 100%);
-    -webkit-background-clip: text;
-    -webkit-text-fill-color: transparent;
 
     .icon {
       width: 16px;

--
Gitblit v1.9.3