Browse Source

感知事件录像弹窗

develop
lau572 4 months ago
parent
commit
6a0dfaed67
  1. 1
      ruoyi-ui/src/store/modules/tagsView.js
  2. 1
      ruoyi-ui/src/views/JiHeExpressway/components/Video/Video.vue
  3. 116
      ruoyi-ui/src/views/JiHeExpressway/pages/control/event/event/EventDetailDialog/index.vue
  4. 2
      ruoyi-ui/src/views/JiHeExpressway/pages/perception/trafficFlow/survey/index.vue
  5. 1
      ruoyi-ui/src/views/event/event/projectionScreen/DecodingStateModal.vue
  6. 1
      ruoyi-ui/src/views/event/event/projectionScreen/dynamicDecodeModal.vue
  7. 3
      ruoyi-ui/src/views/workbench/config/components/lightCurveModal.vue

1
ruoyi-ui/src/store/modules/tagsView.js

@ -103,7 +103,6 @@ const mutations = {
const actions = {
addView({ dispatch }, view) {
debugger
dispatch('addVisitedView', view)
dispatch('addCachedView', view)
},

1
ruoyi-ui/src/views/JiHeExpressway/components/Video/Video.vue

@ -54,7 +54,6 @@ export default {
methods: {
playVideo() {
this.player?.destroy();
debugger
if (this.videoType == 'flv') {
// const player = await openLiveVideo(this.$refs.videoContainerRef, { camId: this.camId, url: this.url, pileNum: this.pileNum })
this.player = new HttpLivePlayer(this.$refs.videoContainerRef, { camId: this.camId, url: this.url, pileNum: this.pileNum, rangeIndex: this.rangeIndex });

116
ruoyi-ui/src/views/JiHeExpressway/pages/control/event/event/EventDetailDialog/index.vue

@ -1,30 +1,38 @@
<template>
<!-- 事件弹窗 - 通用 -->
<div>
<Dialog title="视频录像" width="477px" style="z-index: 2051;" v-model="videoModelVisible">
<div style="flex: 1; height: 245px;width:100%;position: relative;">
<div class="radio" v-if="[2,4,7].indexOf(formData.warningSource) === -1">
<span @click="realType = 'video'" :class="{ active: realType === 'video' }">视频</span>
<span @click="realType = 'picture'" :class="{ active: realType === 'picture' }">图像</span>
</div>
<Carousel ref="carousel" style="height: 100%;" :list="realType === 'video'?(videoList || []):formData.pictures || []" :type="realType" />
</div>
</Dialog>
<Dialog v-model="modelVisible" style="z-index: 2050;" title="事件详情" width="950px" :top="(activeName == '1' || activeName == '2')?'1%':'8%'">
<div class="EventDetail" >
<Form ref="FormConfigRef" :formList="formList" v-model="data" label-width="110px" />
<!-- 视频组件 -->
<div class="video-pic" v-if="['-1','-2'].indexOf(activeName) !== -1 && [1,2,5].indexOf(data.warningSource) !== -1">
<div style="flex: 1; height: 100%;position: relative;">
<div class="radio">
<span @click="videoClick('upCamera')" :class="{ active: realVideo === 'upCamera' }">菏泽</span>
<span @click="videoClick('downCamera') " :class="{ active: realVideo === 'downCamera' }">济南</span>
</div>
<Video v-if="realVideo"
class="item-video"
:pileNum="data.stakeMark"
:rangeIndex="realVideo"
:showHeader="false"
/>
</div>
<div style="flex: 1; height: 100%;width:0px;position: relative;">
<div class="radio" v-if="[2,4,7].indexOf(formData.warningSource) === -1">
<span @click="realType = 'video'" :class="{ active: realType === 'video' }">视频</span>
<span @click="realType = 'picture'" :class="{ active: realType === 'picture' }">图像</span>
</div>
<Carousel style="height: 100%;" :list="realType === 'video'?(videoList || []):formData.pictures || []" :type="realType" />
<div style="display:flex;justify-content: space-between;align-items: center;position:relative;">
<!-- 选择按钮-->
<!-- <div class="radio">-->
<!-- <span @click="videoClick('upCamera')" :class="{ active: realVideo === 'upCamera' }">菏泽</span>-->
<!-- <span @click="videoClick('downCamera') " :class="{ active: realVideo === 'downCamera' }">济南</span>-->
<!-- </div>-->
<Video
class="item-video"
:pileNum="data.stakeMark"
:rangeIndex="realVideo1"
:showHeader="false"
/>
<Video
class="item-video"
:pileNum="data.stakeMark"
:rangeIndex="realVideo"
:showHeader="false"
/>
</div>
</div>
<!-- 组件 -->
@ -35,14 +43,16 @@
:pileNum="data.stakeMark"
rangeIndex="upCamera"
:showHeader="false"
style="width: 49%;margin-right: 2%"
/>
<span>济南方向</span></div>
<div class="item">
<div class="item">
<Video
class="item-video"
:pileNum="data.stakeMark"
rangeIndex="downCamera"
rangeIndex="downCamera"
:showHeader="false"
style="width: 49%;"
/>
<span>菏泽方向</span></div>
</div>
@ -52,31 +62,34 @@
<!-- 确认弹窗 -->
<EventPlanDialog :visible="isShowDialog" :info="info" :eventFormData="data" :activeName="activeName"
@reInitData="() => {
@reInitData="() => {
this.$emit('update:value', false);
this.$emit('queryData', true);
}
" @close="onCloseAddNew" />
<template #footer>
<Button @click.native="onOpen" :style="{ marginTop: '30px', padding: '0 24px' }">视频录像</Button>
<Button :loading="submitLoading" v-if="check(['business:home:event','control:event:event:disposalAndRelease','control:event:event:disposeOf','home:notice:releaseEvent','home:notice:closeEvent']) && activeName == '1'" style="margin-top: 30px;padding: 0 24px"
@click.native="onEnd">终止</Button>
@click.native="onEnd">终止</Button>
<Button :loading="submitLoading" v-if="check(['business:home:event','control:event:event:disposalAndRelease','control:event:event:disposeOf','home:notice:releaseEvent']) && (activeName == '-1' || activeName == '0')" style="margin-top: 30px;padding: 0 24px"
@click.native="onDelete">解除</Button>
@click.native="onDelete">解除</Button>
<Button :style="{ marginTop: '30px', backgroundColor: '#0e708b', padding: '0 24px' }" v-if="(activeName =='-2') && (data.auditFlags =='未审核') && check(['perception:eventDetection:review'])"
@click.native="onAudit">复核</Button>
<Button :style="{ marginTop: '30px', backgroundColor: '#0e708b', padding: '0 24px' }"
@click.native="modelVisible = false">取消</Button>
@click.native="modelVisible = false">取消</Button>
<template v-if="check(['business:home:event','control:event:event:disposalAndRelease','control:event:event:disposeOf','home:notice:releaseEvent','home:notice:disposeEvent'])">
<Button :loading="submitLoading" v-if="!isError && (activeName == '-1')" style="margin-top: 30px;padding: 0 24px"
@click.native="updateEvent">处置</Button>
<Button :loading="submitLoading" v-if="!isError && ( activeName == '0')" style="margin-top: 30px;padding: 0 24px"
@click.native="onSubmit">处置</Button>
<Button :loading="submitLoading" v-if="!isError && activeName == '1'" style="margin-top: 30px;padding: 0 24px"
@click.native="goDispatch">处置</Button>
<Button :loading="submitLoading" v-if="!isError && (activeName == '-1')" style="margin-top: 30px;padding: 0 24px"
@click.native="updateEvent">处置</Button>
<Button :loading="submitLoading" v-if="!isError && ( activeName == '0')" style="margin-top: 30px;padding: 0 24px"
@click.native="onSubmit">处置</Button>
<Button :loading="submitLoading" v-if="!isError && activeName == '1'" style="margin-top: 30px;padding: 0 24px"
@click.native="goDispatch">处置</Button>
</template>
</template>
</Dialog>
</div>
</template>
<script>
@ -161,6 +174,7 @@ export default {
data() {
return {
videoModelVisible:false,
data: {},
formList: [],
isShowDialog: false,
@ -187,6 +201,7 @@ export default {
videoList: [],
realType: 'video',
realVideo: 'downCamera',
realVideo1: 'upCamera',
};
},
computed: {
@ -194,6 +209,7 @@ export default {
get() {
if (this.visible) {
this.isError = false
this.getProcess();
if(this.activeName === '-1' || this.activeName === '-2' ){
_formListGz[4].options.options = WarningSubclassOptions[this.formData.warningType];
@ -201,7 +217,7 @@ export default {
this.formList = [..._formListGz]
let _data = _.cloneDeep(this.formData)
_data.direction=DirectionTypes[_data.direction]
_data.roadName = '济菏高速'
_data.roadName = '济菏高速';
if(_data.warningState==4&&_data.endTime!=null&&_data.endTime!=''&&_data.warningTime!=null){
_data.duration =getDurationEndTime(_data.warningTime,_data.endTime)
}else{
@ -213,7 +229,6 @@ export default {
_data.lane =_data.lang.toString().split(",") || []
}
if(_data.warningSource === 2){
request({
url: `/business/warning/video/${_data.id}`,
method:'get'
@ -250,15 +265,44 @@ export default {
},
},
methods: {
onOpen(){
this.videoModelVisible = !this.videoModelVisible;
this.$nextTick(()=>{
let _data = _.cloneDeep(this.formData);
if(_data.warningSource === 2){
request({
url: `/business/warning/video/${_data.id}`,
method:'get'
}).then(res=>{
if(res.code === 200 && res.msg && res.msg !== ''){
this.videoList = [res.msg]
} else {
this.videoList = []
}
})
} else {
this.videoList = _data.videoList;
}
console.log(this.formData.warningSource,'formData.warningSource')
this.videoList = _data.videoList;
})
},
check(arr){
return checkPermi(arr);
},
videoClick(type){
console.log(type)
this.realVideo = '';
setTimeout(() => {
this.realVideo = type
}, 300);
this.realVideo1 = '';
setTimeout(() => {
this.realVideo1 = type
}, 300);
},
goDispatch() {
this.$router.push(`/control/event/commandDispatch?id=${this.formData.id}`);
@ -653,6 +697,10 @@ export default {
}
}
}
::v-deep .item-video {
width: 49%;
height: 100%;
}
.radio {
position: absolute;
right: 10px;

2
ruoyi-ui/src/views/JiHeExpressway/pages/perception/trafficFlow/survey/index.vue

@ -203,7 +203,6 @@ export default {
data.columnList.forEach(x =>{
seriesData.push(stakeMarkData[x.key])
})
debugger
if (stakeMarkData.direction == '3'){
series.push({
@ -276,7 +275,6 @@ export default {
})
})
debugger
chartOptions.series = series
chartOptions.legend.data = legendData
this.myChart.setOption(chartOptions);

1
ruoyi-ui/src/views/event/event/projectionScreen/DecodingStateModal.vue

@ -94,7 +94,6 @@ export default {
watch:{
show:{
handler(newValue, oldValue){
debugger
this.visibleSync = !this.visibleSync
}
}

1
ruoyi-ui/src/views/event/event/projectionScreen/dynamicDecodeModal.vue

@ -88,7 +88,6 @@ export default {
watch:{
show:{
handler(newValue, oldValue){
debugger
this.visibleSync = !this.visibleSync
}
}

3
ruoyi-ui/src/views/workbench/config/components/lightCurveModal.vue

@ -686,7 +686,6 @@
},
//
getEchartsData(row, type) {
debugger
//
this.XDataLight = []
this.yDataLight = []
@ -976,7 +975,6 @@
},
//
lightChangeEvent(indextabs) {
debugger
console.log(this.lightFilesModel.tunnelId,this.lightFilesModel.direction,"indextabs")
if (!!this.lightFilesModel.tunnelId && !!this.lightFilesModel.direction) {
@ -1031,7 +1029,6 @@
this.paramsData.tunnelId = this.$cache.local.get("manageStationSelect");
}
console.log(this.paramsData)
debugger
await listDepId(this.paramsData).then((response) => {
this.tunnelData = response.rows;
console.log(this.tunnelData, "隧道列表");

Loading…
Cancel
Save