AmCharts - 比较缺少值

时间:2016-08-18 08:19:38

标签: amcharts amstock

我使用AmCharts显示两个数据集,表示每两种文件类型的下载次数:pdf和xls。该图表类似于可用的图表 https://www.amcharts.com/demos/multiple-data-sets/,但我将“重新计算ToTercents”选项设置为“永远不会”。始终显示比较系列的实际下载次数。我是按小时使用的。

我遇到的问题是,在第一个文件类型(主数据集)的特定小时内没有下载的情况下,第二个文件类型的值也不显示,即使下载次数超过0第二种文件类型。

amCharts是否可以显示主数据集中不存在的日期的比较系列的值?

1 个答案:

答案 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"]);

这取自this amCharts demo