echarts渐变色可点击半圆图

  如上所示,用饼图改一个半圆图,同时半圆每个item设置不同的颜色。

  首先需要搞出来一个echarts的容器,如下图所示,这玩意和echarts的官网搞个Div效果是一样的,只不过封装了一层,只需要设置一下参数就行。

<Echart :options="options" style="margin:0; width: 50%;height: 100%;" ref="echart1" @click="pieClick($event)"></Echart>

  上面有个@click,这就是点击事件,如下所示方法,其中dataIndex是点击的索引位置,这样就知道是点击了哪个Item。

pieClick(param){
    this.nowIndex = param.dataIndex;
}

  然后说一下半圆,其实这个半圆是一整个圆,只不过底下那个半圆是使用alpha通道隐藏了,比如设置颜色 rgba(0,0,0,0),最后一个是0,那么就是透明了。

  第二步是设置圆的半径超过100%,则占位就大了,radius: ["90%", "130%"],

  要设置每个item渐变的颜色,其实和设置单色一样,LinearGradient中四个参数分表表示 右,下,左,上四个方位,0 0 0 1 则表示颜色从上方开始渐变。

itemStyle: {
    emphasis: {
        shadowBlur: 10,
            shadowOffsetX: 0,
                shadowColor: "rgba(0, 0, 0, 0.5)",
    },
        normal:{
            color: function (colors) {
                var colorList = [
                    new echarts.graphic.LinearGradient(0, 0, 0, 1, [
                        {offset: 0, color: '#FFC950'},
                        {offset: 0, color: '#D984C3'},
                        {offset: 1, color: '#D947AD'}
                    ]),
                    new echarts.graphic.LinearGradient(0, 0, 0, 1, [
                        {offset: 0, color: '#B676F7'},
                        {offset: 1, color: '#2567F1'}
                    ]),
                    new echarts.graphic.LinearGradient(0, 0, 0, 1, [
                        {offset: 0, color: '#4F9FCE'},
                        {offset: 1, color: '#B676F7'}
                    ]),
                    new echarts.graphic.LinearGradient(0, 0, 0, 1, [
                        {offset: 0, color: '#FF7B7B'},
                        {offset: 1, color: '#F2A9F1'}
                    ]),
                    'rgba(0,0,0,0)'

                ];
                return colorList[colors.dataIndex];
            },
        }
},

  通过上述就形成了上面的渐变可点击半圆图。

  如果要在图表中间加图片,则使用如下代码,

graphic: {//图形中间图片
    elements: [{
        type: "image",
        style: {
            image: require('@/assets/leatherFactory/p8.png'),
            width: 70,
            height: 75,
        },
        left: "center",
        bottom: "20%",
    }],
},

  

  完整的options如下,

options() {
    let ths =this

    let list = [{
        name: "张三",
        value: "9"
    }, {
        name: "李四",
        value: "50"
    }, {
        name: "王五",
        value: "30"
    }, {
        name: "马六",
        value: "9"
    },{
        name:'',
        value:'0'
    }]

    let sum = 0;
    list.map((item, index) => {
        sum += parseInt(item.value)
    })

    list[list.length - 1].value = sum

    //半圆图是因为最后一个颜色,使用alpha设置为透明,其实下半圆还是存在的
    let colorList = ['#D947AD', '#4E9ECD', '#FF7B7B', '#F5C851', "rgba(0,0,0,0)"]

    return {
        graphic: {//图形中间图片
            elements: [{
              type: "image",
              style: {
                image: require('@/assets/leatherFactory/p8.png'),
                width: 70,
                height: 75,
              },
              left: "center",
              bottom: "20%",
            }],
          },
        grid:{
            width:'20%'
        },
        title:{
            subtext:'出货情况',
            textAlign:'center',
            // 副标题样式
            subtextStyle: {
                fontSize: ths.fontChart(2),
                color: 'white'
            },
            left:ths.centerX-1.5+'%',
            top:(ths.centerY-10)+'%',
        },
        tooltip: {
            show:false,
        },
        color: colorList,
        series: [{
            name: "",
            type: "pie",
            hoverAnimation: false,
            startAngle: -180,
            radius: ["90%", "130%"],
            center: ["50%", "90%"],
            label: {
                normal: {
                    show: true,
                    position: "inner", //显示在扇形上
                    formatter: "", //显示内容
                    textStyle: {
                        color: "white", // 改变标示文字的颜色
                        fontSize: 12, //文字大小
                        fontWeight: "bold",
                    },
                },
            },
            labelLine: {
                normal: {
                    show: false,
                },
            },
            data: list,
            itemStyle: {
                emphasis: {
                    shadowBlur: 10,
                    shadowOffsetX: 0,
                    shadowColor: "rgba(0, 0, 0, 0.5)",
                },
                normal:{
                    color: function (colors) {
                        var colorList = [
                            new echarts.graphic.LinearGradient(0, 0, 0, 1, [
                                {offset: 0, color: '#FFC950'},
                                {offset: 0, color: '#D984C3'},
                                {offset: 1, color: '#D947AD'}
                            ]),
                            new echarts.graphic.LinearGradient(0, 0, 0, 1, [
                                {offset: 0, color: '#B676F7'},
                                {offset: 1, color: '#2567F1'}
                            ]),
                            new echarts.graphic.LinearGradient(0, 0, 0, 1, [
                                {offset: 0, color: '#4F9FCE'},
                                {offset: 1, color: '#B676F7'}
                            ]),
                            new echarts.graphic.LinearGradient(0, 0, 0, 1, [
                                {offset: 0, color: '#FF7B7B'},
                                {offset: 1, color: '#F2A9F1'}
                            ]),
                            'rgba(0,0,0,0)'

                        ];
                        return colorList[colors.dataIndex];
                    },
                }
                // color: new echarts.graphic.LinearGradient(0, 1, 1, 1, [
                //   { offset: 0, color: '#C0D2FF' },
                //   // { offset: 0.7, color: '#DAD3F6' },
                //   { offset: 1, color: '#FADBFF' }
                // ])
            },
        }, ],
    }
},

 

posted @ 2023-02-14 10:14  伟衙内  阅读(504)  评论(0编辑  收藏  举报