为了账号安全,请及时绑定邮箱和手机立即绑定

如何绘制 chartJs 的特定区域?

如何绘制 chartJs 的特定区域?

波斯汪 2023-03-03 14:50:06
我有一个如下的折线图(没有任何颜色)在这个折线图中,我想给颜色直到特定的 y 轴值。当它大于 0 时,从那个值到顶部,应该像下面那样应用渐变 为了实现这一点,下面是我的解决方案 plugins: [        {          beforeRender: function (c, options) {            var dataset = c.data.datasets[0];            var yScale = c.scales['y-axis-0'];            var yPos = yScale.getPixelForValue(0);            let nonZeroPoint;            for (var i = 0; i < dataset.data.length; i++) {              if (dataset.data[i] != 0) {                nonZeroPoint= dataset.data[i];                break;              }            }            const newHeight = (yPos * nonZeroPoint) / Math.max(...dataset.data);            var gradientFill = c.ctx.createLinearGradient(0, yPos-newHeight, 0, 0);            gradientFill.addColorStop(0.1, "#fff");            gradientFill.addColorStop(1, "#7E0100");            var model = c.data.datasets[0]._meta[Object.keys(dataset._meta)[0]].$filler.el._model;            model.backgroundColor = gradientFill;          }        }      ]在此解决方案中,yPos 是图表的高度。nonZeroPoint是通过for循环计算出来的一个值,用来标识0之后的第一个数据值。newHeight = (yPos * nonZeroPoint) / Math.max(...dataset.data);此公式根据顶点高度及其值计算nonZeroHeight 的高度。但是我无法获得预期的结果。下面是它。我该如何解决?代码笔: https: //codepen.io/Cicek96/pen/GRZBgpN
查看完整描述

1 回答

?
一只斗牛犬

TA贡献1784条经验 获得超2个赞

使用Plugin Core APIafterLayout中的钩子,这可以写成如下:

new Chart("chart", {

  type: 'line',

  plugins: [{

    afterLayout: c => {

      let dataset = c.data.datasets[0];

      let yScale = c.scales['y-axis-0'];

      let yBottom = yScale.getPixelForValue(0);

      let yGradientStart = yScale.getPixelForValue(dataset.data.find(v => v > 0));

      let yTop = yScale.getPixelForValue(Math.max(...dataset.data));

      let gradientFill = c.ctx.createLinearGradient(0, yBottom, 0, yTop);

      gradientFill.addColorStop(0, "#fff");

      let offset = (yBottom - yGradientStart) / (yBottom - yTop); 

      gradientFill.addColorStop(offset, "#fff");

      gradientFill.addColorStop(1, "#7E0100");

      dataset.backgroundColor = gradientFill;

    }

  }],

  data: {

    labels: ["January", "February", "March", "April", "May", "June", "July"],

    datasets: [{

      label: "My First dataset",

      borderColor: '#7E0100',

      data: [0, 120, 200, 350, 200, 120, 0]

    }]

  },

  options: {

    scales: {

      yAxes: [{

        ticks: {

          max: 500,

          stepSize: 100

        }

      }]

    }

  }

});

<script src="https://cdnjs.cloudflare.com/ajax/libs/Chart.js/2.9.3/Chart.min.js"></script>

<canvas id="chart" height="160"></canvas>


查看完整回答
反对 回复 2023-03-03
  • 1 回答
  • 0 关注
  • 117 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信