链路利用率Top5echarts radial配置项内容和展示

花里胡哨的排序图

配置项如下
      option = commonEchartOption_4(
    ['#9fb9e3', 21, '链路利用率Top5', '5%'],
    [
        ['15%', '10%', '53%', '5'],
        ['15%', '55%', '7%', '5'],
    ],
    [
        [1020, 0],
        [1060, 1],
    ],
    [
        [
            'category',
            'left',
            [-5, 0, 0, 0],
            [-70, 0, 0, 12],
            '#9FB9E3',
            16,
            35,
            0,
            'left',
            [-32, -30, 0, 0],
            14,
            [true, [32, -30, 0, 0]],
        ],
        [
            'category',
            'left',
            [-5, 0, 0, 0],
            [-70, 0, 0, 10],
            '#9FB9E3',
            16,
            5,
            1,
            'left',
            [-32, -20, 0, 0],
            14,
            [true, [32, -20, 0, 0]],
        ],
    ],
    [
        [
            '一平面入口流量',
            '8%',
            '#00D4FF',
            '#00D4FF',
            0,
            0,
            ['40%', ['80%', '100%'], ['0%', '0%']],
            [true, '进', '#00D4FF'],
        ],
        [
            '一平面出口流量',
            '8%',
            '#34E598',
            '#34E598',
            0,
            0,
            ['40%', ['80%', '100%'], ['0%', '0%']],
            [true, '出', '#34E598'],
        ],
        [
            '二平面入口流量',
            '8%',
            '#00D4FF',
            '#00D4FF',
            1,
            3,
            ['40%', ['80%', '100%'], ['0%', '0%']],
            [true, '进', '#00D4FF'],
        ],
        [
            '二平面出口流量',
            '8%',
            '#34E598',
            '#34E598',
            1,
            3,
            ['40%', ['80%', '100%'], ['0%', '0%']],
            [true, '出', '#34E598'],
        ],
    ],
    5,
    'Mb',
    true
);
option.yAxis[0].data = ['xx站(一平面)', 'xx站(一平面)', 'xx站(一平面)', 'xx站(一平面)', 'xx站(一平面)'];
option.series[0].data = [360, 420, 534, 635, 800];
option.series[1].data = [400, 434, 335, 260, 220];
option.yAxis[1].data = [360, 420, 534, 635, 800];
option.yAxis[2].data = [400, 434, 335, 260, 220];
option.yAxis[3].data = ['xx站(二平面)', 'xx站(二平面)', 'xx站(二平面)', 'xx站(二平面)', 'xx站(二平面)'];
option.series[2].data = [360, 420, 534, 635, 800];
option.series[3].data = [400, 434, 335, 260, 220];
option.yAxis[4].data = [360, 420, 534, 635, 800];
option.yAxis[5].data = [400, 434, 335, 260, 220];

