接上一篇文章

237 阅读12分钟

图三

preview.png

  • 特点
    • 带纹理并且带圆角
  • 重点
    • 平铺图片
    • 因为有圆角所以需要截取
/**
 * @version 1.0.1
 * @author yfeng
 * @createTime:2021-08-01,
 * @updateTime:2021-08-01
 * @copyright thunisoft fd
 */
// 事件处理函数
export default {
    props: {
        // 需要传递的数据
        data: {
            type: Array,
            default() {
                return [{
                    name:'九监区',
                    value1:20,
                    value2:2
                }, {
                    name:'十一监区',
                    value1:20,
                    value2:2
                }, {
                    name:'十二监区',
                    value1:20,
                    value2:2
                }, {
                    name:'十三监区',
                    value1:20,
                    value2:2
                }, {
                    name:'十四监区',
                    value1:20,
                    value2:2
                }, {
                    name:'十五监区',
                    value1:20,
                    value2:2
                }];
            }
        },
        legend:{
            type: Array,
            default() {
                return [{
                    name:'本月办理减刑数',
                    key:'value1'
                }, {
                    name:'本月办理假释数',
                    key:'value2'
                }];
            }
        }
    },
    data() {
        return {
            // echarts对象
            myEchart: null,
            // 数据列表
            dataList: [],
            // echart的options
            options: {}
        };
    },
    // 创建元素
    mounted() {
        this.init();
    },
    // 销毁
    destroyed() {
        // 销毁图表
        this.destroyedChart();
    },
    methods: {
        // 设置默认参数
        setDefaultOptions() {
            // 默认的参数
            this.options = {
                barWidth: 15,
                yAxis: {
                    type: 'value',
                    splitLine: {show: false},
                    axisTick: {show: false},
                    axisLabel: {show: false},
                    axisLine:{show: false}
                },
                xAxis: {
                    type: 'category',
                    axisTick: {show: false},
                    axisLine: {show: false},
                    offset:20,
                    axisLabel: {
                        interval:0,
                        textStyle: {
                            interval:0,
                            color: '#b9eff8',
                            fontWeight: 'normal',
                            fontSize: 18
                        },
                        align:'center',
                        formatter:function (params) {
                            const text = params.slice(0, 4);
                            return text;
                        }
                    },
                    data: []
                },
                grid: {
                    top: '25%',
                    left: '5%',
                    bottom: '8%',
                    right: '5%',
                    containLabel: true
                },
                series: [{
                    type: 'bar',
                    name: 'bar1',
                    barWidth : 24,
                    itemStyle: {
                        normal: {
                            label: {
                                show: true,
                                position:'top',
                                formatter: function (value) {
                                    if (parseFloat(value.data)) {
                                        return value.data;
                                    }
                                    return '';
                                },
                                textStyle: {
                                    color: '#d4fbfd',
                                    fontSize: 18
                                }
                            },
                            color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
                                offset: 0,
                                color: '#00f2fe'
                            }, {
                                offset: 1,
                                color: '#4facfe'
                            }]),
                            barBorderRadius:[12, 0, 0, 0]

                        }
                    },
                    data: []
                }, {
                    z: 15,
                    type: 'pictorialBar',
                    animation: true,
                    hoverAnimation: false,
                    data: [],
                    symbolSize: [24, 44],
                    symbolOffset: [0, 20],
                    symbolRepeat: true,
                    symbolClip:true,
                    symbol:'image://',
                    barWidth: 24,
                    itemStyle: {
                        normal: {
                            label: {show: false},
                            barBorderRadius:[12, 0, 0, 0]
                        }
                    }
                }, {
                    type: 'bar',
                    name: 'bar2',
                    barWidth : 24,
                    z: 10,
                    barGap: '30%',
                    itemStyle: {
                        normal: {
                            label: {
                                show: true,
                                position:'top',
                                formatter: function (value) {
                                    if (parseFloat(value.data)) {
                                        return value.data;
                                    }
                                    return '';
                                },
                                textStyle: {
                                    color: '#d4fbfd',
                                    fontSize: 18
                                }
                            },
                            color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
                                offset: 0,
                                color: '#fbdd97'
                            }, {
                                offset: 1,
                                color: '#d3fbfb'
                            }]),
                            barBorderRadius:[0, 12, 0, 0]

                        }
                    },
                    data: []
                }, {
                    z: 30,
                    type: 'pictorialBar',
                    animation: true,
                    barGap: '30%',
                    hoverAnimation: false,
                    symbolSize: [24, 48],
                    symbolOffset: [0, 20],
                    data: [],
                    symbolRepeat: true,
                    symbolClip:true,
                    symbol: 'image://',
                    barWidth: 24,
                    itemStyle: {
                        normal: {
                            label: {show: false},
                            barBorderRadius:[12, 0, 0, 0]
                        }
                    }
                }]
            };
        },
        // 设置数据列表
        setDataList(dataList) {
            this.dataList = dataList;
        },

        /**
         * @description 初始化的方法
         * @name init
         * @return {*} 无
         */
        init() {
            // 更新数据
            this.update(this.data);
        },

        /**
         * @description 刷新图表
         * @return {*} 无
         */
        refresh() {
            if (this.myEchart) {
                this.update(this.dataList);
            }
        },

        /**
         * @description 设置图表的数据
         * @name getChartData
         * @param {object} data 参数
         * @return {*} 无
         */
        update(data) {
            // 先判断数据是否存在
            if (!Array.isArray(data)) {
                return false;
            }
            // 设置数据列表
            this.setDataList(data);
            // 如果不存在echarts
            if (!this.myEchart) {
                // 图表对象
                this.myEchart = window.echarts.init(this.$refs.jsEchart);
                // 绑定resize 事件
                this.bindResizeEvent();
            }
            // 设置默认参数
            this.setDefaultOptions();
            // 方向排序
            const _data = data;
            // 更新数据
            this.updateData(_data);
            // 清空图表
            this.myEchart.clear();
            // 生成图表
            this.myEchart.setOption(this.options);
        },

        // 更新数据对象
        updateData(data) {
            // 需要找到legend的key
            const legendKey = {};
            // 横轴的数据
            const xAxis = [];
            // 有两个柱子
            const _num = 2;
            this.legend.forEach(item => {
                legendKey[item.key] = [];
            });
            data.forEach(item => {
                xAxis.push(item.name);
                // 处理数据
                for (const i in legendKey) {
                    legendKey[i].push(item[i]);
                }
            });
            this.options.series.forEach((item, index) => {
                if (index < _num) {
                    item.name = this.legend[0].name;
                    item.data = legendKey[this.legend[0].key];
                } else {
                    item.name = this.legend[1].name;
                    item.data = legendKey[this.legend[1].key];
                }
            });
            // 处理x轴数据
            this.options.xAxis.data = xAxis;
        },
        // resize 事件处理函数
        resizeHandler() {
            if (this.myEchart) {
                this.myEchart.resize();
            }
        },

        /**
         * @description 绑定resize 事件
         * @name init
         * @return {*} 无
         */
        bindResizeEvent() {
            // 绑定resize事件
            window.eventHandler.on(window, 'resize', this.resizeHandler);
        },
        // 取消事件绑定
        unbindResizeEvent() {
            // 取消绑定resize事件
            window.eventHandler.off(window, 'resize', this.resizeHandler);
        },

        /**
         * @description 销毁图表
         * @name destroyedChart
         * @return {*} 无
         */
        destroyedChart() {
            // 如果存在echarts
            if (this.myEchart) {
                // 销毁实例,销毁后实例无法再被使用。
                this.myEchart.dispose();
                this.myEchart = null;
                // 取消事件绑定
                this.unbindResizeEvent();
            }
        }
    }
};

