四分之三圆环

描述:当前是关于Echarts图表中的 饼图 示例。
 
            let cur_chart_data = [
    {
        name: '80分以下',
        value: 2,
        unit: '家',
    },
    {
        name: '80-90分',
        value: 12,
        unit: '家',
    },
    {
        name: '90分以上',
        value: 14,
        unit: '家',
    },
];

let dashedPic =
        '',
    color = ['#FFC438', '#01CBCF', '#128DFE', '#009DFF'],
    arrName = [],
    arrValue = [],
    sum = 0,
    pieSeries = [],
    lineYAxis = [],
    chartData;

chartData = cur_chart_data;

// 数据处理
chartData &&
    chartData.forEach((v, i) => {
        arrName.push(v.name);
        arrValue.push(v.value);
        sum = sum + v.value;
    });

// 图表option整理
chartData.forEach((v, i) => {
    pieSeries.push({
        name: '评价',
        type: 'pie',
        clockWise: true, //顺时加载
        hoverAnimation: false, //鼠标移入变大
        radius: [90 - i * 25 + '%', 75 - i * 25 + '%'],
        center: ['30%', '50%'],
        label: {
            show: false,
        },
        data: [
            { value: v.value, name: v.name },
            {
                value: sum - v.value,
                name: '',
                itemStyle: {
                    color: 'rgba(0,0,0,0)',
                },
            },
        ],
    });
    pieSeries.push({
        name: '',
        type: 'pie',
        silent: true,
        z: 1,
        clockWise: true, //顺时加载
        hoverAnimation: false, //鼠标移入变大
        radius: [90 - i * 25 + '%', 75 - i * 25 + '%'],
        center: ['30%', '50%'],
        label: {
            show: false,
        },
        data: [
            {
                value: 7.5,
                itemStyle: {
                    color: '#E3F0FF',
                },
            },
            {
                value: 2.5,
                name: '',
                itemStyle: {
                    color: 'rgba(0,0,0,0)',
                },
            },
        ],
    });
    v.percent = ((v.value / sum) * 100).toFixed(1) + '%';
    lineYAxis.push({
        value: i,
        textStyle: {
            rich: {
                circle: {
                    color: color[i],
                    padding: [0, 5],
                },
            },
        },
    });
});

option = {
    grid: {
        top: '10%',
        bottom: '54%',
        left: '30%',
        containLabel: false,
    },
    backgroundColor: '#fff',
    color: color,
    yAxis: [
        {
            type: 'category',
            inverse: true,
            axisLine: {
                show: false,
            },
            axisTick: {
                show: false,
            },
            axisLabel: {
                top: '30%',
                padding: [0, 0, 95, -180],
                formatter: function (params) {
                    let item = chartData[params];
                    // console.log(item)
                    return '{circle|●}{name|' + item.name + '}{value|' + item.value + '家  }{line|}';
                },
                interval: 0,
                inside: true,
                textStyle: {
                    color: '#333',
                    fontSize: 1486,
                    rich: {
                        line: {
                            width: 30,
                            height: 10,
                            backgroundColor: { image: dashedPic },
                        },
                        name: {
                            color: '#666',
                            fontSize: 16,
                        },
                        value: {
                            color: '#333',
                            fontSize: 16,
                            fontWeight: 'bold',
                            padding: [0, 0, 0, 6],
                        },
                    },
                },
                show: true,
            },
            data: lineYAxis,
        },
    ],
    xAxis: [
        {
            show: false,
        },
    ],
    title: {
        text: '小小标题直接展示',
        textStyle: {
            label: {
                normal: {
                    show: true,
                    formatter: ['The whole box is a {term|Text Block}, with'].join('\n'),
                    backgroundColor: '#eee',
                    // borderColor: '#333',
                    borderColor: 'rgb(199,86,83)',
                    borderWidth: 2,
                    borderRadius: 5,
                    padding: 10,
                    color: '#000',
                    fontSize: 14,
                    shadowBlur: 3,
                    shadowColor: '#888',
                    shadowOffsetX: 0,
                    shadowOffsetY: 3,
                    lineHeight: 30,
                    rich: {
                        term: {
                            fontSize: 18,
                            color: 'rgb(199,86,83)',
                        },
                    },
                },
            },
        },
    },
    series: pieSeries,
};