Canvas合成自定义Gif图

简介: 上次介绍了Canvas自定义图片大小及蒙版与生成gif图,没有详细的说明如何生成gif图,生成gif图的过程也可以进行一些优化。我们无需借助第三方库,直接使用canvas原生的api就可以完成很多的功能。

上次介绍了Canvas自定义图片大小及蒙版与生成gif图,没有详细的说明如何生成gif图,生成gif图的过程也可以进行一些优化。

我们无需借助第三方库,直接使用canvas原生的api就可以完成很多的功能。

效果

这里只是说明功能,细节上还未仔细调,清楚了核心部分其余边边角角处理起来会很快。


img_9a09583e2419a9d2a55e5ee5190f98b9.gif
比较丑的效果

过程

  1. 准备素材
  1. 页面
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Canvas Gif</title>
    <script src="gif.js"></script>
</head>
<body>
<canvas width="480" height="480" id="canvas">
    
</canvas>
<img src="images/1.png" id="img">
<img src="" id="result">
</body>
<script>
    window.onload = function () {
        var oImg = document.getElementById("img");
        var canvas = document.getElementById('canvas');
        var ctx = canvas.getContext('2d')

        let gif = new GIF({
            workers: 4,
            quality: 30,
            workerScript: "./gif.worker.js",
            // transparent: "#fff",
            // background: '#ffffff',
        });
        gif.on("finished",function(blob){
            console.log(URL.createObjectURL(blob));
            var file = new FileReader();
            file.readAsDataURL(blob);
            file.onload = function(){
                document.getElementById("result").setAttribute("src", file.result)
            }

        })
        
        var imgList = [
            './images/pic1.png',
            './images/pic2.png',
            './images/pic3.png',
        ];
        var imgObjList = [],count = 0;

        for (let i=0; i<imgList.length; i++){
            var tmpImg = new Image();
            imgObjList.push(tmpImg);
            tmpImg.src = imgList[i];
            tmpImg.onload = function () {
                count++;
                if (count === imgList.length ){
                    generateGif(imgObjList);
                }
            }
        }


        function generateGif(imgObjList) {

            for (let i=0;i<imgObjList.length;i++){
                ctx.save();
                ctx.drawImage(oImg,50,100,220,220);
                ctx.drawImage(imgObjList[i],0,0,canvas.width,canvas.height);
                ctx.restore();
                gif.addFrame(canvas,{copy:true,delay:300})
                ctx.clearRect(0,0,canvas.width,canvas.height)
            }
            gif.render();
        }

    }
</script>
</html>
  1. 效果


    img_a7e6d2c939b7aae18787cb4161059138.gif
    效果图

最后

页面写的有些粗糙...,因为借助gif.js实现起来确实很容易。

参考

相关文章
|
5月前
|
前端开发
canvas图片操作
canvas图片操作
|
前端开发
canvas生成自定义大小图片
canvas生成自定义大小图片
|
1月前
|
C++
SDL基础使用02(加载bmp图片、纹理和渲染)
这篇文章介绍了如何使用SDL库在C++中加载和显示BMP图片,以及如何使用纹理和渲染器进行更高级的图形处理。
18 2
|
1月前
|
C++
SDL基础使用03(渲染显示bmp图片)
如何使用SDL库在C++中创建窗口、加载BMP图片、创建纹理,并通过渲染器进行显示的完整过程。
29 2
|
6月前
|
前端开发
|
前端开发
雪碧图 Sprite图
雪碧图 Sprite图
116 0
|
人工智能 前端开发
Photoshop - 如何用 PS 合成一张 Sprite 图(雪碧图)
Photoshop - 如何用 PS 合成一张 Sprite 图(雪碧图)
398 0
Photoshop - 如何用 PS 合成一张 Sprite 图(雪碧图)
|
前端开发 小程序 JavaScript
小程序canvas实现(分享朋友圈生成图片)
小程序canvas实现(分享朋友圈生成图片)
599 0
小程序canvas实现(分享朋友圈生成图片)
|
API Android开发
【Android 内存优化】自定义组件长图组件 ( 获取图像宽高 | 计算解码区域 | 设置图像解码属性 复用 像素格式 | 图像绘制 )
【Android 内存优化】自定义组件长图组件 ( 获取图像宽高 | 计算解码区域 | 设置图像解码属性 复用 像素格式 | 图像绘制 )
170 0
【Android 内存优化】自定义组件长图组件 ( 获取图像宽高 | 计算解码区域 | 设置图像解码属性 复用 像素格式 | 图像绘制 )
|
Android开发
【Android 应用开发】Paint 渲染 之 BitmapShader 位图渲染 ( 渲染流程 | CLAMP 拉伸最后像素 | REPEAT 重复绘制图片 | MIRROR 绘制反向图片 )(二)
【Android 应用开发】Paint 渲染 之 BitmapShader 位图渲染 ( 渲染流程 | CLAMP 拉伸最后像素 | REPEAT 重复绘制图片 | MIRROR 绘制反向图片 )(二)
306 0
【Android 应用开发】Paint 渲染 之 BitmapShader 位图渲染 ( 渲染流程 | CLAMP 拉伸最后像素 | REPEAT 重复绘制图片 | MIRROR 绘制反向图片 )(二)