如何为任意数量的系列创建等宽的 solidgauge?

How to create equal width solidgauge for any number of series?

我在使用 HighCharts 库创建 solidgauge 图表时遇到了一些问题。

我想让每个系列的宽度和它们的背景都相等,但无法正确理解 innerRadius、outerRadius、数据半径和窗格背景。

它应该灵活适应任何容器宽度。

jsfiddle here

JS:

function buildChartOptions(series)
    {
       var nextRadius = 50, dataRadiusDiff = 25, nextBgInnerRadius = 38, bgRadiusDiff = 24;
        this.options = {
            chart: {},
            title: {},
            tooltip: {},
            pane: {},
            yAxis: {},
            plotOptions: {},
            series: {},
        };

        this.options.chart = {
            type: 'solidgauge',
            marginTop: 50
        };

        this.options.title = {
            text: null,
            style: {
                fontSize: '24px',
            }
        };

        this.options.tooltip = {
            borderWidth: 0,
            backgroundColor: 'none',
            shadow: false,
            style: {
                fontSize: '12px'
            },
            pointFormat: '{series.name}<br><span style="padding:10px;font-size:2em; color: {point.color}; font-weight: bold">{point.y} %</span>',
            positioner: function (labelWidth, labelHeight) {
                return {
                    x: 200 - labelWidth / 2,
                    y: 180
                };
            }
        };

        var chartWidth = (100-(series.length * 8 )),
        borderWidth = (100 - 11.02 * series.length);
        chartWidth = chartWidth < 30 ? 35 : chartWidth;
        borderWidth = borderWidth < 10 ? 15: borderWidth;

        borderWidth = 34;

        console.log('chart ', chartWidth, 'border ', borderWidth);

        this.options.pane = {
            startAngle: -90,
            endAngle: 90,
            size: Math.abs(chartWidth) + '%',
            background: []
        };

        this.options.yAxis = {};

        this.options.plotOptions = {
            solidgauge: {
                borderWidth: borderWidth + 'px',
                dataLabels: {
                    enabled: false
                },
                linecap: 'square',
                stickyTracking: true
            }
        };

        this.options.series = [];

        for(var i=0; i<series.length; i++)
        {
            this.options.series.push({
                name: series[i].name,
                borderColor: Highcharts.getOptions().colors[i],
                data:[{
                    color: Highcharts.getOptions().colors[i],
                    radius: nextRadius+'%',
                    innerRadius: nextRadius+'%',
                    y: (i*10)+20
               }]
            });


            nextRadius += dataRadiusDiff;

            this.options.pane.background.push({
                outerRadius: parseInt(nextBgInnerRadius + bgRadiusDiff) + '%',
                innerRadius: nextBgInnerRadius+'%',
                backgroundColor: Highcharts.Color(Highcharts.getOptions().colors[i]).setOpacity(0.5).get(),
                borderWidth: 1,
                shape: 'arc'
            });

            nextBgInnerRadius += (bgRadiusDiff + 1);
        }

        this.options.series.reverse();
        this.options.pane.background.reverse();
        var chart = Highcharts.chart('container', this.options);
        return this.options;
    }


    var series = [
{name:'A',id :0, data:10, color:'#043310', bgcolor:'#033249'},
{name:'B',id :1, data:30, color:'#024230', bgcolor:'#134349'},
{name:'C',id :2, data:50, color:'#042210', bgcolor:'#022249'},
{name:'D',id :2, data:150, color:'#042210', bgcolor:'#022249'},
{name:'E',id :2, data:250, color:'#042210', bgcolor:'#022249'},
];/*
{name:'F',id :2, data:350, color:'#042210', bgcolor:'#022249'},
{name:'G',id :2, data:150, color:'#042210', bgcolor:'#022249'},
{name:'H',id :2, data:240, color:'#042210', bgcolor:'#022249'},
{name:'I',id :1, data:30, color:'#024230', bgcolor:'#134349'},
{name:'J',id :2, data:50, color:'#042210', bgcolor:'#022249'},
{name:'I',id :1, data:30, color:'#024230', bgcolor:'#134349'},
{name:'J',id :2, data:50, color:'#042210', bgcolor:'#022249'},
];*/

buildChartOptions(series);

有人可以帮我吗?

您不需要对不同容器的宽度进行额外计算,以应用等于所有窗格的 innerRadiusouterRadius 和所有系列的 radiusinnerRadius。如果你想要系列和窗格以相同的宽度显示并且你想动态设置它,你可以编写一个简单的函数并设置最小,最大半径并计算radiusStep。作为参考,请查看我在下面发布的示例。

API参考:
http://api.highcharts.com/highcharts/series%3Csolidgauge%3E.data.radius
http://api.highcharts.com/highcharts/series%3Csolidgauge%3E.data.innerRadius

示例:
http://jsfiddle.net/wt5Lp09r/