chart.js v2:将时间刻度标签与条形中心对齐

时间:2016-07-27 16:48:49

标签: javascript charts chart.js

我正在尝试使用Chart.js v2.2将生成的时间刻度标签与条形图的条形中心对齐。我尝试过offsetGridLines选项,但在使用Xaxis缩放类型时,这似乎没有效果。

这是一个例子,也许我错过了一些东西:

   <div id="container" style="width: 75%;">
    <canvas id="canvas"></canvas>
</div>
<script>
    var barChartData = {
        labels: ["2015-01-01", "2015-02-01", "2015-03-01", "2015-04-01", "2015-05-01", "2015-07-01"],
        datasets: [{
            label: 'Dataset 1',
            backgroundColor: "rgba(220,220,220,0.5)",
            data: [10, 4, 5, 7, 2, 3]
        }]

    };

    window.onload = function() {
        var ctx = document.getElementById("canvas").getContext("2d");
        window.myBar = new Chart(ctx, {
            type: 'bar',
            data: barChartData,
            options: {
                elements: {
                    rectangle: {
                        borderWidth: 2,
                        borderColor: 'rgb(0, 255, 0)',
                        borderSkipped: 'bottom'
                    }
                },
                responsive: true,
                legend: {
                    position: 'top',
                },
                title: {
                    display: true,
                    text: 'Chart.js Bar Chart'
                }
            ,
                scales: {
                  xAxes: [{
                    categoryPercentage: .5,
                    barPercentage: 1,
                    type: 'time',
                    scaleLabel: {
                      display: true,
                      labelString: 'Year-Month'
                    },
                    time: {
                      min: '2014-12-01' ,
                      max: '2015-12-01',
                      unit: 'month',
                      displayFormats: {
                        month: "MMM YY"
                      }
                    },
                    gridLines: {
                        offsetGridLines: false,
                        drawTicks: true,
                      display: true
                    },
                    stacked: true
                  }],
                  yAxes: [{
                    ticks: {
                      beginAtZero: true
                    },
                    stacked: true
                  }]
                }
            }
        });

    };


</script>

2 个答案:

答案 0 :(得分:0)

我删除了设置的minmax值,从而获得了工作图表。

以下是JSFiddle

以下图片是否符合预期结果?

enter image description here

答案 1 :(得分:0)

这个小提琴可能有助于将数据标签放在栏的中心 https://jsfiddle.net/tea8dhgy/

<div id="container" style="width: 75%;">
  <canvas id="canvas"></canvas>
</div>       
 var barChartData = {
      labels: ["2015-01-01", "2015-02-01", "2015-03-01", "2015-04-01", "2015-05-01", "2015-07-01"],
      datasets: [{
        label: 'Dataset 1',
        backgroundColor: "rgba(220,220,220,0.5)",
        data: [10, 4, 5, 7, 2, 3]
      }]

    };


    var ctx = document.getElementById("canvas").getContext("2d");
    new Chart(ctx, {
      type: 'bar',
      data: barChartData,
      options: {
        elements: {
          rectangle: {
            borderWidth: 2,
            borderColor: 'rgb(0, 255, 0)',
            borderSkipped: 'bottom'
          }
        },
        responsive: true,
        legend: {
          position: 'top',
        },
        title: {
          display: true,
          text: 'Chart.js Bar Chart'
        },
        scales: {
          xAxes: [{
            categoryPercentage: .5,
            barPercentage: 1,
            type: 'time',
            scaleLabel: {
              display: true,
              labelString: 'Year-Month'
            },
            time: {
              // min: '2014-12-01' ,
              // max: '2015-12-01',
              unit: 'month',
              displayFormats: {
                month: "MMM YY"
              }
            },
            gridLines: {
              offsetGridLines: false,
              drawTicks: true,
              display: true
            },
            stacked: true
          }],
          yAxes: [{
            ticks: {
              beginAtZero: true
            },
            stacked: true
          }]
        },
        animation: {
          onComplete: function() {
            var chartInstance = this.chart,
              ctx = chartInstance.ctx;

            ctx.font = Chart.helpers.fontString(10, "bold", Chart.defaults.global.defaultFontFamily);
            ctx.textAlign = 'center';
            ctx.textBaseline = 'center';

            this.data.datasets.forEach(function(dataset, i) {
              var meta = chartInstance.controller.getDatasetMeta(i);
              meta.data.forEach(function(bar, index) {
                //var data = dataset.data[index];
                var data = dataset.data[index];
                console.log(bar);
                if (data > 0) {
                  ctx.fillText(data, bar._model.x, bar._model.base - (bar._model.base - bar._model.y) / 2 - 5);
                }
              });
            });
          }
        }
      }
    });