<template>
|
<div class="s-linkage-rules">
|
<div class="top">
|
<p style="text-align:left;margin-bottom: 14px;">
|
<b style="font-size: 14px;line-height: 18px;">已选算法</b>
|
</p>
|
|
<div>
|
<div class="slide-scene">
|
<span class="task-tip" v-if="tableRuleList.length == 0 ">暂无算法,请在独立规则中选择算法</span>
|
<slide-scene :sceneData="tableRuleList"></slide-scene>
|
</div>
|
<!-- <slide-scene :sceneData="Camera.rules"></slide-scene> -->
|
<!-- 系统信息 -->
|
<div class="top-right">
|
<sysinfo
|
v-if="showSysInfo"
|
style="margin-left: 25px;margin-top: -10px;"
|
:ShowLocalVedio="this.TreeDataPool.treeActiveName !== 'camera'"
|
:showRealPoll="this.TreeDataPool.treeActiveName == 'camera'"
|
/>
|
</div>
|
</div>
|
</div>
|
|
<div class="bottom">
|
<div
|
style="width: calc(100% + 80px);height: 10px;background-color: #E9EBF2;p;position:relative;left:-50px"
|
></div>
|
<div class="bottom-right">
|
<div class="draw-and-time-box">
|
<div class="draw-box">
|
<p style="text-align:left;padding: 10px 0px 0px 0px;box-sizing: border-box;">
|
<b style="font-size: 14px">查看区域</b>
|
</p>
|
<div class="img-box">
|
<span class="camera-tip" v-show="swipercanvasData.length == 0 ">暂无区域,请至少选择2个摄像机</span>
|
<!-- swiper 展示 -->
|
<swiper
|
ref="swiper"
|
:options="swiperOption"
|
@slideChange="swiperSlideChange"
|
class="swiper-box-container2"
|
>
|
<swiper-slide v-for="(data, index) in swipercanvasData" :key="index">
|
<b class="video-title" style="font-size:14px;margin-top:-10px">{{ data.name }}</b>
|
<polygon-canvas
|
ref="canvas"
|
v-loading="loading"
|
element-loading-text="刷新中,请稍等..."
|
element-loading-background="rgba(0, 0, 0, 0.8)"
|
:divId="data.cameraId"
|
:isShowDrawArrow="true"
|
:isLink="true"
|
:disabled="false"
|
:loading="data.loading"
|
:snapshot_url="data.baseImg"
|
:canvasDataShow="data.canvasData"
|
:currentCameraId="data.cameraId"
|
@changeLoading="changeLoading"
|
@fromCanvas="getCanvasData"
|
></polygon-canvas>
|
</swiper-slide>
|
</swiper>
|
<div class="swiper-local-prev" v-show="swipercanvasData.length>1">
|
<div class="icon-btn" slot="button-prev">
|
<i class="iconfont iconzuo"></i>
|
</div>
|
</div>
|
<div class="swiper-local-next" v-show="swipercanvasData.length>1">
|
<div class="icon-btn" slot="button-next">
|
<i class="iconfont iconyou1"></i>
|
</div>
|
</div>
|
</div>
|
</div>
|
<div style="float:left;width:calc(10% - 90px);height:100%;"></div>
|
<div
|
class="time-box"
|
style="width:calc(90% + 90px - 576px);overflow-x:auto;overflow-y:hidden"
|
>
|
<p style="text-align:left;padding: 10px;box-sizing: border-box">
|
<b style="font-size: 14px">时间规则</b>
|
</p>
|
<time-slider ref="timeSlider" :type="'link'" />
|
</div>
|
</div>
|
|
<!-- 场景规则 -->
|
<scene-rule
|
linkRule
|
:seletedCameras="Carmeras"
|
:tableRuleList="tableRuleList"
|
:onSaveScene="saveSceneRule"
|
@delete-rule="showRules"
|
></scene-rule>
|
</div>
|
</div>
|
</div>
|
</template>
|
|
<script>
|
import {
|
saveLinkScene,
|
getLinkSceneRule,
|
} from '@/api/scene'
|
|
import VideoRuleData from "@/Pool/VideoRuleData";
|
import polygonCanvas from "@/components/canvas";
|
import TimeSlider from "./TimeSlider";
|
import Sysinfo from "./SystemInfo"
|
import SceneRule from "./SceneRule";
|
import SlideScene from "./scene/SlideScene";
|
|
export default {
|
components: {
|
TimeSlider,
|
polygonCanvas,
|
SceneRule,
|
Sysinfo,
|
SlideScene
|
},
|
computed: {
|
selectedCameraIds() {
|
let ids = [];
|
if (this.TreeDataPool.treeActiveName == 'dataStack') {
|
if (this.TreeDataPool.checkedLocalVedio.length > 0) {
|
ids = this.TreeDataPool.checkedLocalVedio.map(i => {
|
return i.id;
|
})
|
|
}
|
} else {
|
if (this.TreeDataPool.selectedNodes.length > 0) {
|
ids = this.TreeDataPool.selectedNodes;
|
}
|
}
|
|
return ids;
|
}
|
},
|
data() {
|
return {
|
loading: false,
|
Carmeras: [],
|
Camera: new VideoRuleData(),
|
tasksTable: {},
|
swipercanvasData: [],
|
seqNumber: 0,
|
tableRuleList: [],
|
swiperIndex: 0,
|
swiperOption: {
|
grabCursor: true,
|
pagination: {
|
el: ".swiper-pagination",
|
type: "fraction"
|
},
|
navigation: {
|
nextEl: ".swiper-local-next",
|
prevEl: ".swiper-local-prev"
|
}
|
},
|
swiperTaskOption: {
|
slidesPerView: 4,
|
// spaceBetween: 10,
|
pagination: {
|
el: ".swiper-pagination",
|
clickable: true
|
},
|
navigation: {
|
nextEl: ".next-border",
|
prevEl: ".pre-border"
|
}
|
},
|
showSysInfo: false
|
};
|
},
|
watch: {
|
Carmeras: {
|
handler(newVal, oldVal) {
|
this.setSwiperData();
|
},
|
deep: true
|
}
|
},
|
|
methods: {
|
swiperSlideChange() {
|
this.swiperIndex = this.$refs.swiper.swiper.activeIndex;
|
},
|
initCameraData() {
|
this.$nextTick(() => {
|
this.Carmeras = [];
|
this.loading = false;
|
this.showSysInfo = true
|
if (this.TreeDataPool.treeActiveName == 'dataStack') {
|
this.TreeDataPool.checkedLocalVedio.forEach(camera => {
|
this.Carmeras.push(new VideoRuleData(camera.id));
|
});
|
} else {
|
this.TreeDataPool.selectedNodes.forEach(camera => {
|
this.Carmeras.push(new VideoRuleData(camera));
|
});
|
}
|
this.$refs.timeSlider.activeTab = this.VideoManageData.TimeRules[0].id;
|
this.showRules();
|
})
|
},
|
setSwiperData() {
|
let swipers = [];
|
let carmeras = this.Carmeras;
|
for (let i = 0; i < carmeras.length; i++) {
|
swipers = swipers.concat({
|
cameraId: carmeras[i].cameraId,
|
name: carmeras[i].camearInfo.name,
|
baseImg: carmeras[i].baseImg ? carmeras[i].baseImg : undefined,
|
canvasData: carmeras[i].canvasData,
|
loading: carmeras[i].loading,
|
});
|
}
|
this.swipercanvasData = swipers;
|
},
|
getCanvasData() { },
|
showRules() {
|
this.tableRuleList = [];
|
|
if (this.selectedCameraIds.length > 0) {
|
getLinkSceneRule({ cameraIds: this.selectedCameraIds }).then(
|
rsp => {
|
if (rsp && rsp.success) {
|
|
this.tableRuleList = rsp.data;
|
|
// 统一规则编辑的数据结构
|
for (let i = 0; i < this.tableRuleList.length; i++) {
|
this.tableRuleList[i].group_rules = this.tableRuleList[i].rules;
|
}
|
}
|
// this.TreeDataPool.fetchTreeData();
|
}
|
);
|
}
|
|
},
|
|
saveSceneRule(groupRule) {
|
const payload = { ...groupRule }
|
payload.cameraIds = this.selectedCameraIds;
|
|
saveLinkScene(payload).then(rsp => {
|
if (rsp && rsp.success) {
|
//this.Camera.update();
|
this.initCameraData();
|
this.$notify({
|
type: "success",
|
message: "任务保存成功!"
|
});
|
} else {
|
this.$notify({
|
type: "error",
|
message: rsp.data
|
});
|
}
|
}).catch(err => {
|
this.$message({
|
type: "error",
|
message: "保存失败!" + err.data
|
});
|
});
|
},
|
changeLoading(params) {
|
this.loading = params
|
}
|
}
|
};
|
</script>
|
<style lang="scss">
|
.s-linkage-rules {
|
width: 100%;
|
height: 100%;
|
position: relative;
|
.top {
|
width: 100%;
|
height: 174px;
|
position: relative;
|
top: 0;
|
.swiper-box {
|
height: 100%;
|
float: left;
|
width: 48%;
|
margin-top: -10px;
|
position: relative;
|
}
|
.swiper-container {
|
position: initial;
|
min-width: 472px;
|
width: 80%;
|
|
// height: 124px;
|
}
|
.swiper-slide {
|
position: relative;
|
width: 100%;
|
.item-card {
|
height: 110px !important;
|
max-width: 126px;
|
width: 100%;
|
position: absolute;
|
left: 0px;
|
right: 0px;
|
bottom: 0px;
|
top: 0px;
|
margin: auto;
|
background: #ffffff;
|
border: 1px solid #e2e2e2;
|
box-shadow: 0 5px 12px 0 rgba(0, 0, 0, 0.07);
|
border-radius: 4px;
|
cursor: pointer;
|
.icon-xingzhuangcopy {
|
position: relative;
|
left: 0px;
|
right: 0px;
|
bottom: 0px;
|
top: 5px;
|
margin: auto;
|
color: #959699;
|
}
|
|
.mask {
|
position: absolute;
|
width: 100%;
|
height: 100%;
|
background: rgba(0, 0, 0, 0.65);
|
/* filter: blur(20px); */
|
backdrop-filter: blur(1px) brightness(100%);
|
display: none;
|
}
|
|
// @media screen and(max-width: 1280px) {
|
// max-width: 110px;
|
// }
|
@media screen and(max-width: 1440px) {
|
max-width: 110px;
|
}
|
}
|
.item-card:hover {
|
.mask {
|
display: block;
|
}
|
}
|
}
|
.swiper-pre-border,
|
.swiper-next-border {
|
width: 40px;
|
height: 40px;
|
position: absolute;
|
background: #8888;
|
top: 35%;
|
z-index: 99;
|
border-radius: 4em;
|
outline: none;
|
.icon-btn {
|
color: rgb(255, 255, 255);
|
text-align: center;
|
line-height: 38px;
|
cursor: pointer;
|
}
|
}
|
.swiper-pre-border {
|
left: 10px;
|
}
|
.swiper-pre-border:hover {
|
background: #666;
|
}
|
.swiper-next-border {
|
right: 10px;
|
}
|
.swiper-next-border:hover {
|
background: #666;
|
}
|
.top-right {
|
float: right;
|
width: 52%;
|
height: 144px;
|
}
|
.task-css {
|
text-align: left;
|
margin-bottom: 14px;
|
}
|
}
|
|
.bottom {
|
width: 100%;
|
height: calc(100% - 190px);
|
position: absolute;
|
top: 190px;
|
.bottom-side {
|
height: 100%;
|
width: 250px;
|
float: left;
|
overflow: auto;
|
border-right: 1px solid #ccc;
|
border-bottom: 1px solid #ccc;
|
padding: 10px;
|
box-sizing: border-box;
|
.selectTask {
|
margin: 10px auto;
|
width: 140px;
|
padding: 10px;
|
box-sizing: border-box;
|
border: 1px solid #ccc;
|
position: relative;
|
.selectTaskDelete {
|
position: absolute;
|
right: 10px;
|
font-size: 18px;
|
cursor: pointer;
|
}
|
}
|
}
|
.bottom-right {
|
width: calc(100% + 30px);
|
height: 100%;
|
float: left;
|
overflow: auto;
|
padding: 10px 0px;
|
box-sizing: border-box;
|
.draw-and-time-box {
|
height: 430px;
|
width: 100%;
|
.draw-box,
|
.time-box {
|
float: left;
|
width: 50%;
|
height: 100%;
|
.img-box {
|
height: calc(100% - 32px);
|
width: 100%;
|
// padding: 5px;
|
box-sizing: border-box;
|
display: flex;
|
// justify-content: center;
|
// align-items: center;
|
position: relative;
|
overflow: hidden;
|
.refresh-btn {
|
position: absolute;
|
right: 10px;
|
top: 10px;
|
}
|
img {
|
width: 90%;
|
padding: 5px;
|
box-sizing: border-box;
|
}
|
.swiper-box-container2 {
|
width: 100%;
|
//padding: 8px 8px 0px 8px;
|
.el-card__body {
|
height: 100%;
|
padding: 0px;
|
}
|
height: calc(100% - 10px);
|
.info {
|
width: 100%;
|
height: 100%;
|
.info-left {
|
width: 50%;
|
height: 100%;
|
float: left;
|
img {
|
width: 100%;
|
}
|
}
|
.info-right {
|
width: 50%;
|
height: 100%;
|
float: left;
|
box-sizing: border-box;
|
padding: 10px;
|
p {
|
padding: 4px 0px;
|
}
|
.infoIcon {
|
height: 24px;
|
cursor: pointer;
|
i {
|
margin: 5px;
|
font-size: 22px;
|
}
|
}
|
}
|
}
|
}
|
.swiper-local-prev,
|
.swiper-local-next {
|
width: 40px;
|
height: 40px;
|
position: absolute;
|
background: #8888;
|
top: 40%;
|
z-index: 99;
|
border-radius: 4em;
|
outline: none;
|
.icon-btn {
|
color: rgb(255, 255, 255);
|
text-align: center;
|
line-height: 38px;
|
cursor: pointer;
|
}
|
}
|
.swiper-local-prev {
|
left: 10px;
|
}
|
.swiper-local-prev:hover {
|
background: #666;
|
}
|
.swiper-local-next {
|
left: 90%;
|
}
|
.swiper-local-next:hover {
|
background: #666;
|
}
|
.camera-tip {
|
position: relative;
|
width: 300px;
|
top: 40%;
|
left: 40%;
|
font-size: 12px;
|
color: #cccccc;
|
font-family: PingFangSC-Regular;
|
}
|
}
|
}
|
.draw-box {
|
width: 576px;
|
}
|
}
|
}
|
.bottom-right::-webkit-scrollbar {
|
width: 0 !important;
|
}
|
}
|
|
.add-btn {
|
color: #3d68e1;
|
margin-left: 10px;
|
font-size: 14px;
|
cursor: pointer;
|
}
|
.add-btn:hover {
|
color: #2249b4;
|
}
|
.task-tip {
|
font-family: PingFangSC-Regular;
|
font-size: 12px;
|
color: #cccccc;
|
margin-top: 10%;
|
margin-left: 38%;
|
}
|
}
|
</style>
|
<style lang="scss" scoped>
|
.el-loading-spinner {
|
background: url("/images/cameraAccess/loading.gif") no-repeat;
|
top: 50%;
|
margin-top: -21px;
|
width: calc(100% - 260px) !important;
|
text-align: center;
|
position: absolute;
|
margin-left: 260px;
|
.el-loading-text {
|
color: #3d68e1;
|
margin: 3px 0;
|
font-size: 14px;
|
text-align: left;
|
margin-top: 22px !important;
|
padding-left: 30px;
|
}
|
}
|
</style>
|