Skip to main content

HTML5 Canvas RGB过滤图片教程

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

用Konva更改图片的RGB分量,可以使用Konva.Filters.RGB

说明:通过滑动控件来改变RGB值。

所有可用滤镜详见【滤镜文档】(/api/Konva.Filters.html)。

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.RGB]);
  image.red(100);
  image.green(100);
  image.blue(100);

  // 创建滑块
  const createSlider = (label, property) => {
    const container = document.createElement('div');
    container.style.position = 'absolute';
    container.style.left = '20px';

    const text = document.createElement('span');
    text.textContent = `${label}: `;
    container.appendChild(text);

    const slider = document.createElement('input');
    slider.type = 'range';
    slider.min = '0';
    slider.max = '255';
    slider.step = '1';
    slider.value = image[property]();
    slider.style.width = '200px';

    slider.addEventListener('input', (e) => {
      const value = parseInt(e.target.value);
      image[property](value);
    });

    container.appendChild(slider);
    return container;
  };

  const redSlider = createSlider('红色', 'red');
  redSlider.style.top = '20px';
  document.body.appendChild(redSlider);

  const greenSlider = createSlider('绿色', 'green');
  greenSlider.style.top = '45px';
  document.body.appendChild(greenSlider);

  const blueSlider = createSlider('蓝色', 'blue');
  blueSlider.style.top = '70px';
  document.body.appendChild(blueSlider);
};
imageObj.src = 'https://konvajs.org/assets/lion.png';
imageObj.crossOrigin = 'anonymous';