From f8abd2603002eb6ff296d26f99042681d9b2bc92 Mon Sep 17 00:00:00 2001 From: lawrencehj <1934378145@qq.com> Date: 星期五, 23 七月 2021 17:06:49 +0800 Subject: [PATCH] 修正推流列表播放错误 --- web_src/src/components/dialog/devicePlayer.vue | 56 ++++++++++++++++++++++++++++++++++++++++++++++---------- 1 files changed, 46 insertions(+), 10 deletions(-) diff --git a/web_src/src/components/dialog/devicePlayer.vue b/web_src/src/components/dialog/devicePlayer.vue index 9653833..be1332e 100644 --- a/web_src/src/components/dialog/devicePlayer.vue +++ b/web_src/src/components/dialog/devicePlayer.vue @@ -3,7 +3,7 @@ <el-dialog title="瑙嗛鎾斁" top="0" :close-on-click-modal="false" :visible.sync="showVideoDialog" @close="close()"> <!-- <LivePlayer v-if="showVideoDialog" ref="videoPlayer" :videoUrl="videoUrl" :error="videoError" :message="videoError" :hasaudio="hasaudio" fluent autoplay live></LivePlayer> --> - <player ref="videoPlayer" :visible.sync="showVideoDialog" :videoUrl="videoUrl" :error="videoError" :message="videoError" :height="false" :hasaudio="hasaudio" fluent autoplay live ></player> + <player ref="videoPlayer" :visible.sync="showVideoDialog" :videoUrl="videoUrl" :error="videoError" :message="videoError" :height="false" :hasAudio="hasAudio" fluent autoplay live ></player> <div id="shared" style="text-align: right; margin-top: 1rem;"> <el-tabs v-model="tabActiveName" @tab-click="tabHandleClick"> <el-tab-pane label="瀹炴椂瑙嗛" name="media"> @@ -48,7 +48,10 @@ <el-table-column label="鎿嶄綔"> <template slot-scope="scope"> - <el-button icon="el-icon-video-play" size="mini" @click="playRecord(scope.row)">鎾斁</el-button> + <el-button-group> + <el-button icon="el-icon-video-play" size="mini" @click="playRecord(scope.row)">鎾斁</el-button> + <el-button icon="el-icon-download" size="mini" @click="downloadRecord(scope.row)">涓嬭浇</el-button> + </el-button-group> </template> </el-table-column> </el-table> @@ -181,11 +184,12 @@ showVideoDialog: false, streamId: '', app : '', + mediaServerId : '', convertKey: '', deviceId: '', channelId: '', tabActiveName: 'media', - hasaudio: false, + hasAudio: false, loadingRecords: false, recordsLoading: false, isLoging: false, @@ -218,7 +222,7 @@ if (tab.name == "codec") { this.$axios({ method: 'get', - url: '/zlm/index/api/getMediaInfo?vhost=__defaultVhost__&schema=rtmp&app='+ this.app +'&stream='+ this.streamId + url: '/zlm/' +this.mediaServerId+ '/index/api/getMediaInfo?vhost=__defaultVhost__&schema=rtmp&app='+ this.app +'&stream='+ this.streamId }).then(function (res) { that.tracksLoading = false; if (res.data.code == 0 && res.data.online) { @@ -239,6 +243,7 @@ this.channelId = channelId; this.deviceId = deviceId; this.streamId = ""; + this.mediaServerId = ""; this.app = ""; this.videoUrl = "" if (!!this.$refs.videoPlayer) { @@ -255,8 +260,8 @@ break; case "streamPlay": this.tabActiveName = "media"; - this.showRrecord = false, - this.showPtz = false, + this.showRrecord = false; + this.showPtz = false; this.play(param.streamInfo, param.hasAudio) break; case "control": @@ -267,19 +272,17 @@ console.log(val) }, play: function (streamInfo, hasAudio) { - - this.hasaudio = hasAudio; + this.hasAudio = hasAudio; this.isLoging = false; // this.videoUrl = streamInfo.rtc; this.videoUrl = this.getUrlByStreamInfo(streamInfo); this.streamId = streamInfo.streamId; this.app = streamInfo.app; + this.mediaServerId = streamInfo.mediaServerId; this.playFromStreamInfo(false, streamInfo) }, getUrlByStreamInfo(streamInfo){ let baseZlmApi = process.env.NODE_ENV === 'development'?`${location.host}/debug/zlm`:`${location.host}/zlm` - console.log(12121212) - console.log(baseZlmApi) // return `${baseZlmApi}/${streamInfo.app}/${streamInfo.streamId}.flv`; // return `http://${baseZlmApi}/${streamInfo.app}/${streamInfo.streamId}.flv`; return streamInfo.ws_flv; @@ -428,6 +431,7 @@ var streamInfo = res.data; that.app = streamInfo.app; that.streamId = streamInfo.streamId; + that.mediaServerId = streamInfo.mediaServerId; that.videoUrl = that.getUrlByStreamInfo(streamInfo); that.recordPlay = true; }); @@ -443,6 +447,38 @@ if (callback) callback() }); }, + downloadRecord: function (row) { + let that = this; + if (that.streamId != "") { + that.stopDownloadRecord(function () { + that.streamId = "", + that.downloadRecord(row); + }) + } else { + this.$axios({ + method: 'get', + url: '/api/download/start/' + this.deviceId + '/' + this.channelId + '?startTime=' + row.startTime + '&endTime=' + + row.endTime + '&downloadSpeed=4' + }).then(function (res) { + var streamInfo = res.data; + that.app = streamInfo.app; + that.streamId = streamInfo.streamId; + that.mediaServerId = streamInfo.mediaServerId; + that.videoUrl = that.getUrlByStreamInfo(streamInfo); + that.recordPlay = true; + }); + } + }, + stopDownloadRecord: function (callback) { + this.$refs.videoPlayer.pause(); + this.videoUrl = ''; + this.$axios({ + method: 'get', + url: '/api/download/stop/' + this.deviceId + "/" + this.channelId + }).then(function (res) { + if (callback) callback() + }); + }, ptzCamera: function (leftRight, upDown, zoom) { console.log('浜戝彴鎺у埗锛�' + leftRight + ' : ' + upDown + " : " + zoom); let that = this; -- Gitblit v1.8.0