本文用于记录
<template>
<div class="CaseSituation">
<!-- 标题-->
<div class="common-index-part-title">
<common-title title="渔船画像">
</common-title>
</div>
<!-- 内容-->
<div class="common-index-part-content"
v-loading="isLoading"
element-loading-text="拼命加载中"
element-loading-background="rgba(0, 0, 0, 0.8)"
>
<!-- 图表-->
<div style="width:100%;height:100%;margin-top:15px" id="shipPort"></div>
</div>
</div>
</template>
<script>
import CommonTitle from "@/pages/enforceStatistic/components/commonTitle/commonTitle";
import shipBack from "../../../../assets/enforceStatistic/decisionMark/shipBack.png"
import shipIcon from "../../../../assets/enforceStatistic/decisionMark/shipIcon.png"
export default {
name: "CaseSituation",
components: {CommonTitle},
data () {
return {
myChart: null,
isLoading: false,
allArr: [],
width: 60,
timer: null
}
},
mounted () {
clearInterval(this.timer)
this.initChart()
},
methods: {
initChart () {
let points = [
{
name: '拆解灭失',
desc: {
type: 1,
},
},
{
name: '渔船交易',
desc: {
type: 2,
},
},
{
name: '渔船检验',
desc: {
type: 1,
},
},
{
name: '渔船新造',
desc: {
type: 1,
},
},
{
name: '渔船证书',
desc: {
type: 1,
},
},
{
name: '渔船生产',
desc: {
type: 1,
},
},
{
name: '渔船改造',
desc: {
type: 1,
},
},
];
let oneArr = [
{
name: '中心点',
desc: {
type: 0,
},
symbol: 'none',
symbolSize: 233,
},
];
let erArr = points;
let allArr = [...oneArr, ...erArr]
// 点
allArr.forEach((el, ind) => {
if (el.desc.type > 0) {
el.symbolSize = [100, 40];
el.symbol =
'image://';
el.itemStyle = {
color: '#fff',
fontSize: '16px',
};
}
el.label = {
show: true,
position: 'bottom',
distance: -28,
color: '#fff',
fontSize: '16px',
fontFamily: 'SourceHanSansCN-Medium',
};
});
// 点分布
oneArr = this.CalutePointToSplitCircle(oneArr, {
stratAngle: 0,
raduis: 0,
nodeRadius: 0,
emptyCenterRadius: 0,
});
erArr = this.CalutePointToSplitCircle(erArr, {
stratAngle: -45,
raduis: 40,
nodeRadius: 5,
emptyCenterRadius: 10,
});
allArr = [...oneArr, ...erArr];
this.allArr = allArr
this.isBig = true
this.myChart= this.$echarts.init(
document.getElementById('shipPort')
)
this.timer = setInterval(this.draw, 500);
},
draw() {
let [minwidth, maxwidth] = [60, 70]; // 最小、初始、最大 缩放尺寸
var width = this.width
if (this.isBig) {
width += 5
if (width > maxwidth) {
this.isBig = false
}
} else {
width -= 5
if (width < minwidth) {
this.isBig = true
}
}
this.width = width
let option = this.getOption(width);
this.myChart.setOption(option, true);
},
getOption (width) {
let option = {
xAxis: {
show: false,
type: 'value',
max: 50,
min: -51,
},
grid: {
top: 10,
bottom: 10,
left: 10,
right: 10,
},
yAxis: {
show: false,
type: 'value',
max: 50,
min: -50,
},
graphic: {
elements: [
{
type: 'image',
z: 4,
style: {
image: shipBack,
width: 170,
height: 170,
},
left: 'center',
top: 'center',
},
{
type: 'image',
z: 5,
style: {
image: shipIcon,
width: width,
height: width,
},
left: 'center',
top: 'center',
},
],
},
series: [
{
name: '节点',
type: 'graph',
silent: false,
cursor: 'default',
coordinateSystem: 'cartesian2d',
z: 3,
data: this.allArr,
},
],
};
return option;
},
// 圆形分区
CalutePointToSplitCircle(arr, option) {
const newArray = [];
let single_angle = (360 / 8).toFixed(2);
let UtilCalute = {
calute_x: (ang, radius) => {
return (Math.cos((ang * Math.PI) / 180).toFixed(2) * radius).toFixed(2);
},
calute_y: (ang, radius) => {
return (Math.sin((ang * Math.PI) / 180).toFixed(2) * radius).toFixed(2);
},
};
// 正东方向开始 逆时针方向
arr.forEach((e, index) => {
let itemDesc = e.desc;
let ang =
option.stratAngle +
(itemDesc.angle && typeof itemDesc.angle === 'number' ? itemDesc.angle : single_angle * index);
// 各节点中心点
const x = UtilCalute.calute_x(ang, option.raduis);
const y = UtilCalute.calute_y(ang, option.raduis);
e.value = [x, y]; // 节点中心点
newArray.push(e);
});
return newArray;
},
},
beforeDestroy () {
clearInterval(this.timer)
}
}
</script>
<style lang="less" scoped>
</style>