如何使用Google Chart在v轴上显示基线值?

时间:2017-09-24 23:29:20

标签: javascript charts google-visualization

我在Google Chart中为v轴添加基线。

vAxis: {
      title: 'Popularity', baseline: 20, baselineColor: 'red'
    }

enter image description here

我想像这样展示基线的价值。

enter image description here

我该怎么做?

这是jsfiddle中的完整代码。 https://jsfiddle.net/ztn5fmnw/

1 个答案:

答案 0 :(得分:1)

需要更多选项才能完全像发布的图片一样

但首先,需要在数据表中添加另一列
新栏目中不需要任何数据,
只需在加载原始数据后添加

data.addColumn('number', 'y1');

新系列将被分配到第二个y轴(右侧)
这将允许自定义第二个y轴

series: {
  1: {
    targetAxisIndex: 1,     // <-- assign y1 to second y-axis
    visibleInLegend: false  // <-- hide from legend
  }
},

接下来,两个y轴都需要相同的范围
使用vAxis.viewWindow设置两者的范围

vAxis: {
  title: 'Popularity', baseline: 20, baselineColor: 'red',
  viewWindow: {
    min: 0,
    max: 100
  }
},

然后使用vAxes选项仅自定义第二个y轴
使用ticks添加基线的值

vAxes: {
  1: {
    textStyle: {
      color: 'red'
    },
    ticks: [20]
  }
}

请参阅以下工作代码段...

google.charts.load('current', {
  packages: ['corechart']
}).then(function () {
  var data = new google.visualization.DataTable();
  data.addColumn('number', 'X');
  data.addColumn('number', 'y0');
  data.addRows([
    [0, 0],   [1, 10],  [2, 23],  [3, 17],  [4, 18],  [5, 9],
    [6, 11],  [7, 27],  [8, 33],  [9, 40],  [10, 32], [11, 35],
    [12, 30], [13, 40], [14, 42], [15, 47], [16, 44], [17, 48],
    [18, 52], [19, 54], [20, 42], [21, 55], [22, 56], [23, 57],
    [24, 60], [25, 50], [26, 52], [27, 51], [28, 49], [29, 53],
    [30, 55], [31, 60], [32, 61], [33, 59], [34, 62], [35, 65],
    [36, 62], [37, 58], [38, 55], [39, 61], [40, 64], [41, 65],
    [42, 63], [43, 66], [44, 67], [45, 69], [46, 69], [47, 70],
    [48, 72], [49, 68], [50, 66], [51, 65], [52, 67], [53, 70],
    [54, 71], [55, 72], [56, 73], [57, 75], [58, 70], [59, 68],
    [60, 64], [61, 60], [62, 65], [63, 67], [64, 68], [65, 69],
    [66, 70], [67, 72], [68, 75], [69, 80]
  ]);
  data.addColumn('number', 'y1');

  var options = {
    hAxis: {
      title: 'Time'
    },
    series: {
      1: {
        targetAxisIndex: 1,
        visibleInLegend: false
      }
    },
    vAxis: {
      title: 'Popularity', baseline: 20, baselineColor: 'red',
      viewWindow: {
        min: 0,
        max: 100
      }
    },
    vAxes: {
      1: {
        textStyle: {
          color: 'red'
        },
        ticks: [20]
      }
    }
  };

  var chart = new google.visualization.LineChart(document.getElementById('chart_div'));
  chart.draw(data, options);
});
<script src="https://www.gstatic.com/charts/loader.js"></script>
<div id="chart_div"></div>