如何为任意数量的系列创建等宽的 solidgauge?
How to create equal width solidgauge for any number of series?
我在使用 HighCharts 库创建 solidgauge 图表时遇到了一些问题。
我想让每个系列的宽度和它们的背景都相等,但无法正确理解 innerRadius、outerRadius、数据半径和窗格背景。
它应该灵活适应任何容器宽度。
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);
有人可以帮我吗?
您不需要对不同容器的宽度进行额外计算,以应用等于所有窗格的 innerRadius
、outerRadius
和所有系列的 radius
、innerRadius
。如果你想要系列和窗格以相同的宽度显示并且你想动态设置它,你可以编写一个简单的函数并设置最小,最大半径并计算radiusStep。作为参考,请查看我在下面发布的示例。
API参考:
http://api.highcharts.com/highcharts/series%3Csolidgauge%3E.data.radius
http://api.highcharts.com/highcharts/series%3Csolidgauge%3E.data.innerRadius
我在使用 HighCharts 库创建 solidgauge 图表时遇到了一些问题。
我想让每个系列的宽度和它们的背景都相等,但无法正确理解 innerRadius、outerRadius、数据半径和窗格背景。
它应该灵活适应任何容器宽度。
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);
有人可以帮我吗?
您不需要对不同容器的宽度进行额外计算,以应用等于所有窗格的 innerRadius
、outerRadius
和所有系列的 radius
、innerRadius
。如果你想要系列和窗格以相同的宽度显示并且你想动态设置它,你可以编写一个简单的函数并设置最小,最大半径并计算radiusStep。作为参考,请查看我在下面发布的示例。
API参考:
http://api.highcharts.com/highcharts/series%3Csolidgauge%3E.data.radius
http://api.highcharts.com/highcharts/series%3Csolidgauge%3E.data.innerRadius