Skip to main content

HTML5 Canvas 灰度图像滤镜教程

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

要用 Konva 反转图像的颜色,我们可以使用 Konva.Filters.Grayscale 滤镜。

有关所有可用滤镜,请访问 滤镜文档

import Konva from 'konva';

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

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.Grayscale]);
};
imageObj.src = 'https://konvajs.org/assets/lion.png';
imageObj.crossOrigin = 'anonymous';