欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  web前端

canvas和gif.js打造自己的数字雨头像

程序员文章站 2022-03-08 16:38:16
...
本文主要介绍了canvas+gif.js打造自己的数字雨头像的示例代码,这里整理了详细的代码,非常具有实用价值,需要的朋友可以参考下,希望能帮助到大家。

canvas和gif.js打造自己的数字雨头像

使用说明

1.传一个你喜欢的头像,最后是正方形的

2.生成后看字符颜色是不是太诡异,可以改变字符颜色

3.觉得满意,右键另存为即可

gif.js

今天的主角是gif.js,gif.js是一个在浏览器上依靠H5api就能gif动画的库,这里介绍一下我猜的坑。关于绘制数字雨,园子里有相关文章,我就不瞎BB了。

gif.js可以很方便的根据canvas动图得到gif:


//代码来自官网

var gif = new GIF({
 workers: 2,//启用两个worker。
 quality: 10//图像质量
});//创建一个GIF实例

// 核心方法,向gif中加一帧图像,参数可以是img/canvas元素,还可以从ctx中复制一帧
gif.addFrame(imageElement);

// or a canvas element
gif.addFrame(canvasElement, {delay: 200});//一帧时长是200

// or copy the pixels from a canvas context
gif.addFrame(ctx, {copy: true});

gif.on('finished', function(blob) {//最后生成一个blob对象
 window.open(URL.createObjectURL(blob));
});

gif.render();//开始启动

整体而言,这个库的api十分简洁,友好。之前看了一个jsGif,看的云里雾里,后来才发现这么个好东西。由于生成gif图像是个耗费cpu的操作,尤其是当图像比较大的时候,因此库允许在webworker中渲染。但是文档中还是有几个要注意的地方要说明(其实是我踩的坑):

1.git.addFrame是添加一帧,要生成会动的gif,要来一个循环:


for(...){
gif.render(...)
}

2.构造函数GIF的选项中,需要workerScript选项,这样才能实现在worker中渲染图像,如下所示:


var gif = new GIF({
workers: 2,
quality: 10,
  workerScript:'./gif.worker.js'
});

大家学会了吗?赶紧动手尝试一下吧。

相关推荐:

微信小程序怎么上传头像

利用Laravel生成Gravatar头像地址的优雅方法

CSS3实现头像旋转效果实例分享

以上就是canvas和gif.js打造自己的数字雨头像的详细内容,更多请关注其它相关文章!