第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機立即綁定

Canvas合成自定義Gif圖

標簽:
動效動畫

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

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

效果

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


240

比较丑的效果

过程

  1. 准备素材

  1. 页面

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Canvas Gif</title>
    <script class="lazyload" src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB/AAffA0nNPuCLAAAAAElFTkSuQmCC" data-original="gif.js"></script>
</head>
<body>
      <canvas width="480" height="480" id="canvas">
    </canvas><img class="lazyload" src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB/AAffA0nNPuCLAAAAAElFTkSuQmCC" data-original="images/1.png" id="img">
    <img class="lazyload" src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB/AAffA0nNPuCLAAAAAElFTkSuQmCC" data-original="" id="result">
</body>
<script>
    window. = 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. = 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. = 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. 效果


    480

    效果图

最后

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

参考

點擊查看更多內容
TA 點贊

若覺得本文不錯,就分享一下吧!

評論

作者其他優(yōu)質文章

正在加載中
  • 推薦
  • 評論
  • 收藏
  • 共同學習,寫下你的評論
感謝您的支持,我會繼續(xù)努力的~
掃碼打賞,你說多少就多少
贊賞金額會直接到老師賬戶
支付方式
打開微信掃一掃,即可進行掃碼打賞哦
今天注冊有機會得

100積分直接送

付費專欄免費學

大額優(yōu)惠券免費領

立即參與 放棄機會
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網(wǎng)微信公眾號

舉報

0/150
提交
取消