Skip to main content

HTML5 Canvas 万花筒图像滤镜教程

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

要使用 Konva 创建一个万花筒,我们可以使用 Konva.Filters.Kaleidoscope 滤镜,并设置 kaleidoscopePowerkaleidoscopeAngle 属性。

说明:滑动控件以调整万花筒的功率和角度。

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

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.Kaleidoscope]);
  image.kaleidoscopePower(3);
  image.kaleidoscopeAngle(0);

  // 创建滑块
  const createSlider = (label, min, max, defaultValue, 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 = min;
    slider.max = max;
    slider.step = property === 'kaleidoscopePower' ? '1' : '0.1';
    slider.value = defaultValue;
    slider.style.width = '200px';
    
    slider.addEventListener('input', (e) => {
      const value = parseFloat(e.target.value);
      image[property](value);
    });
    
    container.appendChild(slider);
    return container;
  };

  const powerSlider = createSlider('功率', 2, 8, 3, 'kaleidoscopePower');
  powerSlider.style.top = '20px';
  document.body.appendChild(powerSlider);

  const angleSlider = createSlider('角度', 0, 360, 0, 'kaleidoscopeAngle');
  angleSlider.style.top = '45px';
  document.body.appendChild(angleSlider);
};
imageObj.src = 'https://konvajs.org/assets/lion.png';
imageObj.crossOrigin = 'anonymous';