You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
frontend/src/views/components/carouselChart.vue

717 lines
18 KiB
Vue

2 years ago
<template>
<div class="thumb-example">
2 years ago
<div class="picTop">
<!-- 判断是否是图片并且不为空 -->
<div
class="bigimg"
v-if="
2 years ago
bigPicPath.indexOf('nopic') == -1 &&
bigPicPath.indexOf('videos') == -1
"
:style="bigPicPath ? 'backgroundImage:url(' + bigPicPath + ')' : ''"
@click="handleBigPicbox(bigPicPath)"
>
<!-- @click="handleBigPicbox(bigPicPath)" -->
<div
class="nosee"
:style="'backgroundImage:url(' + bigPicPath + ')'"
></div>
<viewer :options="OptionssalseImg" class="bigimgView">
<img ref="picJpg" class="animImg" :src="bigPicPath" />
</viewer>
2 years ago
<canvas id="myCanvas" class="myCanvas" ref="myCanvas"></canvas>
<!-- <img ref="picJpg" class="animImg" :src="bigPicPath + '!1366x768'" /> -->
</div>
<div class="bigimg nopic" v-if="bigPicPath.indexOf('nopic') !== -1">
<img
class="animImg"
:src="bigPicPath.substring(0, bigPicPath.length - 9)"
/>
</div>
2 years ago
<div class="bigimg" v-else-if="bigPicPath.indexOf('videos') !== -1">
<video
width="100%"
height="100%"
:src="bigPicPath"
controls="controls"
2 years ago
:poster="videopath"
autoplay
2 years ago
></video>
</div>
<div
v-if="
showBigpic &&
bigPicPath.indexOf('nopic') == -1 &&
bigPicPath.indexOf('videos') == -1
"
class="showPic"
@click="closePic"
>
<div class="picboxI">
<img class="maskPic" :src="bigPicPath" />
</div>
<div class="viewClose">
<i @click="closePic" class="el-icon-close"></i>
</div>
</div>
2 years ago
<div class="arrow leftArrow" v-if="this.bigNum != 0" @click="leftClick">
<i class="el-icon-arrow-left"></i>
</div>
<div
class="arrow rightArrow"
v-if="this.bigNum < this.terminalPhoto.length - 1"
@click="rightClick"
>
<i class="el-icon-arrow-right"></i>
</div>
</div>
<div class="picBottom">
<ul class="smallPicBox">
<li
v-for="(item, index) in fiveList"
@click="handleBigpic(item, index)"
:class="activeSmall === index ? 'borderActive' : ''"
>
2 years ago
<div
class="smallhavePic"
v-if="
item.path.indexOf('nopic') == -1 &&
item.path.indexOf('videos') == -1
"
>
<img :src="item.path + '!260x160'" />
<p class="timeInfo">
<el-tooltip
class="item"
effect="dark"
content="拍照时间"
placement="top-start"
>
<span>{{ $moment(item.photoTime).format("HH:mm:ss") }}</span>
</el-tooltip>
2 years ago
(
<el-tooltip
class="item"
effect="dark"
content="图片上传时间"
placement="top-start"
>
<span> {{ $moment(item.recvTime).format("HH:mm:ss") }}</span>
</el-tooltip>
)
2 years ago
<span
>--{{
item.alias !== null && item.alias !== ""
? item.alias
2 years ago
: item.channelName
2 years ago
}}</span
>
</p>
</div>
2 years ago
<div
class="smallnoPic"
v-else-if="item.path.indexOf('videos') !== -1"
>
2 years ago
<img
src="../../assets/img/loading.jpg"
style="object-fit: cover"
2 years ago
v-if="item.thumb == null"
2 years ago
/>
<img :src="item.thumb" v-else />
<p class="videoicon"><i class="el-icon-video-play"></i></p>
2 years ago
<p class="timeInfo">
<el-tooltip
class="item"
effect="dark"
content="拍照时间"
placement="top-start"
>
<span>{{ $moment(item.photoTime).format("HH:mm:ss") }}</span>
</el-tooltip>
(
<el-tooltip
class="item"
effect="dark"
content="图片上传时间"
placement="top-start"
>
<span> {{ $moment(item.recvTime).format("HH:mm:ss") }}</span>
</el-tooltip>
)
2 years ago
<span
>--{{
item.alias !== null && item.alias !== ""
? item.alias
: item.channelName
}}</span
>
2 years ago
</p>
2 years ago
</div>
<div class="smallnoPic" v-else>
<img :src="item.path" />
</div>
2 years ago
</li>
</ul>
<div
2 years ago
class="arrow leftArrow"
v-if="this.page != 1"
@click="smallLeftClick"
>
<i class="el-icon-arrow-left"></i>
</div>
<div
2 years ago
class="arrow rightArrow"
v-if="this.page < this.total"
@click="smallRightClick"
>
2 years ago
<i class="el-icon-arrow-right"></i>
</div>
</div>
</div>
2 years ago
</template>
<script>
2 years ago
import { getCoordinate, updateMarkEnableStatus } from "@/utils/api/index";
2 years ago
export default {
2 years ago
components: {},
props: {
terminalPhoto: {
type: Array,
default: () => [],
},
},
data() {
return {
2 years ago
OptionssalseImg: {
inline: false,
button: true,
navbar: false,
title: false,
toolbar: false,
tooltip: false,
zoomable: true,
url: "src",
},
2 years ago
isshowArrow: true, //判断是否显示切换按钮
bigPicPath: "", //大图地址
2 years ago
videopath: "",
2 years ago
smallPicPath: "", //小图地址
bigNum: 0, //判断大图是第几张
fiveList: [], //小图图片list
activeSmall: 0, //索引选中小图,
page: 1, //当前第几页
pagesize: 5, //每页显示五条
total: 0, //总共又几页
2 years ago
localPoints: [], //画图对象
canvas: null,
ctx: null,
imgpic: null,
2 years ago
color: "",
num: "",
showBigpic: false,
2 years ago
flagline: true,
2 years ago
markEnable: "",
};
},
2 years ago
mounted() {
2 years ago
console.log(this.terminalPhoto);
this.bigPicPath = this.terminalPhoto[0].path + "!1366x768";
2 years ago
this.fiveList = this.terminalPhoto.slice(this.page - 1, this.pagesize);
this.total = this.terminalPhoto.length / this.pagesize;
2 years ago
console.log(this.fiveList);
2 years ago
//获取points
getCoordinate({
channelId:
this.fiveList[0].channelId == null ? 1 : this.fiveList[0].channelId,
2 years ago
needPic: "0",
termId: this.fiveList[0].termId,
})
.then((res) => {
console.log(res);
this.localPoints = res.data.list;
2 years ago
this.color = res.data.color;
this.num = res.data.boderWidth;
2 years ago
this.markEnable = res.data.markEnable;
if (this.markEnable === 1) {
this.drawline();
}
2 years ago
})
.catch((err) => {});
2 years ago
},
watch: {
terminalPhoto: function (newVal, oldVal) {
this.bigPicPath = this.terminalPhoto[0].path + "!1366x768";
2 years ago
this.fiveList = this.terminalPhoto.slice(this.page - 1, this.pagesize);
this.total = this.terminalPhoto.length / this.pagesize;
},
2 years ago
},
2 years ago
created() {},
2 years ago
methods: {
2 years ago
handleBigPicbox() {
this.showBigpic = true;
},
closePic() {
this.showBigpic = false;
},
2 years ago
openline() {
this.flagline = true;
console.log("11111111111111111111111111", this.flagline);
2 years ago
updateMarkEnableStatus({
status: 1,
}).then((res) => {
console.log(res);
});
2 years ago
this.drawline();
},
2 years ago
drawline() {
this.canvas = this.$refs.myCanvas;
this.imgpic = this.$refs.picJpg;
console.log(this.canvas);
console.log(this.imgpic);
this.canvas.width = this.imgpic.offsetWidth; //设置画布大小
this.canvas.height = this.imgpic.offsetHeight; //设置画布大小
this.ctx = this.canvas.getContext("2d");
console.log(this.localPoints);
2 years ago
if (this.flagline == true) {
this.localPoints = this.localPoints;
} else {
this.localPoints = [];
}
2 years ago
console.log(this.ctx);
this.ctx.beginPath();
//设置线条颜色,必须放在绘制之前
this.ctx.strokeStyle = this.color;
// 线宽设置,必须放在绘制之前
this.ctx.lineWidth = this.num;
for (var i = 0; i < this.localPoints.length; i++) {
this.ctx.moveTo(
this.localPoints[i].x1 * this.imgpic.width,
this.localPoints[i].y1 * this.imgpic.height
);
this.ctx.lineTo(
this.localPoints[i].x2 * this.imgpic.width,
this.localPoints[i].y2 * this.imgpic.height
);
2 years ago
}
this.ctx.closePath();
this.ctx.stroke();
},
2 years ago
//不显示绘制线
handelClear() {
this.ctx.clearRect(0, 0, this.canvas.width, this.canvas.height);
2 years ago
this.flagline = false;
2 years ago
updateMarkEnableStatus({
status: 0,
}).then((res) => {
console.log(res);
});
2 years ago
},
2 years ago
getphotoList() {
this.fiveList = this.terminalPhoto.slice(
(this.page - 1) * this.pagesize,
this.page * this.pagesize
);
this.bigPicPath = this.fiveList[this.activeSmall].path + "!1366x768";
2 years ago
this.videopath = this.fiveList[this.activeSmall].thumb;
2 years ago
},
//大图点击左侧切换图片
leftClick() {
this.bigNum--; //执行下一张
this.bigPicPath = this.terminalPhoto[this.bigNum].path + "!1366x768";
2 years ago
this.activeSmall--;
console.log("activeSmall", this.activeSmall, "bigNum", this.bigNum);
console.log(this.page);
if (this.activeSmall < 0) {
this.activeSmall = 4;
this.smallLeftClick();
}
2 years ago
console.log(this.terminalPhoto[this.bigNum]);
getCoordinate({
channelId: this.terminalPhoto[this.bigNum].channelId,
needPic: "1",
termId: this.terminalPhoto[this.bigNum].termId,
})
.then((res) => {
console.log(res);
this.localPoints = res.data.list;
2 years ago
if (this.markEnable === 1) {
this.drawline();
}
2 years ago
})
.catch((err) => {});
2 years ago
},
//点击右侧切换图片
rightClick() {
this.bigNum++; //执行下一张
this.bigPicPath = this.terminalPhoto[this.bigNum].path + "!1366x768";
2 years ago
this.activeSmall++;
console.log("activeSmall", this.activeSmall, "bigNum", this.bigNum);
if (this.activeSmall > 4) {
this.activeSmall = 0;
console.log(this.activeSmall);
this.smallRightClick();
}
2 years ago
getCoordinate({
channelId: this.terminalPhoto[this.bigNum].channelId,
needPic: "1",
termId: this.terminalPhoto[this.bigNum].termId,
})
.then((res) => {
console.log(res);
this.localPoints = res.data.list;
2 years ago
if (this.markEnable === 1) {
this.drawline();
}
2 years ago
})
.catch((err) => {});
2 years ago
},
//点击小图变成大图
handleBigpic(row, index) {
console.log(row);
console.log();
this.activeSmall = index;
this.bigPicPath = row.path + "!1366x768";
2 years ago
getCoordinate({
channelId: row.channelId,
needPic: "1",
termId: row.termId,
})
.then((res) => {
console.log(res);
this.localPoints = res.data.list;
2 years ago
if (this.markEnable === 1) {
this.drawline();
}
// this.drawline();
2 years ago
})
.catch((err) => {});
2 years ago
},
//点击小图切换左侧
smallLeftClick() {
this.activeSmall = 0;
2 years ago
console.log("点击了左侧");
this.page--;
if (this.page < 1) {
this.isshowArrow = false;
} else {
this.getphotoList();
}
console.log(this.page);
console.log(this.fiveList);
2 years ago
//获取points
getCoordinate({
channelId: this.fiveList[0].channelId,
needPic: "0",
termId: this.fiveList[0].termId,
})
.then((res) => {
console.log(res);
this.localPoints = res.data.list;
2 years ago
if (this.markEnable === 1) {
this.drawline();
}
// this.drawline();
2 years ago
})
.catch((err) => {});
2 years ago
},
//点击小图切换右侧
smallRightClick() {
this.activeSmall = 0;
2 years ago
console.log("点击了右侧");
console.log(this.page);
this.page++;
this.getphotoList();
console.log(this.fiveList);
2 years ago
//获取points
getCoordinate({
channelId: this.fiveList[0].channelId,
needPic: "0",
termId: this.fiveList[0].termId,
})
.then((res) => {
console.log(res);
this.localPoints = res.data.list;
2 years ago
if (this.markEnable === 1) {
this.drawline();
}
// this.drawline();
2 years ago
})
.catch((err) => {});
2 years ago
},
},
2 years ago
};
</script>
<style lang="less">
2 years ago
.thumb-example {
width: 100%;
display: flex;
flex-direction: column;
2 years ago
height: calc(100% - 0px);
box-sizing: border-box;
.showPic {
position: fixed;
background-color: rgba(0, 0, 0, 0.5);
bottom: 0;
left: 0;
overflow: hidden;
right: 0;
top: 0;
z-index: 9999;
display: flex;
2 years ago
cursor: pointer;
.picboxI {
position: relative;
max-width: 1366px;
max-height: 768px;
margin: auto;
animation-name: scaleDraw;
/*关键帧名称*/
animation-timing-function: ease;
/*动画的速度曲线*/
animation-iteration-count: 1;
/*动画播放的次数*/
animation-duration: 0.65s;
img {
max-width: 1366px;
max-height: 768px;
margin: auto;
}
}
.viewClose {
-webkit-app-region: no-drag;
background-color: rgba(0, 0, 0, 0.5);
border-radius: 50%;
cursor: pointer;
height: 80px;
overflow: hidden;
position: absolute;
right: -40px;
top: -40px;
transition: background-color 0.15s;
width: 80px;
.el-icon-close {
bottom: 16px;
left: 16px;
position: absolute;
color: #fff;
font-size: 18px;
}
}
}
2 years ago
.picTop {
2 years ago
width: 100%;
height: 80%;
overflow: hidden;
2 years ago
margin-bottom: 4px;
2 years ago
position: relative;
&:hover {
.arrow {
opacity: 1;
transition: all 0.5s ease-in;
}
}
.bigimg {
width: 100%;
2 years ago
height: 100%;
display: flex;
align-items: center;
justify-content: center;
position: relative;
background-size: 100% 100%;
.nosee {
width: 100%;
height: 100%;
position: absolute;
background-size: 100% 100%;
z-index: 2;
}
.bigimgView {
width: 100%;
height: 100%;
position: absolute;
z-index: 3;
opacity: 0;
}
2 years ago
.mark {
position: absolute;
bottom: 12px;
2 years ago
color: #fff;
background-color: rgba(0, 0, 0, 0.5);
left: 16px;
font-size: 14px;
line-height: 24px;
//opacity: 0;
transition: bottom 2s ease 0s;
}
2 years ago
.myCanvas {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
cursor: pointer;
z-index: 2;
2 years ago
}
}
2 years ago
img {
width: 100%;
height: 100%;
object-fit: fill;
cursor: pointer;
}
.arrow {
opacity: 0;
position: absolute;
cursor: pointer;
color: #fff;
font-size: 16px;
2 years ago
border-radius: 30px;
position: absolute;
top: 50%;
transform: translateY(-50%);
background-color: rgba(0, 0, 0, 0.5);
display: flex;
justify-content: center;
align-items: center;
color: #fff;
text-align: center;
line-height: 60px;
width: 40px;
height: 40px;
2 years ago
&:hover {
2 years ago
color: @color-primary;
2 years ago
}
}
.leftArrow {
left: 16px;
}
.rightArrow {
right: 16px;
2 years ago
}
}
2 years ago
.picBottom {
width: 100%;
2 years ago
height: 20%;
2 years ago
position: relative;
.smallPicBox {
width: 100%;
height: 100%;
display: flex;
justify-content: center;
2 years ago
li {
width: 20%;
border: 3px solid transparent;
// overflow: hidden;
2 years ago
box-sizing: border-box;
2 years ago
display: flex;
align-items: center;
justify-content: center;
2 years ago
position: relative;
img {
width: 100%;
height: 100%;
object-fit: fill;
cursor: pointer;
}
.smallhavePic {
width: 100%;
height: 100%;
}
.smallnoPic {
width: 100%;
height: 100%;
}
2 years ago
}
2 years ago
.timeInfo {
position: absolute;
bottom: 0px;
width: 100%;
background: #f0f0f0;
2 years ago
padding: 6px 0px;
2 years ago
font-size: 12px;
text-align: center;
color: #333;
}
.videoicon {
position: absolute;
2 years ago
top: 73%;
left: 10%;
transform: translate(-50%, -50%);
i {
2 years ago
font-size: 28px;
color: #fff;
}
}
2 years ago
.borderActive {
.timeInfo {
2 years ago
//background: @color-primary;
background: linear-gradient(180deg, #00eaff 10%, @color-primary 100%);
2 years ago
color: #fff;
}
}
// .borderActive {
2 years ago
// border: 3px solid @color-primary;
2 years ago
// &::after {
// content: "";
// position: absolute;
// width: 0;
// height: 0;
// left: 50%;
// top: -16px;
// margin-left: -8px;
2 years ago
// border-bottom: 13px solid @color-primary;
2 years ago
// border-left: 8px solid transparent;
// border-right: 8px solid transparent;
// }
// }
2 years ago
}
2 years ago
.arrow {
position: absolute;
2 years ago
cursor: pointer;
color: #fff;
font-size: 12px;
2 years ago
border-radius: 30px;
position: absolute;
top: 45%;
transform: translateY(-50%);
background-color: rgba(0, 0, 0, 0.5);
display: flex;
justify-content: center;
align-items: center;
color: #fff;
text-align: center;
2 years ago
line-height: 60px;
width: 28px;
height: 28px;
2 years ago
}
.leftArrow {
left: 16px;
}
.rightArrow {
right: 16px;
}
}
2 years ago
}
@keyframes scaleDraw {
/*定义关键帧、scaleDrew是需要绑定到选择器的关键帧名称*/
0% {
transform: scale(0);
/*开始为原始大小*/
}
100% {
transform: scale(1);
}
}
2 years ago
// https://v1.github.surmon.me/vue-awesome-swiper/
2 years ago
</style>