有角度的环状图

描述:当前是关于Echarts图表中的 示例。
 
             var imgurl = 'image://';
        var mainData = [];
        mainData.push({
            name: '充值收入',
            value: 342305,
            prevalue: 382305,
            hismax: 455898,
            per: '25%'
        });
        mainData.push({
            name: '包月收入',
            value: 1332042,
            prevalue: 1552305,
            hismax: 1896900,
            per: '25%'
        });
        mainData.push({
            name: '道具消费',
            value: 305652,
            prevalue: 323305,
            hismax: 446783,
            per: '25%'
        });
        mainData.push({
            name: '新增用户',
            value: 31861,
            prevalue: 30805,
            hismax: 77598,
            per: '25%'
        });
        mainData.push({
            name: '活跃用户',
            value: 114553,
            prevalue: 120105,
            hismax: 145898,
            per: '25%'
        });
        function createSeries(mainData) {
            var result = [];
            var insideLabel = {
                normal: {
                    position: 'center',
                    formatter: function(params) {
                        if (params.name == "other")
                            return "";
                        var str = '';

                        for (var i = 0; i < params.name.length; i++) {
                            console.log(params.name[i])
                            str += params.name[i];
                            if ((i + 1) % 2 == 0) { str += '\n'; }
                        }
                        return str;
                    },
                    textStyle: {
                        fontStyle: 'normal',
                        fontWeight: 'normal',
                        fontSize: 12,
                        color: '#666'
                    }
                }
            };
            var outsideLabel = {
                normal: {
                    show: false
                }
            };
            var itemOthers = {
                normal: {
                    color: '#eee'
                }
            };
            for (var i = 0; i < mainData.length; i++) {
                var increase = mainData[i].value > mainData[i].prevalue;
                result.push({
                    type: 'pie',
                    center: [i * 20 + 10 + '%', 30 + (i - 2) * (i - 2) * 5 + '%'],
                    radius: ['20%', '22%'],
                    label: insideLabel,
                    angleAxis: {
                        clockwise: true
                    },
                    data: [{
                        name: mainData[i].name,
                        value: mainData[i].value,
                        // prevalue: mainData[i].prevalue
                    },{
                        name: 'other',
                        value: mainData[i].hismax - mainData[i].value,
                        itemStyle: itemOthers
                    }],
                    markPoint: {
                        data: [{
                            symbol: '',
                            symbolSize: 15,
                            // symbolRotate: increase ? 0 : 180,
                            itemStyle: {
                                normal: {
                                    color: 'transparent'
                                }
                            },
                            // name: mainData[i].name,
                            value: mainData[i].per,
                            x:  i * 20 + 9 + '%',
                            y: 14 + (i - 2) * (i - 2) * 5 + '%',
                            label: {
                                normal: {
                                    show: true,
                                    position: 'cener',
                                    formatter: function(params) {
                                        return params.value;
                                    },
                                    textStyle: {
                                        color: '#333'
                                    }
                                }
                            },
                        }]
                    }
                });
            }
            var youxiji = {
                name: 'hill',
                type: 'pictorialBar',
                symbolSize: ['20%', '25%'],
                barCategoryGap: '-50%',
                symbolOffset: [0, '-50%'],
                symbol: imgurl,
                label: {
                    normal: {
                        show: true,
                        position: 'top',
                        color: '#333'
                    }
                },
                data: ['1'],
                z: 10,
                itemStyle: {
                    normal: {
                        opacity: 0.8,
                        //每根柱子颜色设置
                        color: function(params) {
                            let colorList = [
                                "#1cd389",
                                "#668eff",
                                "#ffc751",
                                "#5bd1ff",
                                "#ff6e72",
                                "#16c1af",
                                "#9692ff",
                                "#eeeeee",
                            ];
                            return colorList[params.dataIndex];
                        }
                    },
                    emphasis: {
                        opacity: 1
                    }
                },
            }
            result.push(youxiji)
            return result;
        }
        var option = {
            backgroundColor: '#fff',

            xAxis: {
                data: ['a'],
                axisTick: {
                    show: false
                },
                axisLine: {
                    show: false
                },
                axisLabel: {
                    show: false
                }
            },
            yAxis: {
                splitLine: {
                    show: false
                },
                axisTick: {
                    // 刻度线
                    show: false
                },
                axisLine: {
                    // 轴线
                    show: false
                },
                axisLabel: {
                    // 轴坐标文字
                    show: false
                }
            },
            series: createSeries(mainData)
        }