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);

}

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

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现 GIF 图片转字符动画,可以使用 Qt 提供的 QImage 类来读取 GIF 图片,并将每一帧转换为字符画。下面是一个简单的示例代码: ```cpp #include <QApplication> #include <QImage> #include <QLabel> #include <QTimer> int main(int argc, char *argv[]) { QApplication app(argc, argv); // 加载 GIF 图片 QImage gif("animation.gif"); // 创建标签显示字符动画 QLabel label; label.setStyleSheet("font-family: courier; font-size: 14px;"); label.setMinimumSize(gif.width() * 7, gif.height() * 14); label.show(); // 定时器更新标签内容 QTimer timer; int currentFrame = 0; connect(&timer, &QTimer::timeout, [&]() { // 获取当前帧的像素数据 QImage frame = gif.copy(currentFrame * gif.width(), 0, gif.width(), gif.height()); QByteArray asciiData; asciiData.reserve(frame.width() * frame.height()); for (int y = 0; y < frame.height(); ++y) { for (int x = 0; x < frame.width(); ++x) { QColor color(frame.pixel(x, y)); int gray = qGray(color.rgb()); char c = " .-+*#"[gray / 51]; asciiData.append(c); } asciiData.append('\n'); } label.setText(asciiData); currentFrame = (currentFrame + 1) % (gif.width() / gif.height()); }); timer.start(50); return app.exec(); } ``` 在这个示例中,我们使用了 QTimer 定时器来更新标签内容,每隔 50 毫秒切换到下一帧。对于每一帧的像素数据,我们将每个像素转换为一个字符,并将这些字符拼接成一个字符串,最后设置给标签。注意,我们使用了一个字符集,将像素的灰度值映射到不同的字符上,以实现字符画的效果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值