Skip to main content

使用 Konva 通过名称选择 HTML5 Canvas 形状教程

要用 Konva 按名称选择形状,我们可以使用 find() 方法结合 . 选择器。 find() 方法返回匹配选择器字符串的节点数组。

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 circle1 = new Konva.Circle({
  x: 50,
  y: stage.height() / 2,
  radius: 30,
  fill: 'red',
  name: 'myCircle'
});

const circle2 = new Konva.Circle({
  x: 150,
  y: stage.height() / 2,
  radius: 30,
  fill: 'green',
  name: 'myCircle'
});

const rect = new Konva.Rect({
  x: 250,
  y: stage.height() / 2 - 25,
  width: 50,
  height: 50,
  fill: 'blue',
  name: 'myRect'
});

layer.add(circle1);
layer.add(circle2);
layer.add(rect);

// 按名称查找所有圆形
const circles = layer.find('.myCircle');
circles.forEach(circle => {
  // 仅对圆形添加动画
  circle.to({
    duration: 1,
    rotation: 360,
    easing: Konva.Easings.EaseInOut
  });
});