微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何使用KonvaJS用鼠标绘制箭头?

如何解决如何使用KonvaJS用鼠标绘制箭头?

社区。我需要使用KonvaJS用鼠标绘制箭头。我不使用React。这是我第一次使用KonvaJS。我已经搜索解决此问题的信息,但没有发现任何问题。我也阅读了该库的文档,但只发现了如何绘制基本箭头。感谢您的帮助。非常感谢!

解决方法

有很多绘制箭头的方法。您可以遵循Free drawing Konva Demo,但使用箭头代替线条。

最简单的解决方案是使用mousedown-创建一条线,使用mousemove更新线的位置,使用mouseup-完成线。

let arrow;
stage.on('mousedown',() => {
   const pos = stage.getPointerPosition();
    arrow = new Konva.Arrow({
      points: [pos.x,pos.y],stroke: 'black',fill: 'black'
    });
    layer.add(arrow);
    layer.batchDraw();
});

stage.on('mousemove',() => {
  if (arrow) {
      const pos = stage.getPointerPosition();
      const points = [arrow.points()[0],arrow.points()[1],pos.x,pos.y];
      arrow.points(points);
      layer.batchDraw();
  }
});

stage.on('mouseup',() => {
  arrow = null;
});

演示:https://jsbin.com/lefivihibu/2/edit?html,output

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。