javascript - 谷歌折线图中的可变背景颜色

标签 javascript charts google-visualization

我想绘制一个相当简单的谷歌折线图,但我希望在图表区域中使用水平色带,以指示低/中/高值。

查看图表 API,它似乎不可能是直接的,因为 chartArea.backgroundColor 似乎是我可以设置的唯一值。

意识到这似乎是图表的限制,是否可以通过任何其他方法或 javascript 魔法以任何其他方式重新创建它?

下面是我希望产生什么样的效果的示例。 Example of desired effect

提前致谢。

最佳答案

使用 ComboChart

使用 seriesType: 'area'

isStacked: true

您可以根据需要定义任意数量的范围

visibleInLegend: false 从图例中隐藏区域系列

然后您可以为要跟踪的系列设置自定义类型:
例如 'line',在下面的工作片段中......

google.charts.load('current', {
  callback: function () {
    var dataTable = new google.visualization.DataTable({
      cols: [
        {label: 'Time', type: 'number'},
        {label: 'Low', type: 'number'},
        {label: 'Avg', type: 'number'},
        {label: 'High', type: 'number'},
        {label: 'Dogs', type: 'number'}
      ],
      rows: [
        {c:[{v: 0}, {v: 25}, {v: 50}, {v: 25}, {v: 0}]},
        {c:[{v: 5}, {v: 25}, {v: 50}, {v: 25}, {v: 24}]},
        {c:[{v: 10}, {v: 25}, {v: 50}, {v: 25}, {v: 20}]},
        {c:[{v: 15}, {v: 25}, {v: 50}, {v: 25}, {v: 48}]},
        {c:[{v: 20}, {v: 25}, {v: 50}, {v: 25}, {v: 53}]},
        {c:[{v: 25}, {v: 25}, {v: 50}, {v: 25}, {v: 61}]},
        {c:[{v: 30}, {v: 25}, {v: 50}, {v: 25}, {v: 63}]},
        {c:[{v: 40}, {v: 25}, {v: 50}, {v: 25}, {v: 66}]},
        {c:[{v: 45}, {v: 25}, {v: 50}, {v: 25}, {v: 70}]},
        {c:[{v: 50}, {v: 25}, {v: 50}, {v: 25}, {v: 75}]},
        {c:[{v: 55}, {v: 25}, {v: 50}, {v: 25}, {v: 78}]},
        {c:[{v: 60}, {v: 25}, {v: 50}, {v: 25}, {v: 80}]},
        {c:[{v: 65}, {v: 25}, {v: 50}, {v: 25}, {v: 85}]},
        {c:[{v: 70}, {v: 25}, {v: 50}, {v: 25}, {v: 90}]}
      ]
    });

    var options = {
      chartArea: {
        width: '60%'
      },
      hAxis: {
        ticks: [0, 15, 30, 45, 60],
        title: 'Time'
      },
      isStacked: true,
      series: {
        // low
        0: {
          areaOpacity: 0.6,
          color: '#FFF59D',
          visibleInLegend: false
        },

        // avg
        1: {
          areaOpacity: 0.6,
          color: '#A5D6A7',
          visibleInLegend: false
        },

        // high
        2: {
          areaOpacity: 0.6,
          color: '#EF9A9A',
          visibleInLegend: false
        },

        // dogs
        3: {
          color: '#01579B',
          type: 'line'
        }
      },
      seriesType: 'area',
      title: 'Example',
      vAxis: {
        ticks: [0, 25, 50, 75, 100],
        title: 'Popularity'
      }
    };

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

关于javascript - 谷歌折线图中的可变背景颜色,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39669997/

相关文章:

c# - Visual Studio 2012 语法错误/<% : method %>/;

javascript - ChartJS : datalabels: show percentage value in Pie piece

javascript - 在响应式 Highcharts 饼中将文本居中

Android 图表与其他内容在同一页面中

javascript - 如何使用 onClick 在表单元素内切换类?

javascript - ASP.NET MVC 客户端模型和 JavaScript

javascript - 谷歌图表的问题是 bootstrap Modal

javascript - Google 图表不绘制/显示

javascript - 使用 firebase 在 ionic 2 中实现类似/不同的功能

javascript - Google 图表 pointSize 和 lineWidth 选项 - 不要更改散点图