我很困惑......
我正在尝试创建一个具有多个Y轴的串行amchart,但我希望它们使用相同的X轴。 Amcharts.com有一个演示(http://www.amcharts.com/demos/multiple-value-axes/)
我已将我的输出放在JSfiddle上,供您查看:http://jsfiddle.net/2cMMF/3/ 如您所见,年份在X轴上显示两次,
我复制了这个脚本,但我似乎能够把它弄好。唯一不同的是chartData:
function generateChartData() {
var chartData = [];
var xAxis;
var yAxis;
@for(j <- 0 until totalAmountForms){
@for(i <- 0 until data.get(j).length) {
yAxis = @data.get(j).get(i)
xAxis = @label.get(j).get(i)
@if(j==0){
chartData.push({
values1: yAxis,
categories: xAxis
});
}
@if(j==1){
chartData.push({
values2: yAxis,
categories: xAxis
});
}
@if(j==2){
chartData.push({
values3: yAxis,
categories: xAxis
});
}
@if(j==3){
chartData.push({
values4: yAxis,
categories: xAxis
});
}
@if(j==4){
chartData.push({
values5: yAxis,
categories: xAxis
});
}
}
}
return chartData;
}
关于我在这里做错了什么的任何想法? 我也试过生成一次xAxis,但只是在图X轴上得到“未定义”。 这是我将xAxis提供给图表的地方:
"categoryField":"categories",
"categoryAxis": {
"parseDate": false,
"axisColor": "#DADADA",
"minorGridEnabled": true
}
我将Play框架与Scala一起使用(代码有效,编译,但没有正确显示图表)。
答案 0 :(得分:1)
答案是简单地将“值”与“类别”一起推送到chartData。 见下面的例子:
function generateChartData() {
var chartData = [];
var xAxis;
var yAxis1;
var yAxis2;
var yAxis3;
var yAxis4;
var yAxis5;
@if(totalAmountForms==1){
@for(i <- 0 until data.get(0).length) {
xAxis = @label.get(0).get(i)
yAxis1 = @data.get(0).get(i)
chartData.push({
values1: yAxis1,
categories: xAxis
});
}
}
@if(totalAmountForms==2){
@for(i <- 0 until data.get(1).length) {
xAxis = @label.get(0).get(i)
yAxis1 = @data.get(0).get(i)
yAxis2 = @data.get(1).get(i)
chartData.push({
values1: yAxis1,
values2: yAxis2,
categories: xAxis
});
}
}
@if(totalAmountForms==3){
@for(i <- 0 until data.get(2).length) {
xAxis = @label.get(0).get(i)
yAxis1 = @data.get(0).get(i)
yAxis2 = @data.get(1).get(i)
yAxis3 = @data.get(2).get(i)
chartData.push({
values1: yAxis1,
values2: yAxis2,
values3: yAxis3,
categories: xAxis
});
}
}
@if(totalAmountForms==4){
@for(i <- 0 until data.get(3).length) {
xAxis = @label.get(0).get(i)
yAxis1 = @data.get(0).get(i)
yAxis2 = @data.get(1).get(i)
yAxis3 = @data.get(2).get(i)
yAxis4 = @data.get(3).get(i)
chartData.push({
values1: yAxis1,
values2: yAxis2,
values3: yAxis3,
values4: yAxis4,
categories: xAxis
});
}
}
@if(totalAmountForms==5){
@for(i <- 0 until data.get(4).length) {
xAxis = @label.get(0).get(i)
yAxis1 = @data.get(0).get(i)
yAxis2 = @data.get(1).get(i)
yAxis3 = @data.get(2).get(i)
yAxis4 = @data.get(3).get(i)
yAxis5 = @data.get(4).get(i)
chartData.push({
values1: yAxis1,
values2: yAxis2,
values3: yAxis3,
values4: yAxis4,
values5: yAxis5,
categories: xAxis
});
}
}
return chartData;
}
不是我写过的最好的代码,但它现在有用......