在chart.js的条形图中添加图像

问题描述 投票:0回答:1

我需要在chart.js的条形图中添加图像。

所有可用的解决方案都使用pointStyle属性处理折线图点。找不到Barcharts的示例,也没有官方文档提供解决方案。我检查了插件,但都找不到解决方案。

var imageExample = new Image();
cloud.src = 'imageurl.png';

Chart.pluginService.register({
    afterUpdate: function (chart) {
        console.log(chart.config.data.datasets[0]);                
        chart.config.data.datasets[0]._meta[0].data[0]._model.pointStyle = imageExample;
    }
});

示例结果应类似于以下内容:output

image chart.js
1个回答
0
投票

您可以使用chartjs-plugin-labels在各个小节内添加图像。

new Chart(document.getElementById('myChart'), {
  type: 'bar',
  data: {
    labels: ['A', 'B', 'C'],
    datasets: [{
      label: 'My First Dataset',
      data: [30, 59, 80],
      fill: false,
      backgroundColor: ['rgba(255, 99, 132, 0.2)', 'rgba(255, 159, 64, 0.2)', 'rgba(255, 205, 86, 0.2)'],
      borderColor: ['rgb(255, 99, 132)', 'rgb(255, 159, 64)', 'rgb(255, 205, 86)', 'rgb(75, 192, 192)'],
      borderWidth: 1
    }]
  },
  options: {
    plugins: {
      labels: {
        render: 'image',
        textMargin: -30,
        images: [
          {
            src: 'https://i.stack.imgur.com/9EMtU.png',
            width: 20,
            height: 20
          }, 
          null, 
          {
            src: 'https://i.stack.imgur.com/9EMtU.png',
            width: 20,
            height: 20
          }
        ]
      }
    },
    scales: {
      yAxes: [{
        ticks: {
          beginAtZero: true
        }
      }]
    }
  }
});
canvas {
  max-width: 300px;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/Chart.js/2.9.3/Chart.bundle.min.js"></script>
<script src="https://cdn.jsdelivr.net/gh/emn178/chartjs-plugin-labels/src/chartjs-plugin-labels.js"></script>
<canvas id="myChart" width="10" height="5"></canvas>
© www.soinside.com 2019 - 2024. All rights reserved.