图四

preview.png

  • 特点
    • 排序渐变
    • 带图标
    • 边框
/**
 * @version 1.0.1
 * @author yfeng
 * @createTime:2021-08-01,
 * @updateTime:2021-08-01
 * @copyright thunisoft fd
 */
// 事件处理函数
export default {
    props: {
        // 需要传递的数据
        data: {
            type: Array,
            default() {
                return [{
                    name:'一监区',
                    value:80
                }, {
                    name:'二监区',
                    value:20
                }, {
                    name:'三监区',
                    value:30
                }, {
                    name:'四监区',
                    value:50
                }, {
                    name:'五监区',
                    value:60
                }, {
                    name:'六监区',
                    value:20
                }];
            }
        }
    },
    data() {
        return {
            // echarts对象
            myEchart: null,
            // 数据列表
            dataList: [],
            // echart的options
            options: {},
            itemStyle: {
                normal: {
                    color: {
                        x: 0,
                        y: 0,
                        x2: 1,
                        y2: 0,
                        type: 'linear',
                        global: false,
                        colorStops: [
                            {
                                // 第一节下面
                                offset: 0,
                                color: '#025ec4'
                            },
                            {
                                offset: 1,
                                color: '#00ecfd'
                            }
                        ]
                    },
                    barBorderColor: 'transparent',
                    barBorderWidth: 10,
                    barBorderRadius: 2
                }
            }
        };
    },
    // 创建元素
    mounted() {
        this.init();
    },
    // 销毁
    destroyed() {
        // 销毁图表
        this.destroyedChart();
    },
    methods: {
        // 设置默认参数
        setDefaultOptions() {
            // 默认的参数
            this.options = {
                grid: {
                    top: '8%',
                    bottom: -15,
                    right: 30,
                    left: 30,
                    containLabel: true
                },
                xAxis: {show: false},
                yAxis: [{
                    show: true,
                    data: [],
                    axisLine: {show: false},
                    splitLine: {show: false},
                    axisTick: {show: false},
                    axisLabel: {
                        show:true,
                        color: '#b9eff8',
                        lineHeight: 40,
                        fontSize: 20,
                        fontWeight:'normal',
                        formatter: function (value) {
                            return value;
                        }
                    }
                }, {
                    show: true,
                    data: [],
                    axisLine: {show: false},
                    splitLine: {show: false},
                    axisTick: {show: false},
                    axisLabel: {
                        margin: 20,
                        color: '#fff',
                        align: 'left',
                        lineHeight: 40,
                        fontSize: 20,
                        fontWeight:'normal',
                        formatter: function (value) {
                            return value;
                        }
                    }
                }],
                series: [{
                    name: 'XXX',
                    type: 'pictorialBar',
                    symbolSize: [34, 33],
                    symbolOffset: [10, -1],
                    z: 12,
                    data: []
                }, {
                    name: 'bar',
                    type: 'bar',
                    yAxisIndex: 0,
                    data: [],
                    barWidth: 20
                },
                {
                    name: 'border',
                    type: 'bar',
                    barGap: '-100%',
                    barWidth: 20,
                    itemStyle: {
                        normal: {
                            color: 'rgba(2,250,254,0.08)',
                            barBorderColor: 'rgba(0,255,246,0.35)',
                            barBorderWidth: 1,
                            barBorderRadius: 2,
                            label: {
                                // 标签显示位置
                                show: false,
                                position: 'top'
                            }
                        }
                    },
                    data: [],
                    z: 0
                }]
            };
        },
        // 设置数据列表
        setDataList(dataList) {
            this.dataList = dataList;
        },

        /**
         * @description 初始化的方法
         * @name init
         * @return {*} 无
         */
        init() {
            // 更新数据
            this.update(this.data);
        },

        /**
         * @description 刷新图表
         * @return {*} 无
         */
        refresh() {
            if (this.myEchart) {
                this.update(this.dataList);
            }
        },

        /**
         * @description 设置图表的数据
         * @name getChartData
         * @param {object} data 参数
         * @return {*} 无
         */
        update(data) {
            // 先判断数据是否存在
            if (!Array.isArray(data)) {
                return false;
            }
            // 设置数据列表
            this.setDataList(data);
            // 如果不存在echarts
            if (!this.myEchart) {
                // 图表对象
                this.myEchart = window.echarts.init(this.$refs.jsEchart);
                // 绑定resize 事件
                this.bindResizeEvent();
            }
            // 设置默认参数
            this.setDefaultOptions();
            // 方向排序
            const _data = data;
            // 更新数据
            this.updateData(_data);
            // 清空图表
            this.myEchart.clear();
            // 生成图表
            this.myEchart.setOption(this.options);
        },

        // 更新数据对象
        updateData(data) {
            // 对数组进行排序
            const _data = data.sort(this.compare('value')).reverse();
            // 存储名字
            const nameArr = [];
            // 存储值
            const number = [];
            // 光
            const guangArr = [];
            _data.forEach((item, index) => {
                nameArr.push(item.name);
                number.push(item.value);
                const guangItem = {
                    value:item.value,
                    symbolPosition:'end'
                };
                // 深拷贝
                item.itemStyle = JSON.parse(JSON.stringify(this.itemStyle));
                // eslint-disable-next-line default-case
                switch (index) {
                    // 最后一名
                    case 0:
                        item.itemStyle.normal.color.colorStops = [{
                            // 第一节下面
                            offset: 0,
                            color: '#db500d'
                        },
                        {
                            offset: 1,
                            color: '#dba212'
                        }];
                        guangItem.symbol = 'image://';
                        break;
                    // eslint-disable-next-line no-fallthrough
                    case 1:
                        item.itemStyle.normal.color.colorStops = [{
                            // 第一节下面
                            offset: 0,
                            color: '#a39f17'
                        },
                        {
                            offset: 1,
                            color: '#d7c913'
                        }];
                        guangItem.symbol = 'image://';
                        break;
                    // eslint-disable-next-line no-fallthrough
                    case 2:
                        item.itemStyle.normal.color.colorStops = [{
                            // 第一节下面
                            offset: 0,
                            color: '#008e9e'
                        },
                        {
                            offset: 1,
                            color: '#07fda5'
                        }];
                        guangItem.symbol = 'image://';
                        break;
                    // eslint-disable-next-line no-fallthrough
                    default:
                        guangItem.symbol = 'image://';
                }
                guangArr.push(guangItem);
            });
            // 获取数组中最大的值
            const maxNum = Math.max.apply(null, number);
            // 改变yAxis
            this.options.yAxis.forEach((item, index) => {
                item.data = nameArr;
                if (index) {
                    item.axisLabel.formatter = function (value, index) {
                        return `${number[index]}分`;
                    };
                }
            });
            // 带光的bar
            // 光的data
            this.options.series[0].data = guangArr;
            // bar的data
            this.options.series[1].data = _data;
            // 框的data
            this.options.series[2].data = new Array(nameArr.length).fill(maxNum);
        },
        // 对象排序
        compare(property) {
            return function (a, b) {
                const value1 = a[property];
                const value2 = b[property];
                return value2 - value1;
            };
        },
        // resize 事件处理函数
        resizeHandler() {
            if (this.myEchart) {
                this.myEchart.resize();
            }
        },

        /**
         * @description 绑定resize 事件
         * @name init
         * @return {*} 无
         */
        bindResizeEvent() {
            // 绑定resize事件
            window.eventHandler.on(window, 'resize', this.resizeHandler);
        },
        // 取消事件绑定
        unbindResizeEvent() {
            // 取消绑定resize事件
            window.eventHandler.off(window, 'resize', this.resizeHandler);
        },

        /**
         * @description 销毁图表
         * @name destroyedChart
         * @return {*} 无
         */
        destroyedChart() {
            // 如果存在echarts
            if (this.myEchart) {
                // 销毁实例,销毁后实例无法再被使用。
                this.myEchart.dispose();
                this.myEchart = null;
                // 取消事件绑定
                this.unbindResizeEvent();
            }
        }
    }
};