自定义 legend

描述:当前是关于Echarts图表中的 饼图 示例。
 
                  var img = ''
var colorList = [
    ['rgba(1, 52, 155, 1)', 'rgba(56, 123, 252, 1)'],
    ['rgba(254, 239, 77, 1)', 'rgba(133, 119, 0, 1)'],
    ['rgba(168, 168, 168, 1)', 'rgba(255, 255, 255, 1)'],
    ['rgba(0, 247, 255, 1)', 'rgba(0, 138, 131, 1)'],
];
var trafficWay = [{
    name: '游园',
    value: 20
}, {
    name: '社区公园',
    value: 10
}, {
    name: '综合公园',
    value: 30
}, {
    name: '专类公园',
    value: 40
}];
var nameArray = trafficWay.map(item => {
    return item.name
})

let option = {
    backgroundColor: '#081736',
    graphic: {
        elements: [{
            type: "image",
            z: 3,
            style: {
                image: img,
                width: 206,
                height: 206
            },
            left: '15%',
            top: 'center',
        }]
    },
    tooltip: {
        show: false
    },
    legend: {
        icon: `path://M881.387 297.813c38.08 65.387 57.28 136.747 57.28 214.187s-19.094 148.8-57.28 214.187c-38.187 65.28-89.92 117.12-155.2 155.2S589.44 938.667 512 938.667s-148.8-19.094-214.187-57.28c-65.28-38.08-117.013-89.814-155.306-155.307C104.427 660.8 85.333 589.44 85.333 512c0-77.333 19.094-148.693 57.28-214.187 38.08-65.28 89.814-117.013 155.307-155.306C363.2 104.533 434.56 85.333 512 85.333c77.333 0 148.693 19.094 214.187 57.28 65.28 38.187 117.013 89.92 155.2 155.2z m-217.707-47.36C617.387 223.467 566.827 209.92 512 209.92s-105.387 13.547-151.68 40.533-82.987 63.68-109.973 109.974c-26.987 46.293-40.534 96.853-40.534 151.68s13.547 105.386 40.534 151.68c26.986 46.293 63.68 82.986 109.973 109.973 46.293 26.987 96.853 40.533 151.68 40.533s105.387-13.546 151.68-40.533c46.293-26.987 82.987-63.68 109.973-109.973 26.987-46.294 40.534-96.854 40.534-151.68s-13.547-105.387-40.534-151.68c-27.093-46.294-63.786-82.987-109.973-109.974z`,
        orient: 'vertical',
        data: nameArray,
        left: '45%',
        top: 'center',
        align: 'left',
        itemGap: 15,
        textStyle: {
            color: "#fff",
            fontSize: 14,
            rich: {
                a0: {
                    color: colorList[0][1],
                },
                a1: {
                    color: colorList[1][1],
                },
                a2: {
                    color: colorList[2][1],
                },
                a3: {
                    color: colorList[3][1],
                },
                b: {
                    color: '#fff',
                    width:90
                }
            }
        },
        formatter: function (name) {
            if (trafficWay.length) {
                let title = ''
                var target
                var index
                for (var i = 0, l = trafficWay.length; i < l; i++) {
                    if (trafficWay[i].name == name) {
                        target = trafficWay[i].value
                        title = trafficWay[i].label
                        index = i < 6 ? i : 5
                    }
                }
                return `{b| ${name}}{a${index}| ${target}} 个`
            }
        }
    },
    toolbox: {
        show: false
    },
    series: [{
        itemStyle: {
            normal: {
                color: function (params) {
                    return new echarts.graphic.LinearGradient(0, 0, 1, 1, [
                        {
                            offset: 0,
                            color: colorList[params.dataIndex][0],
                        },
                        {
                            offset: 1,
                            color: colorList[params.dataIndex][1],
                        },
                    ]);
                },
            },
        },
        roseType: 'radius',
        labelLine: {
            show: false,
        },
        label: {
            show: false
        },
        hoverAnimation: true,
        type: 'pie',
        radius: [30, 84],
        center: ['26%', '50%'],
        data: trafficWay,
        z: 10,
    },]
}