From 4f26bd71769f6fc0e1e0da17b22d43eaebedbed8 Mon Sep 17 00:00:00 2001
From: 648540858 <648540858@qq.com>
Date: 星期三, 16 八月 2023 16:39:44 +0800
Subject: [PATCH] 优化级联语音对讲释放逻辑

---
 web_src/src/components/dialog/devicePlayer.vue |   95 +++++++++++++++++++++++++----------------------
 1 files changed, 50 insertions(+), 45 deletions(-)

diff --git a/web_src/src/components/dialog/devicePlayer.vue b/web_src/src/components/dialog/devicePlayer.vue
index 0bc3335..925e7cb 100644
--- a/web_src/src/components/dialog/devicePlayer.vue
+++ b/web_src/src/components/dialog/devicePlayer.vue
@@ -16,7 +16,6 @@
                         :hasAudio="hasAudio" fluent autoplay live></rtc-player>
           </el-tab-pane>
           <el-tab-pane label="h265web">h265web鏁鏈熷緟</el-tab-pane>
-          <el-tab-pane label="wsPlayer">wsPlayer 鏁鏈熷緟</el-tab-pane>
         </el-tabs>
         <jessibucaPlayer v-if="Object.keys(this.player).length == 1 && this.player.jessibuca" ref="jessibuca"
                          :visible.sync="showVideoDialog" :videoUrl="videoUrl" :error="videoError" :message="videoError"
@@ -181,7 +180,7 @@
                                                      style="font-size: 1.875rem;"></i></div>
                 <div style="position: absolute; left: 7.25rem; top: 3.25rem; font-size: 1.875rem;"
                      @mousedown="ptzCamera('zoomout')" @mouseup="ptzCamera('stop')"><i
-                  class="el-icon-zoom-out control-zoom-btn"></i></div>
+                    class="el-icon-zoom-out control-zoom-btn"></i></div>
                 <div class="contro-speed" style="position: absolute; left: 4px; top: 7rem; width: 9rem;">
                   <el-slider v-model="controSpeed" :max="255"></el-slider>
                 </div>
@@ -300,8 +299,9 @@
           </el-tab-pane>
           <el-tab-pane label="璇煶瀵硅" name="broadcast">
             <div style="padding: 0 10px">
-              <el-switch v-model="broadcastMode" :disabled="broadcastStatus !== -1" active-color="#409EFF" active-text="鍠婅瘽"
-                         inactive-text="瀵硅"></el-switch>
+              <el-switch v-model="broadcastMode" :disabled="broadcastStatus !== -1" active-color="#409EFF"
+                         active-text="鍠婅瘽(Broadcast)"
+                         inactive-text="瀵硅(Talk)"></el-switch>
             </div>
             <div class="trank" style="text-align: center;">
               <el-button @click="broadcastStatusClick()" :type="getBroadcastStatus()" :disabled="broadcastStatus === -2"
@@ -539,25 +539,31 @@
       // if (callback )callback();
     },
 
-    playFromStreamInfo: function (realHasAudio, streamInfo) {
-      this.showVideoDialog = true;
-      this.hasaudio = realHasAudio && this.hasaudio;
-      this.$refs[this.activePlayer].play(this.getUrlByStreamInfo(streamInfo))
-    },
-    close: function () {
-      console.log('鍏抽棴瑙嗛');
-      if (!!this.$refs[this.activePlayer]) {
-        this.$refs[this.activePlayer].pause();
-      }
-      this.videoUrl = '';
-      this.coverPlaying = false;
-      this.showVideoDialog = false;
-      if (this.convertKey != '') {
-        this.convertStop();
-      }
-      this.convertKey = ''
-      this.stopBroadcast()
-    },
+        playFromStreamInfo: function (realHasAudio, streamInfo) {
+          this.showVideoDialog = true;
+          this.hasaudio = realHasAudio && this.hasaudio;
+          if (this.$refs[this.activePlayer]) {
+            this.$refs[this.activePlayer].play(this.getUrlByStreamInfo(streamInfo))
+          }else {
+            this.$nextTick(() => {
+              this.$refs[this.activePlayer].play(this.getUrlByStreamInfo(streamInfo))
+            });
+          }
+        },
+        close: function () {
+            console.log('鍏抽棴瑙嗛');
+            if (!!this.$refs[this.activePlayer]){
+              this.$refs[this.activePlayer].pause();
+            }
+            this.videoUrl = '';
+            this.coverPlaying = false;
+            this.showVideoDialog = false;
+            if (this.convertKey != '') {
+              this.convertStop();
+            }
+            this.convertKey = ''
+            this.stopBroadcast()
+        },
 
     copySharedInfo: function (data) {
       console.log('澶嶅埗鍐呭锛�' + data);
@@ -565,20 +571,20 @@
       this.tracks = []
       let _this = this;
       this.$copyText(data).then(
-        function (e) {
-          _this.$message({
-            showClose: true,
-            message: '澶嶅埗鎴愬姛',
-            type: 'success'
-          });
-        },
-        function (e) {
-          _this.$message({
-            showClose: true,
-            message: '澶嶅埗澶辫触锛岃鎵嬪姩澶嶅埗',
-            type: 'error'
-          });
-        }
+          function (e) {
+            _this.$message({
+              showClose: true,
+              message: '澶嶅埗鎴愬姛',
+              type: 'success'
+            });
+          },
+          function (e) {
+            _this.$message({
+              showClose: true,
+              message: '澶嶅埗澶辫触锛岃鎵嬪姩澶嶅埗',
+              type: 'error'
+            });
+          }
       );
     },
     ptzCamera: function (command) {
@@ -654,16 +660,15 @@
         this.$axios({
           method: 'get',
           url: '/api/play/broadcast/' + this.deviceId + '/' + this.channelId + "?timeout=30&broadcastMode=" + this.broadcastMode
-        }).then( (res)=> {
-          if (res.data.code == 0) {
+        }).then((res) => {
+          if (res.data.code === 0) {
             let streamInfo = res.data.data.streamInfo;
             if (document.location.protocol.includes("https")) {
               this.startBroadcast(streamInfo.rtcs)
-            }else {
+            } else {
               this.startBroadcast(streamInfo.rtc)
             }
-
-          }else {
+          } else {
             this.$message({
               showClose: true,
               message: res.data.msg,
@@ -671,7 +676,7 @@
             });
           }
         });
-      }else if (this.broadcastStatus === 1) {
+      } else if (this.broadcastStatus === 1) {
         this.broadcastStatus = -1;
         this.broadcastRtc.close()
       }
@@ -693,7 +698,7 @@
           let pushKey = res.data.data.pushKey;
           // 鑾峰彇鎺ㄦ祦閴存潈KEY
           url += "&sign=" + crypto.createHash('md5').update(pushKey, "utf8").digest('hex')
-          console.log("寮�濮嬭闊冲璁诧細 " + url)
+          console.log("寮�濮嬭闊冲枈璇濓細 " + url)
           this.broadcastRtc = new ZLMRTCClient.Endpoint({
             debug: true, // 鏄惁鎵撳嵃鏃ュ織
             zlmsdpUrl: url, //娴佸湴鍧�
@@ -719,7 +724,7 @@
             console.error('涓嶆敮鎸亀ebrtc', e)
             this.$message({
               showClose: true,
-              message: '涓嶆敮鎸亀ebrtc, 鏃犳硶杩涜璇煶瀵硅',
+              message: '涓嶆敮鎸亀ebrtc, 鏃犳硶杩涜璇煶鍠婅瘽',
               type: 'error'
             });
             this.broadcastStatus = -1;

--
Gitblit v1.8.0