| | |
| | | </div> |
| | | <div style="background-color: #FFFFFF; margin-bottom: 1rem; position: relative; padding: 0.5rem; text-align: left;font-size: 14px;"> |
| | | <el-button icon="el-icon-plus" size="mini" style="margin-right: 1rem;" type="primary" @click="addStreamProxy">添加代理</el-button> |
| | | <el-button v-if="false" icon="el-icon-search" size="mini" style="margin-right: 1rem;" type="primary" @click="addOnvif">搜索ONVIF</el-button> |
| | | </div> |
| | | <devicePlayer ref="devicePlayer"></devicePlayer> |
| | | <el-table :data="streamProxyList" border style="width: 100%" :height="winHeight"> |
| | |
| | | <el-table-column label="流地址" width="400" align="center" show-overflow-tooltip > |
| | | <template slot-scope="scope"> |
| | | <div slot="reference" class="name-wrapper"> |
| | | |
| | | |
| | | <el-tag size="medium" v-if="scope.row.type == 'default'"> |
| | | <i class="cpoy-btn el-icon-document-copy" title="点击拷贝" v-clipboard="scope.row.url" @success="$message({type:'success', message:'成功拷贝到粘贴板'})"></i> |
| | | <i class="cpoy-btn el-icon-document-copy" title="点击拷贝" v-clipboard="scope.row.url" @success="$message({type:'success', message:'成功拷贝到粘贴板'})"></i> |
| | | {{scope.row.url}} |
| | | </el-tag> |
| | | <el-tag size="medium" v-if="scope.row.type != 'default'"> |
| | | <i class="cpoy-btn el-icon-document-copy" title="点击拷贝" v-clipboard="scope.row.src_url" @success="$message({type:'success', message:'成功拷贝到粘贴板'})"></i> |
| | | <i class="cpoy-btn el-icon-document-copy" title="点击拷贝" v-clipboard="scope.row.src_url" @success="$message({type:'success', message:'成功拷贝到粘贴板'})"></i> |
| | | {{scope.row.src_url}} |
| | | </el-tag> |
| | | </div> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column prop="gbId" label="国标编码" width="180" align="center" show-overflow-tooltip/> |
| | | <el-table-column label="启用" width="120" align="center"> |
| | | <template slot-scope="scope"> |
| | | <div slot="reference" class="name-wrapper"> |
| | | <el-tag size="medium" v-if="scope.row.enable">已启用</el-tag> |
| | | <el-tag size="medium" type="info" v-if="!scope.row.enable">未启用</el-tag> |
| | | </div> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column label="转HLS" width="120" align="center"> |
| | | <template slot-scope="scope"> |
| | | <div slot="reference" class="name-wrapper"> |
| | |
| | | </div> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column label="启用" width="120" align="center"> |
| | | <template slot-scope="scope"> |
| | | <div slot="reference" class="name-wrapper"> |
| | | <el-tag size="medium" v-if="scope.row.enable">已启用</el-tag> |
| | | <el-tag size="medium" type="info" v-if="!scope.row.enable">未启用</el-tag> |
| | | </div> |
| | | </template> |
| | | </el-table-column> |
| | | |
| | | |
| | | <el-table-column label="操作" width="360" align="center" fixed="right"> |
| | | <template slot-scope="scope"> |
| | |
| | | :total="total"> |
| | | </el-pagination> |
| | | <streamProxyEdit ref="streamProxyEdit" ></streamProxyEdit> |
| | | <onvifEdit ref="onvifEdit" ></onvifEdit> |
| | | </el-main> |
| | | </el-container> |
| | | </div> |
| | |
| | | |
| | | <script> |
| | | import streamProxyEdit from './dialog/StreamProxyEdit.vue' |
| | | import onvifEdit from './dialog/onvifEdit.vue' |
| | | import devicePlayer from './dialog/devicePlayer.vue' |
| | | import uiHeader from './UiHeader.vue' |
| | | export default { |
| | |
| | | components: { |
| | | devicePlayer, |
| | | streamProxyEdit, |
| | | onvifEdit, |
| | | uiHeader |
| | | }, |
| | | data() { |
| | | return { |
| | | streamProxyList: [], |
| | | streamProxyList: [], |
| | | currentPusher: {}, //当前操作设备对象 |
| | | updateLooper: 0, //数据刷新轮训标志 |
| | | currentDeviceChannelsLenth:0, |
| | |
| | | }, |
| | | mounted() { |
| | | this.initData(); |
| | | // this.updateLooper = setInterval(this.initData, 10000); |
| | | this.updateLooper = setInterval(this.initData, 1000); |
| | | }, |
| | | destroyed() { |
| | | this.$destroy('videojs'); |
| | |
| | | addStreamProxy: function(){ |
| | | this.$refs.streamProxyEdit.openDialog(null, this.initData) |
| | | }, |
| | | addOnvif: function(){ |
| | | this.getListLoading = true; |
| | | this.getListLoading = true; |
| | | this.$axios({ |
| | | method: 'get', |
| | | url:`/api/onvif/search?timeout=3000`, |
| | | }).then((res) =>{ |
| | | this.getListLoading = false; |
| | | if (res.data.code == 0 ){ |
| | | if (res.data.data.length > 0) { |
| | | console.log(res.data.data) |
| | | this.$refs.onvifEdit.openDialog(res.data.data, (url)=>{ |
| | | if (url != null) { |
| | | this.$refs.onvifEdit.close(); |
| | | this.$refs.streamProxyEdit.openDialog({type: "default", url: url, src_url: url}, this.initData()) |
| | | } |
| | | }) |
| | | }else { |
| | | this.$message.success("未找到可用设备"); |
| | | } |
| | | }else { |
| | | this.$message.error(res.data.msg); |
| | | } |
| | | |
| | | }).catch((error)=> { |
| | | this.getListLoading = false; |
| | | this.$message.error(error.response.data.msg); |
| | | }); |
| | | |
| | | }, |
| | | saveStreamProxy: function(){ |
| | | }, |
| | | play: function(row){ |
| | |
| | | console.log(error); |
| | | that.getListLoading = false; |
| | | }); |
| | | |
| | | |
| | | }, |
| | | deleteStreamProxy: function(row){ |
| | | console.log(1111) |
| | | let that = this; |
| | | this.getListLoading = true; |
| | | that.$axios({ |
| | | method:"delete", |
| | | url:"/api/proxy/del", |
| | | params:{ |
| | | app: row.app, |
| | | stream: row.stream |
| | | } |
| | | app: row.app, |
| | | stream: row.stream |
| | | } |
| | | }).then((res)=>{ |
| | | that.getListLoading = false; |
| | | that.initData() |
| | | that.initData() |
| | | }).catch(function (error) { |
| | | console.log(error); |
| | | that.getListLoading = false; |
| | | that.getListLoading = false; |
| | | }); |
| | | }, |
| | | start: function(row){ |
| | |
| | | stream: row.stream |
| | | } |
| | | }).then(function (res) { |
| | | that.getListLoading = false; |
| | | that.startBtnLaoding = false; |
| | | that.initData() |
| | | that.getListLoading = false; |
| | | that.startBtnLaoding = false; |
| | | if (res.data == "success"){ |
| | | that.initData() |
| | | }else { |
| | | that.$message({ |
| | | showClose: true, |
| | | message: "保存失败,请检查地址是否可用!", |
| | | type: "error", |
| | | }); |
| | | } |
| | | |
| | | }).catch(function (error) { |
| | | console.log(error); |
| | | that.getListLoading = false; |