vue+echarts: 信息中心动画

61 阅读5分钟

本文用于记录

image.png

具体可参考信息中心动画 (zhangmuchen.top)

渔船画像icon.png

img_info_bg_ship.png

<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>