Skip to main content

HTML5 Canvas 亮度图像滤镜教程

注意:此滤镜在 Konva 10.0.0 中引入,用以替代 Brighten 滤镜。为了向后兼容,Brighten 滤镜仍可用,但已被弃用,将在未来版本中移除。 新滤镜渲染效果更接近 CSS filter: brightness(0.5);

要对 Konva.Image 应用滤镜,必须先使用 cache() 函数缓存它,然后使用 filters() 函数应用滤镜。

要使用 Konva 调节图像明暗度,可以使用 Konva.Filters.Brightness 滤镜,并通过 brightness 属性设置亮度值。 brightness 属性可以设置从 0 到 2 的任意数字,具体含义:

  • 0 会产生完全黑色的图像
  • 1 是原始图像(无变化)
  • 大于 1 的值会使图像变亮
  • 2 会产生非常明亮的图像

说明:拖动滑块调整亮度

所有可用滤镜可查看滤镜文档

import Konva from 'konva';

const width = window.innerWidth;
const height = window.innerHeight;

const stage = new Konva.Stage({
  container: 'container',
  width: width,
  height: height,
});

const layer = new Konva.Layer();
stage.add(layer);

const imageObj = new Image();
imageObj.onload = () => {
  const image = new Konva.Image({
    x: 50,
    y: 50,
    image: imageObj,
    draggable: true,
  });

  layer.add(image);

  image.cache();
  image.filters([Konva.Filters.Brightness]);
  image.brightness(1.5);

  const slider = document.createElement('input');
  slider.type = 'range';
  slider.min = '0';
  slider.max = '2';
  slider.step = '0.1';
  slider.value = image.brightness();

  slider.style.position = 'absolute';
  slider.style.top = '20px';
  slider.style.left = '20px';

  slider.addEventListener('input', (e) => {
    const value = parseFloat(e.target.value);
    image.brightness(value);
  });

  document.body.appendChild(slider);
};

imageObj.src = 'https://konvajs.org/assets/darth-vader.jpg';
imageObj.crossOrigin = 'anonymous';