饼图

描述:当前是关于Echarts图表中的 饼图 示例。
 
            let imgSrc = '';
let chartData = [
    {
        value: 520,
        name: '幼儿园',
    },
    {
        value: 280,
        name: '小学',
    },
    {
        value: 100,
        name: '初中',
    },
    {
        value: 100,
        name: '高中',
    },
];
let colorList = ['#115FEA', '#10EBE3', '#10A9EB', '#EB9C10', '#2E10EB', '#9B10EB'];
let sum = chartData.reduce((per, cur) => per + cur.value, 0);
let gap = 1 * sum / 100;
let pieData1 = [];
let pieData2 = [];
let gapData = {
    name: '',
    value: gap,
    itemStyle: {
        color: 'transparent',
    },
};
for (let i = 0; i < chartData.length; i++) {
    // 第一圈数据
    pieData1.push({
        ...chartData[i],
        itemStyle: {
              borderRadius: 10
            }
        });
    pieData1.push(gapData);

    // 第二圈数据
    pieData2.push({
        ...chartData[i],
        itemStyle: {
            color: colorList[i],
            opacity: 0.1,
        },
    });
    pieData2.push(gapData);
}
console.log(pieData2);
option = {
    backgroundColor: '#000',
    tooltip: {
        show: false,
        backgroundColor: 'rgba(17,95,234,0.5)',
        textStyle: {
            color: '#F0F0F0',
        },
    },
    legend: {
        show: true,
        right: 'right',
        top: 'center',

        icon: 'rect',
        itemWidth: 4,
        itemHeight: 20,
        textStyle: {
            color: '#F0F0F0',
            rich: {
                name: {
                    padding: [0, 10, 0, 8],
                    color: '#fff',
                    fontSize: 16,
                },
                percent: {
                    padding: [0, 0, 0, 8],
                    color: '#fff',
                },
            },
        },
        formatter: (name) => {
            console.log(name);
            console.log(chartData);
            let item = chartData.find((i) => {
                return i.name == name;
            });
            let p = ((item.value / sum) * 100).toFixed(0);
            return '{name|' + name + '}' + '{percent|' + p + '}' + '%';
        },
    },
    graphic: {
        elements: [{
            type: "image",
            z: 3,
            style: {
                image: imgSrc,
                width: 70,
                height: 70,
            },
            top: 'middle',
            left: 'center',
            scale: [1.5,1.5]
        }]
    },
    grid: {
        top: 35,
        right: 30,
        bottom: 20,
        left: 30,
    },
    color: colorList,
    series: [
        {
            name: '消息来源',
            type: 'pie',
            roundCap: true,
            radius: ['76%', '80%'],
            center: ['50%', '50%'],
            label: {
                show: false,
            },
            labelLine: {
                show: false,
            },
            data: pieData1,
        },
        {
            type: 'pie',
            radius: ['76%', '64%'],
            center: ['50%', '50%'],
            gap: 1.71,
            label: {
                show: false,
            },
            labelLine: {
                show: false,
            },
            silent: true,
            data: pieData2,
        },
        {
            type: 'pie',
            center: ['50%', '50%'],
            radius: [0, '45.6%'],
            label: {
                show: false,
            },
            labelLine: {
                show: false,
            },
            itemStyle: {
                color: 'rgba(5,37,95,0.3)',
            },
            silent: true,
            data: [
                {
                    value: 100,
                    name: '',
                },
            ],
        },
    ],
};