首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用react-konva在画布上设置GIF动画

使用react-konva在画布上设置GIF动画
EN

Stack Overflow用户
提问于 2020-03-17 20:27:39
回答 1查看 840关注 0票数 1

我正在尝试使用react为应用程序创建一个UI。我已经使用react-konva创建了一个2D画布。我已经知道如何将图像导入到这个画布上,但我在尝试制作gif动画时遇到了问题。有关于如何在konva中实现它的文档,但我似乎无法将其转换为react-konva。

在konva中执行此操作的文档提供了here

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-03-19 01:54:14

代码语言:javascript
复制
import React from "react";
import { render } from "react-dom";
import { Stage, Layer, Image } from "react-konva";
// gifler will be imported into global window object
import "gifler";

const GIF = ({ src }) => {
  const imageRef = React.useRef(null);
  const canvas = React.useMemo(() => {
    const node = document.createElement("canvas");
    return node;
  }, []);

  React.useEffect(() => {
    // save animation instance to stop it on unmount
    let anim;
    window.gifler(src).get(a => {
      anim = a;
      anim.animateInCanvas(canvas);
      anim.onDrawFrame = (ctx, frame) => {
        ctx.drawImage(frame.buffer, frame.x, frame.y);
        imageRef.current.getLayer().draw();
      };
    });
    return () => anim.stop();
  }, [src, canvas]);

  return <Image image={canvas} ref={imageRef} />;
};

class App extends React.Component {
  render() {
    return (
      <Stage width={window.innerWidth} height={window.innerHeight}>
        <Layer>
          <GIF src="https://konvajs.org/assets/yoda.gif" />
        </Layer>
      </Stage>
    );
  }
}

render(<App />, document.getElementById("root"));

演示:https://codesandbox.io/s/react-konva-gif-animation-p86qr

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/60722444

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档