js实现GIF图片的分解和合成

https://www.jb51.net/article/172709.htm

这篇文章主要为大家详细介绍了js实现GIF图片的分解和合成,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

java

无意中看到一篇文章写得是关于纯前端处理GIF图片的问题,感觉挺有意思的所以自己也实现了一下;

主要用到的有两个第三方库:合成GIF图片的gif.js和分解的libgif.js;

分解GIF

1. 引入Git库

1

import SuperGif from './libgif.js'

2. 处理图片

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

var file = e.target.files[0];

 console.log(file.type.indexOf('image/gif'));

 load_gif(file);

function load_gif(gif_source) {

  var gifImg = document.getElementById('gifImg');

  // gif库需要img标签配置下面两个属性

  gifImg.setAttribute('rel:animated_src', URL.createObjectURL(gif_source))

  gifImg.setAttribute('rel:auto_play', '0')

  

  // 新建gif实例

  var rub = new SuperGif({ gif: gifImg } );

  

  var running = false;

  rub.load(function(){

  var img_list = [];

  var j = 0;

  console.log(rub.get_length());

  for (var i=1; i <= rub.get_length(); i++) {

  // 遍历gif实例的每一帧

  rub.move_to(i);

  

  var imgImage = new Image();

  //canvas生成base64图片数据

  imgImage.src = rub.get_canvas().toDataURL('image/jpeg',0.8);

  }

 }

合成GIF图片

1. 引入Git库

1

import GIF from './gif.js'

2. 图片合成

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

var gif = new GIF({

  workers: 2,

  quality: 10,

  workerScript: 'js/gif.worker.js'

});

var j = 0;

  

var canvas= document.createElement("canvas");

var ctx = tCanvas.getContext('2d');

  

for (var i=1; i <= len; i++) {

  

 var imgImage = new Image();

 imgImage.src = img;

 imgImage.onload = function (e) {

  

 //Canvas绘制图片

 canvas.width = width;

 canvas.height = height;

 console.log(width,height)

 //铺底色

 ctx.fillStyle = "#fff";

 ctx.fillRect(0, 0, canvas.width, canvas.height);

 ctx.drawImage(imgImage, 0, 0, width, height);

  

  

 gif.addFrame(canvas,{copy:true,delay:50});

 j++;

 //图片

 if(j>=len) {

 gif.render()

 };

 }

}

gif.on('finished', function(blob) {

 //生成图片链接

  var url = URL.createObjectURL(blob);

}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值