Konva 画布中的 SVG 动画

Posted

技术标签:

【中文标题】Konva 画布中的 SVG 动画【英文标题】:SVG Animations in Konva canvas 【发布时间】:2020-02-27 06:22:34 【问题描述】:

我想将动画 SVG 添加到 Konva 画布。我尝试使用 Image 对象添加它。 SVG 显示,但它不是动画的。

我还尝试向图层添加动画,如 Konva 的视频演示中所示,但这也不起作用。

有人知道如何完成这项工作吗?

 var width = window.innerWidth;
      var height = window.innerHeight;

      var stage = new Konva.Stage(
        container: 'container',
        width: width,
        height: height
      );

      var layer = new Konva.Layer();
      stage.add(layer);

      // main API:
      var imageObj = new Image();
      imageObj.onload = function() 
        var image = new Konva.Image(
          x: 50,
          y: 50,
          image: imageObj,
          width: 240,
          height: 180
        );

        // add the shape to the layer
        layer.add(image);
        layer.batchDraw();
      ;
      
      var animation=new Konva.Animation(function()
      
      ,layer);
      animation.start();
      
      
      imageObj.src = '';

     
*
  margin:0;
  padding:0;
<script src="https://cdnjs.cloudflare.com/ajax/libs/konva/4.0.13/konva.min.js"></script>
 <div id="container"></div>

【问题讨论】:

【参考方案1】:

据我所知,目前还没有针对此类用例的解决方案。

最好只使用 SVG 而不是画布 (Konva)。 或者直接在画布上画图,不用 SVG。

【讨论】:

我只想指出,如果 Konva 的维护者想要实现这一点,由于画布规范 actually forbid the drawing of animated images through drawImage 他们将不得不进行 SMIL js 实现(如 FakeSmile), js 实现 CSS 动画(我不知道),并使其顺利运行 svg 到画布方法 parser à la canvg。 所以,转换为 Konva 动画是一个晚上的工作,但手动将它们编码为 Konva 确实是最简单的解决方案。感谢您的回答!

以上是关于Konva 画布中的 SVG 动画的主要内容,如果未能解决你的问题,请参考以下文章

使用 konva 在画布中绘制类似网格的电子表格

如何使用 React Konva Image 将画布重新绘制到自身上?

无法使用 Konva 将 PDF 图像作为图像对象加载到 HTML5 画布中

Konva stage.toDataUrl()是不是渲染我在画布中看到的图像?

在 SVG 和画布之间,哪个更适合操作/动画多个图像?也许两者都没有,只使用 css3 转换?

d3.js:将 SVG 地理路径转换为画布