使用apng-js,apng动画连续播放,取代gif

通过使用apng-js可以控制播放图片,或者点击按钮达到播放多次动画的效果,在动画播放结束页可以执行一些操作。

废话不多说,直接上代码

1、npm install apng-js

2、新建apng.js文件,里面做了一些通用封装

javascript 复制代码
import parseAPNG from 'apng-js';
/**
 * 获取图片ArrayBuffer
 * @param url 图片地址
 * @returns {Promise<ArrayBuffer>}
 */
export function getImgBuffer(url) {
  return new Promise(async (resolve) => {
   const blob = await fetch(url).then((res) => res.blob());
   const reader = new FileReader();
   reader.readAsArrayBuffer(blob);
   reader.onload = () => {
    resolve(reader.result);
   };
  });
}

/**
 * 获取apng图片的控制实例
 * @param url 图片地址
 * @param options apng配置参数
 * @returns {Promise<APNG>}
 */
export async function getApng(url, options = {}) {
  const imgBuffer = await getImgBuffer(url);
  const apng = parseAPNG(imgBuffer);
  Object.keys(options).forEach((key) => {
   apng[key] = options[key];
  });
  return apng;
}


/**
 * 播放anpng
 * @param apngFile apng图片
 * @param canvasClass className
 * @param canvasWidth canvasWidth
 * @param canvasWidth canvasWidth
 * @param appendParent 需要追加到 父组件id
 */
export async function playApng(apngFile, canvasClass,appendParent, canvasWidth=375,canvasHeight=375,canvasStyles) {
  let apngObj = null
  let apngPlayer = null
  await getApng(apngFile).then(res => {
    apngObj = res
  })
  if (!apngObj) {
    return
  }
  const container = document.getElementById(appendParent); // 放到 某个 模块下
  let canvas = document.createElement('canvas');// 每次新建canvas,可以达到类似于敲木鱼多次播放的效果(播放结束后该canvas自动隐藏)
  canvas.width = canvasWidth;
  canvas.height = canvasHeight;
  canvas.setAttribute('class', canvasClass);
  Object.assign(canvas.style, canvasStyles);
  container.appendChild(canvas);
  // willReadFrequently: true可以提升 canvas 渲染速度
  apngObj.getPlayer(canvas.getContext('2d', { willReadFrequently: true })).then(res => {
    apngPlayer = res
    // 开始播放apng动画
    apngPlayer.play()
    // 添加动画播放结束监听事件
    apngPlayer.on('end', () => {
      // 动画播放结束,当前的canvas隐藏(或者做其他动作)
      canvas.style.display = 'none';
    })
  })
}
export default {
  getImgBuffer,
  getApng,
  playApng
};

3、对应页面引入上面定义好的apng.js,具体路径根据自己项目定

javascript 复制代码
import Apng from '@/utils/apng.js'
import pngSrc from '@/static/makeCake/xxx.png'

4、传入具体的apng图片(本地地址)、canvas命名和apng要插入的某个父容器id

javascript 复制代码
const canvasPlay = () => {
  let apngWidth = 300 //宽和高是必须要的
  let apngHeight = 300
  let apngFile = pngSrc
// canvasStyle 按需设置,看自己需要放置的位置
  let canvasStyle = {
    position: 'absolute',
    bottom: '0',
    zIndex: '12',
    left: '50%',
    transform: 'translateX(-50%)'
  }
  Apng.playApng(pngSrc, 'canvasName', 'canvasParent', apngWidth, apngHeight, canvasStyle)
}

canvasPlay () // 执行
相关推荐
Algorithm15767 分钟前
JVM是什么,与Java的关系是什么,以及JVM怎么实现的跨平台性
java·开发语言·jvm
Gnevergiveup8 分钟前
2024网鼎杯青龙组Web+Misc部分WP
开发语言·前端·python
边疆.22 分钟前
C++类和对象 (中)
c语言·开发语言·c++·算法
yy_xzz24 分钟前
QT编译报错:-1: error: cannot find -lGL
开发语言·qt
你不讲 wood27 分钟前
使用 Axios 上传大文件分片上传
开发语言·前端·javascript·node.js·html·html5
林浔090635 分钟前
C语言部分输入输出(printf函数与scanf函数,getchar与putchar详解,使用Linux ubuntu)
c语言·开发语言
一颗甜苞谷1 小时前
开源一款基于 JAVA 的仓库管理系统,支持三方物流和厂内物流,包含 PDA 和 WEB 端的源码
java·开发语言·开源
CLCNboss1 小时前
Mac安装Ruby
开发语言·经验分享·笔记·macos·ruby
ai产品老杨1 小时前
深度学习模型量化原理
开发语言·人工智能·python·深度学习·安全·音视频
秋恬意1 小时前
LinkedList 源码分析
java·开发语言·面试