我使用AmCharts显示两个数据集,表示每两种文件类型的下载次数:pdf和xls。该图表类似于可用的图表 https://www.amcharts.com/demos/multiple-data-sets/,但我将“重新计算ToTercents”选项设置为“永远不会”。始终显示比较系列的实际下载次数。我是按小时使用的。
我遇到的问题是,在第一个文件类型(主数据集)的特定小时内没有下载的情况下,第二个文件类型的值也不显示,即使下载次数超过0第二种文件类型。
amCharts是否可以显示主数据集中不存在的日期的比较系列的值?
答案 0 :(得分:1)
使用此迷你插件,如果您的图表配置中设置了syncDataTimestamps: true
,它将预处理您的数据,并将缺少的“空”数据点添加到主数据集,以便所有数据点来自所有显示数据集,即使它们的时间戳不重叠:
/**
* amCharts plugin: sync timestamps of the data sets
* ---------------
* Will work only if syncDataTimestamps is set to true in chart config
*/
AmCharts.addInitHandler(function(chart) {
// check if plugin is enabled
if (chart.syncDataTimestamps !== true)
return;
// go thorugh all data sets and collect all the different timestamps
var dates = {};
for (var i = 0; i < chart.dataSets.length; i++) {
var ds = chart.dataSets[i];
for (var x = 0; x < ds.dataProvider.length; x++) {
var date = ds.dataProvider[x][ds.categoryField];
if (dates[date.getTime()] === undefined)
dates[date.getTime()] = {};
dates[date.getTime()][i] = ds.dataProvider[x];
}
}
// iterate through data sets again and fill in the blanks
for (var i = 0; i < chart.dataSets.length; i++) {
var ds = chart.dataSets[i];
var dp = [];
for (var ts in dates) {
if (!dates.hasOwnProperty(ts))
continue;
var row = dates[ts];
if (row[i] === undefined) {
row[i] = {};
var d = new Date();
d.setTime(ts);
row[i][ds.categoryField] = d;
}
dp.push(row[i]);
}
dp.sort(function(a,b){
return new Date(a[ds.categoryField]) - new Date(b[ds.categoryField]);
});
ds.dataProvider = dp;
}
}, ["stock"]);