function commonEchartOption_4(
    titleobj,
    gridobj,
    xaisobj,
    yaisobj,
    seriesobj,
    datalength,
    dwval,
    pmimgbool,
    serieslabobj
) {
    var option = {};
    option['backgroundColor'] = {
        type: 'radial',
        x: 0.5,
        y: 0.5,
        r: 0.5,
        colorStops: [
            {
                offset: 0,
                color: '#0f2660',
            },
            {
                offset: 1,
                color: '#020712',
            },
        ],
        global: false,
    };
    option['title'] = {
        text: titleobj[2] ? titleobj[2] : '统计分析图',
        textStyle: { fontFamily: '宋体', fontWeight: 'bolder', color: titleobj[0], fontSize: titleobj[1] },
        left: titleobj[5] ? titleobj[5] : 'center',
    };
    if (titleobj[3]) {
        option.title.top = titleobj[3];
    }
    var gridarr = [];
    for (var i = 0; i < gridobj.length; i++) {
        gridarr.push({ top: gridobj[i][0], left: gridobj[i][1], right: gridobj[i][2], bottom: gridobj[i][3] });
    }
    option['grid'] = gridarr;
    option['tooltip'] = { show: false };
    var xaisarr = [];
    for (var i = 0; i < xaisobj.length; i++) {
        xaisarr.push({
            type: 'value',
            gridIndex: xaisobj[i][1],
            axisLine: { show: false },
            max: xaisobj[i][0],
            splitLine: { show: false },
            axisLabel: { show: false },
            axisTick: { show: false },
        });
    }
    option['xAxis'] = xaisarr;
    serieslabobj = serieslabobj ? serieslabobj : [];
    var yaisarr = [];
    for (var i = 0; i < yaisobj.length; i++) {
        yaisarr.push({
            type: yaisobj[i][0],
            offset: yaisobj[i][6],
            splitLine: { show: false },
            axisLine: { show: false },
            axisLabel: {
                show: true,
                align: yaisobj[i][1],
                padding: yaisobj[i][2],
                textStyle: { color: yaisobj[i][4], fontSize: yaisobj[i][5] },
                formatter: function (params, index) {
                    if (index == datalength - 1) {
                        return '{b|}' + '{name|' + params + '}';
                    } else {
                        return '{c|' + (datalength - index) + '}' + '{name|' + params + '}';
                    }
                },
                rich: {
                    b: {
                        backgroundColor: {
                            image:
                                '',
                        },
                        width: 29,
                        height: 29,
                        align: 'center',
                    },
                    c: {
                        color: '#FFFFFF',
                        width: 29,
                        height: 29,
                        align: 'center',
                        verticalAlign: 'center',
                        backgroundColor: {
                            image:
                                '',
                        },
                        fontSize: yaisobj[i][5],
                    },
                    name: { color: '#9FB9E3', fontSize: yaisobj[i][5], padding: yaisobj[i][3] },
                },
            },
            axisTick: { show: false },
            gridIndex: yaisobj[i][7] ? yaisobj[i][7] : 0,
            position: yaisobj[i][8] ? yaisobj[i][8] : 'left',
        });
        yaisarr.push({
            type: 'category',
            gridIndex: yaisobj[i][7] ? yaisobj[i][7] : 0,
            position: 'right',
            axisTick: { show: false },
            axisLine: { show: false },
            axisLabel: {
                show: true,
                align: 'right',
                fontSize: yaisobj[i][5],
                formatter: function (params) {
                    return '{name|' + params + dwval + '}';
                },
                rich: { name: { color: '#9FB9E3', width: 100, fontSize: yaisobj[i][10], padding: yaisobj[i][9] } },
            },
        });
        if (yaisobj[i][11] && yaisobj[i][11][0]) {
            yaisarr.push({
                type: 'category',
                gridIndex: yaisobj[i][7] ? yaisobj[i][7] : 0,
                position: 'right',
                axisTick: { show: false },
                axisLine: { show: false },
                axisLabel: {
                    show: true,
                    align: 'right',
                    fontSize: yaisobj[i][5],
                    formatter: function (params) {
                        return '{name|' + params + dwval + '}';
                    },
                    rich: {
                        name: { color: '#9FB9E3', width: 100, fontSize: yaisobj[i][10], padding: yaisobj[i][11][1] },
                    },
                },
            });
        }
    }
    option['yAxis'] = yaisarr;
    var seriesarr = [];
    for (var i = 0; i < seriesobj.length; i++) {
        var objseriesv = {
            name: seriesobj[i][0],
            xAxisIndex: seriesobj[i][4],
            yAxisIndex: seriesobj[i][5],
            barGap: '220%',
            barCategoryGap: '5%',
            barWidth: seriesobj[i][1],
            type: 'pictorialBar',
            xAxisIndex: seriesobj[i][4],
            yAxisIndex: seriesobj[i][5],
            symbol: 'rect',
            symbolMargin: seriesobj[i][6][0],
            symbolSize: seriesobj[i][6][1],
            symbolOffset: seriesobj[i][6][2],
            symbolRepeat: true,
            itemStyle: {
                color: {
                    type: 'linear',
                    x: 0,
                    y: 0,
                    x2: 1,
                    y2: 0,
                    colorStops: [
                        { offset: 0, color: seriesobj[i][2] },
                        { offset: 1, color: seriesobj[i][3] },
                    ],
                    global: false,
                },
            },
            z: 2,
        };
        if (seriesobj[i][7] && seriesobj[i][7][0]) {
            objseriesv['label'] = {
                show: seriesobj[i][7][0],
                position: 'left',
                offset: serieslabobj[0] ? serieslabobj[0] : [-64, 0],
                padding: serieslabobj[1] ? serieslabobj[1] : [0, 0, 0, 295],
                borderWidth: 1,
                borderColor: serieslabobj[2] ? serieslabobj[2] : '#1F2C83',
                distance: serieslabobj[3] ? serieslabobj[3] : -370,
                color: seriesobj[i][7][2] ? seriesobj[i][7][2] : '#9FB9E3',
                fontSize: serieslabobj[4] ? serieslabobj[4] : 13,
                formatter: seriesobj[i][7][1],
            };
        }
        seriesarr.push(objseriesv);
    }
    option['series'] = seriesarr;
    if (pmimgbool && option.yAxis.length >= 2) {
        for (var j = 1; j < option.yAxis.length; j++) {
            if (option.yAxis[j].position == 'left') {
                option.yAxis[j].axisLabel.formatter = function (params, index) {
                    return '{name|' + params + '}';
                };
            }
        }
    }
    return option;
}

    
截图如下