Javascript 使用海图的蝴蝶图
我正在尝试使用海图创建一个蝴蝶图。我想把它画成 代码如下Javascript 使用海图的蝴蝶图,javascript,highcharts,Javascript,Highcharts,我正在尝试使用海图创建一个蝴蝶图。我想把它画成 代码如下 // Data gathered from http://populationpyramid.net/germany/2015/ $(function () { // Age categories var categories = ['0-4', '5-9', '10-14', '15-19', '20-24', '25-29', '30-34', '35-39', '40-44', '45-49', '
// Data gathered from http://populationpyramid.net/germany/2015/
$(function () {
// Age categories
var categories = ['0-4', '5-9', '10-14', '15-19',
'20-24', '25-29', '30-34', '35-39', '40-44',
'45-49', '50-54', '55-59', '60-64', '65-69',
'70-74', '75-79', '80-84', '85-89', '90-94',
'95-99', '100 + '];
$(document).ready(function () {
Highcharts.chart('container', {
chart: {
type: 'bar'
},
title: {
text: 'Population pyramid for Germany, 2015'
},
subtitle: {
text: 'Source: <a href="http://populationpyramid.net/germany/2015/">Population Pyramids of the World from 1950 to 2100</a>'
},
xAxis: [{
categories: categories,
reversed: false,
labels: {
step: 1
}
}, /*{ // mirror axis on right side
opposite: true,
reversed: false,
categories: categories,
linkedTo: 0,
labels: {
step: 1
}
}*/],
yAxis: {
title: {
text: null
},
labels: {
formatter: function () {
return Math.abs(this.value) + '%';
}
}
},
plotOptions: {
series: {
stacking: 'normal'
}
},
tooltip: {
formatter: function () {
return '<b>' + this.series.name + ', age ' + this.point.category + '</b><br/>' +
'Population: ' + Highcharts.numberFormat(Math.abs(this.point.y), 0);
}
},
series: [{
name: 'Male',
data: [-2.2, -2.2, -2.3, -2.5, -2.7, -3.1, -3.2,
-3.0, -3.2, -4.3, -4.4, -3.6, -3.1, -2.4,
-2.5, -2.3, -1.2, -0.6, -0.2, -0.0, -0.0]
}, {
name: 'Female',
data: [2.1, 2.0, 2.2, 2.4, 2.6, 3.0, 3.1, 2.9,
3.1, 4.1, 4.3, 3.6, 3.4, 2.6, 2.9, 2.9,
1.8, 1.2, 0.6, 0.1, 0.0]
}]
});
});
});
这是我的小提琴,我怎样才能在系列之间得到我的xAxis标签。请指导我实现这一点。将图表与插件相结合是一种方法。列范围图表允许您指定列的位置并为标签留出空间。插件将轴移动到图表的中心
Highcharts.chart('container', {
title: {
text: 'Butterfly Chart Example'
},
subtitle: {
text: '<a href="http://stackoverflow.com">stackoverflow.com</a>'
},
chart: {
type: 'columnrange',
inverted: true,
marginTop: 100
},
legend: {
verticalAlign: 'top',
y: 60,
x: -25,
itemDistance: 50
},
xAxis: {
categories: ['G7', 'A8', 'V9', 'V4', 'V3', 'V1', 'V5'],
crossing: 118,
lineWidth: 0,
tickLength: 0,
},
yAxis: {
gridLineWidth: 0,
tickInterval: 50,
min: 0,
max: 250,
lineWidth: 1,
title: {
text: null
}
},
plotOptions: {
series: {
grouping: false
}
},
series: [{
name: 'South',
color: 'blue',
data: [
[55, 100],
[60, 100],
[65, 100],
[55, 100],
[75, 100],
[52, 100],
[60, 100]
]
}, {
name: 'North',
color: 'orange',
data: [
[120, 170],
[120, 150],
[120, 175],
[120, 130],
[120, 125],
[120, 148],
[120, 145]
]
}]
});
示例:图表与插件相结合是一种方法。列范围图表允许您指定列的位置并为标签留出空间。插件将轴移动到图表的中心
Highcharts.chart('container', {
title: {
text: 'Butterfly Chart Example'
},
subtitle: {
text: '<a href="http://stackoverflow.com">stackoverflow.com</a>'
},
chart: {
type: 'columnrange',
inverted: true,
marginTop: 100
},
legend: {
verticalAlign: 'top',
y: 60,
x: -25,
itemDistance: 50
},
xAxis: {
categories: ['G7', 'A8', 'V9', 'V4', 'V3', 'V1', 'V5'],
crossing: 118,
lineWidth: 0,
tickLength: 0,
},
yAxis: {
gridLineWidth: 0,
tickInterval: 50,
min: 0,
max: 250,
lineWidth: 1,
title: {
text: null
}
},
plotOptions: {
series: {
grouping: false
}
},
series: [{
name: 'South',
color: 'blue',
data: [
[55, 100],
[60, 100],
[65, 100],
[55, 100],
[75, 100],
[52, 100],
[60, 100]
]
}, {
name: 'North',
color: 'orange',
data: [
[120, 170],
[120, 150],
[120, 175],
[120, 130],
[120, 125],
[120, 148],
[120, 145]
]
}]
});
示例:我会用与摩根不同的方法来处理这个问题,尽管这个示例确实很有用 我将以标准条形图的形式进行此操作,使用多个yAxis对象,每个系列一个,这也允许使用左向系列的反转属性 代码示例: 小提琴: 示例输出:
我会用不同于摩根的方式来处理这个问题,尽管这个例子确实很有用 我将以标准条形图的形式进行此操作,使用多个yAxis对象,每个系列一个,这也允许使用左向系列的反转属性 代码示例: 小提琴: 示例输出:
您好@jlriggs,我们可以有一个轴标签,这样它们可以容纳超过10个字符的类别名称。Plz检查此小提琴轴标签的可用空间完全取决于yAxis位置设置。如果更改“宽度”和“左侧”设置,可以根据需要创建任意多或任意小的空间。此外,如果您将标签居中,无论是通过CSS还是使用useHTML功能,他们都会更好地利用空间。只需强调,条形图中具有两个轴的比例和列范围是不同的-数据故事也是不同的,即使图表看起来也很相似。这是一个很好的图表,虽然-表示的数据比图片中的图表要干净得多。@GeekExplorer,morganfree-很好的一点是,我的示例中的每个轴都有不同的比例。此类图表中的两个y轴应始终具有相同的比例。我用一个代码片段更新了代码,将每个轴的最大值设置为两个数据集的最大值,根据您之前的评论更新了轴间距和标签设置,并更新了附加的图像和提琴。非常感谢@jlbriggHi@jlriggs,我们可以有一个轴标签,以便它们可以容纳超过10个字符的类别名称吗。Plz检查此小提琴轴标签的可用空间完全取决于yAxis位置设置。如果更改“宽度”和“左侧”设置,可以根据需要创建任意多或任意小的空间。此外,如果您将标签居中,无论是通过CSS还是使用useHTML功能,他们都会更好地利用空间。只需强调,条形图中具有两个轴的比例和列范围是不同的-数据故事也是不同的,即使图表看起来也很相似。这是一个很好的图表,虽然-表示的数据比图片中的图表要干净得多。@GeekExplorer,morganfree-很好的一点是,我的示例中的每个轴都有不同的比例。此类图表中的两个y轴应始终具有相同的比例。我用一个片段更新了代码,将每个轴的最大值设置为两个数据集的最大值,根据您之前的评论更新了轴间距和标签设置,并更新了附加的图像和小提琴。非常感谢@jlbigas您的同意,我觉得@jlbiggs answer讲述了整个故事,感谢您的帮助,像你这样的人激励我去做这些不同的工作。非常感谢你们:正如你们所同意的,我觉得@jlbigs的回答讲述了整个故事,并感谢你们帮助我的努力,像你们这样的人激励我去完成这些不同的任务。非常感谢你: