亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > HTML > 正文

Canvas圖片分割效果的實(shí)現(xiàn)

2024-08-26 00:21:36
字體:
供稿:網(wǎng)友

之前在逛cssdesignawards時(shí)發(fā)現(xiàn)了一個(gè)把圖片內(nèi)容分割的效果(網(wǎng)址:https://weareludwig.com),大家可以點(diǎn)進(jìn)去看看,感覺挺炫酷的,于是自己試著實(shí)現(xiàn)了一下,效果還不錯(cuò)。效果查看https://codepen.io/geeknoble/pen/OQaOVG

分析

首先我們可以發(fā)現(xiàn)圖片的內(nèi)容被分成了一個(gè)個(gè)小矩形,并對每個(gè)矩形進(jìn)行了隨機(jī)平移。Canvas的drawImage函數(shù)可以對圖片內(nèi)容進(jìn)行裁剪并繪制到Canvas畫布中,所以該效果主要實(shí)現(xiàn)原理就是使用drawImage。主要效果有兩個(gè),一個(gè)是圖片內(nèi)容的打亂和復(fù)原,一個(gè)是和下張圖片的切換,這兩個(gè)效果都可以使用drawImage,只是移動(dòng)的距離不一樣??傮w思路有了那么就可以去著手實(shí)現(xiàn)一下。

初始工作

首先我們要初始化一些變量,比如圖片的寬高,矩形的個(gè)數(shù),剪切的尺寸等,然后再計(jì)算每個(gè)矩形的坐標(biāo),使用一個(gè)二重循環(huán)將矩形坐標(biāo)保存在data中。每個(gè)矩形有個(gè)隨機(jī)位移,這個(gè)位移也需要保存起來,存在randoms中。其中x,y表示canvas畫布的坐標(biāo),x1,y1表示圖片裁剪的坐標(biāo)。

init: function (context, width, height, area, img) {            this.context = context;            this.img = img;            this.imgWidth = img[0].width;          //圖片寬高            this.imgHeight = img[0].height;            this.index = 0;                       //當(dāng)前圖片序號            this.width = width;                  //畫布寬高            this.height = height;            this.area = height/12;                     //小矩形長度            this.countX = width / this.area;             //水平和垂直方向小矩形個(gè)數(shù)            this.countY = height / this.area;            this.wx = this.imgWidth / this.countX;      //圖片在小矩形中的寬高            this.wy = this.imgHeight / this.countY;            this.state = true;                   //圖片狀態(tài),true表示未拆分            this.dataFlag = true;                //小矩形坐標(biāo)狀態(tài),true表示未加上隨機(jī)值            this.duration = 1000;                 //動(dòng)畫時(shí)間            this.duration2 = 1500;            this.startTime = 0;            this.data = [];                       //小矩形坐標(biāo)信息            this.randoms = [];                    //位置隨機(jī)值            //初始化矩形坐標(biāo)            var x1 = 0, y1 = 0, x = 0, y = 0;            for (var i = 0; i < this.countY; i++) {                for (var j = 0; j < this.countX; j++) {                    context.drawImage(this.img[this.index], x1, y1, this.wx, this.wy, x, y, this.area, this.area);                    //儲(chǔ)存矩形坐標(biāo)                    this.data.push({                        x1: x1,                        y1: y1,                        x: x,                        y: y                    });                    //添加隨機(jī)值                    this.randoms.push(random(-this.area, this.area));                    x1 += this.wx;                    x += this.area;                }                x1 = 0;                y1 += this.wy;                x = 0;                y += this.area;            }            this.checkMargin();        }

檢測邊緣

在給矩形添加位移之前我們需要判斷一下位移后的坐標(biāo)是否超過圖片界限,比如在頂部的矩形如果是y軸移動(dòng),那么只能夠向上移,判斷的條件為當(dāng)前坐標(biāo)加上位移值是否小于0或大于圖片的寬高。如果更新后的坐標(biāo)小于0,那么這個(gè)隨機(jī)值一定是負(fù)數(shù),需要把隨機(jī)值改為正數(shù),如果大于圖片高度,那么改成負(fù)數(shù)即可。由于每個(gè)矩形的移動(dòng)都是在一個(gè)方向上移動(dòng),所以我這里寫成偶數(shù)位移動(dòng)x軸,奇數(shù)位移動(dòng)y軸。

//檢測邊緣        checkMargin: function () {            var self = this;            this.data.forEach(function (item, index) {                if (index % 2 == 0) {  // 下標(biāo)為2的倍數(shù)時(shí)移動(dòng)x軸,否則移動(dòng)y軸                    if ( item.x1 + self.randoms[index] < 0)                        // 改為正數(shù)                        self.randoms[index] = -self.randoms[index];                    if (item.x1 + self.wx + self.randoms[index] > self.imgWidth )                        // 改為負(fù)數(shù)                        self.randoms[index] = -Math.abs(self.randoms[index])                } else {                    if (item.y1 + self.randoms[index] < 0)                        self.randoms[index] = -self.randoms[index];                    if (item.y1 + self.randoms[index] + self.wy > self.imgHeight)                        self.randoms[index] = -Math.abs(self.randoms[index])                }            })        }

分離和復(fù)原

動(dòng)畫的內(nèi)容的分離和復(fù)原就是更新矩形坐標(biāo)的值,打亂內(nèi)容只要將data里的坐標(biāo)加上隨機(jī)值,而復(fù)原就是減去隨機(jī)值,

//檢測邊緣        checkMargin: function () {            var self = this;            this.data.forEach(function (item, index) {                if (index % 2 == 0) {  // 下標(biāo)為2的倍數(shù)時(shí)移動(dòng)x軸,否則移動(dòng)y軸                    if ( item.x1 + self.randoms[index] < 0)                        // 改為正數(shù)                        self.randoms[index] = -self.randoms[index];                    if (item.x1 + self.wx + self.randoms[index] > self.imgWidth )                        // 改為負(fù)數(shù)                        self.randoms[index] = -Math.abs(self.randoms[index])                } else {                    if (item.y1 + self.randoms[index] < 0)                        self.randoms[index] = -self.randoms[index];                    if (item.y1 + self.randoms[index] + self.wy > self.imgHeight)                        self.randoms[index] = -Math.abs(self.randoms[index])                }            })        }

在儲(chǔ)存好坐標(biāo)后就可以去實(shí)現(xiàn)平移動(dòng)畫了,移動(dòng)的過程有一個(gè)平滑的過渡,我們可以使用Tween.js的緩動(dòng)算法,該算法有4個(gè)參數(shù)分別是當(dāng)前時(shí)間,初始位置,結(jié)束位置,動(dòng)畫時(shí)間。詳細(xì)內(nèi)容可以參考張鑫旭的這篇文章https://www.zhangxinxu.com/wordpress/2016/12/how-use-tween-js-animation-easing/ 。通過Tween.js可以算出每一幀要移動(dòng)的距離,然后再使用requestAnimationFrame去更新坐標(biāo)。

blockAnimation: function () {            var flag = 1;            if (this.state) {  // 判斷是打亂圖片還是還原圖片                this.update(true)            } else {                flag = -1;                this.update(false);            }            var self = this;            this.startTime = +new Date();  // 獲取當(dāng)前時(shí)間            this.state = !this.state;            (function animation() {                var t = +new Date();                if (t >= self.startTime + self.duration) {  // 動(dòng)畫結(jié)束條件                    return false;                }                self.data.forEach(function (item, index) {                    if (index % 2 == 0) {                        var pos = Math.tween.Expo.easeInOut(t - self.startTime, 0, self.randoms[index] * flag, self.duration);   // 計(jì)算出每幀移動(dòng)的距離                        self.context.drawImage(self.img[self.index], item.x1 + pos, item.y1, self.wx, self.wy, item.x, item.y, self.area, self.area);                    } else {                        var pos = Math.tween.Expo.easeInOut(t - self.startTime, 0, self.randoms[index] * flag, self.duration);                          self.context.drawImage(self.img[self.index], item.x1, item.y1 + pos, self.wx, self.wy, item.x, item.y, self.area, self.area);                    }                });                requestAnimationFrame(animation);            })();        }

到這里就已經(jīng)實(shí)現(xiàn)了分離和復(fù)原的動(dòng)畫了

Canvas,圖片分割

圖片切換

接下來開始處理圖片切換的部分,這里跟輪播圖有點(diǎn)像,輪播圖動(dòng)畫是將每個(gè)圖片位置移動(dòng)可視窗口寬度的距離,這里也是一樣,只要將坐標(biāo)加上圖片高度就可以實(shí)現(xiàn)y軸上的切換。和輪播圖不一樣的是,我們這里只有一個(gè)canvas標(biāo)簽,在切換時(shí)只需要改變當(dāng)前圖和下一張圖的坐標(biāo),當(dāng)前圖移動(dòng)距離為y1 + pos,下張圖移動(dòng)距離為y1 + pos - imgHeight(為什么要減imgHeight就不用說了吧)。

//垂直滑動(dòng)動(dòng)畫        verticalAnimation: function (val) {            if (!this.time2) {                return false;            }            this.checkTime(2);            var self = this;            val ? val = 1 : val = -1;  //判斷上滑還是下滑            if ((this.index + val) < 0 || (this.index + val) >= (this.img.length)) {   //判斷圖片序號是否到底                return false;            }            this.state ? this.update(true) : this.update(false);            this.startTime = +new Date();            (function animation() {                var t = +new Date();                if (t >= self.startTime + self.duration2) {                    val === 1 ? self.index++ : self.index--;  //調(diào)整圖片順序                    self.index < 0 ? self.index = self.img.length - 1 : self.index;                    self.index >= self.img.length ? self.index = 0 : self.index;                    return false;                }                self.data.forEach(function (item) {                    var pos = Math.tween.Cubic.easeInOut(t - self.startTime, 0, (self.imgHeight) * val, self.duration2);                    // 更新當(dāng)前圖片坐標(biāo)                    self.context.drawImage(self.img[self.index], item.x1, item.y1 + pos, self.wx, self.wy, item.x, item.y, self.area, self.area);                    // 更新下張圖片坐標(biāo)                    self.context.drawImage(self.img[self.index + val], item.x1, item.y1 + pos - self.imgHeight * val, self.wx, self.wy, item.x, item.y, self.area, self.area);                });                requestAnimationFrame(animation);            })()        }

x軸的切換也是同理,現(xiàn)在所有功能都差不多完成了,完整代碼可以在codepen里查看。

Canvas,圖片分割

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持VeVb武林網(wǎng)。


注:相關(guān)教程知識閱讀請移步到HTML教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
www.日日操| 免费一级a毛片夜夜看| 国产九九精品视频| 91制片厂免费观看| 亚洲熟妇av一区二区三区漫画| 亚洲承认在线| 亚洲精品女av网站| 亚洲aa在线| 菠萝蜜视频在线观看一区| 欧美一a一片一级一片| 欧美日韩调教| 日本精品一区二区三区视频| 久久伊人91精品综合网站| 人妻少妇精品无码专区二区| 亚洲人成在线观看| 欧美网站免费| 成品网站w灬+源码1| 国产精品劲爆视频| 国产精品99久久不卡二区| 亚洲国产一区二区久久| 国内精品免费**视频| 日韩av快播网址| 欧美激情视频一区二区| 亚洲综合激情六月婷婷在线观看| 成年女人色毛片免费| 92精品国产成人观看免费| 久久久国际精品| 影音先锋在线影院| 加勒比av一区二区| 成人性生交大片免费看无遮挡aⅴ| 岛国最新视频免费在线观看| 草莓视频一区二区三区| 国产成人综合亚洲| 波多野结衣一区二区三区| 99国产精品国产精品毛片| 一区在线视频| 国产精品黄色大片| 美女露胸视频在线观看| 日韩免费电影一区二区| 天堂午夜影视日韩欧美一区二区| 欧美精选视频一区二区| 久久综合成人精品亚洲另类欧美| 男女羞羞电影免费观看| 国产精品自拍第一页| 男人靠女人免费视频网站| 欧美性受xxxx黑人猛交| 看欧美日韩国产| 成人动漫在线观看视频| 日韩av电影国产| 99久久免费精品| 日本三级电影网| 久久久久国产精品免费网站| 永久av免费在线观看| 国产亚洲成人av| 成人中文字幕av| 国产精品久久久一区麻豆最新章节| av电影网站在线观看| 国产成人精品无码免费看夜聊软件| 国产成人av免费在线观看| 999大胆视频| 蜜臀av.com| 国产美女网站视频| 欧美精品一卡| 91视频观看免费| 日本午夜一区二区| 香蕉av福利精品导航| 韩国精品久久久999| 午夜精品久久久久久久99樱桃| 国产精品女同一区二区三区| 自拍小视频在线观看| 日韩少妇内射免费播放18禁裸乳| 久久成人av少妇免费| 精品国产第一国产综合精品| 毛片毛片毛片毛片毛片毛片毛片毛片毛片| 天使と恶魔の榨精在线播放| 欧美中在线观看| 国产一精品一av一免费爽爽| 免费在线观看的电影网站| 高清av电影| 亚洲综合精品国产一区二区三区| 欧美午夜视频一区二区| 成人观看免费完整观看| 日韩在线第二页| 91成人精品视频| 欧美丰满少妇xxxxx| 超碰在线免费播放| 国产av一区二区三区| 乐播av一区二区三区| 欧洲女同同性吃奶| 四虎激情影院| 亚洲一区二区三区乱码aⅴ蜜桃女| 亚洲国产一区二区三区青草影视| 亚洲老司机av| 午夜激情福利视频| 成人性教育视频在线观看| 男人的天堂视频在线| 免费成人性网站| 国产福利视频一区| 精品国产乱码久久久久久1区二区| 91美女主播在线视频| 国产精品扒开腿做| 在线视频观看91| 久久精品女人的天堂av| 蜜臀av国产精品久久久久| 日本久久亚洲电影| 四虎影视网站| 中文字幕一区在线观看视频| 91视频免费在线看| 中文字幕成人在线| 久久久久国产| 亚洲三级中文字幕| 97超碰人人模人人爽人人看| 伊人久久精品视频| 日本一区二区三区在线免费观看| 欧美日韩三级一区| 欧美黑人精品一区二区不卡| 蜜桃在线一区二区| 国产精品久久激情| 天天干天天操天天爱| 一本色道亚洲精品aⅴ| 天堂av中文在线| 欧美精品免费在线观看| 日本18中文字幕| 日本三级久久久| 免费在线看黄色片| 欧美xxxx黑人xyx性爽| 国产原创popny丨九色| 久久午夜羞羞影院免费观看| 致1999电视剧免费观看策驰影院| 精品中文字幕在线| 亚洲天堂免费电影| 国产三级中文字幕| 亚洲av成人无码久久精品| 中文国产亚洲喷潮| 美女久久网站| 中文字幕在线一区| 国产乱理伦片在线观看夜一区| 日本精品一区二区三区不卡无字幕| 亚洲一级二级| 国产一级片av| 国产激情自拍| 最新中文字幕亚洲| 国产精品一区二区亚洲| 九色综合婷婷综合| 狠狠色丁香久久婷婷综合丁香| 久久观看最新视频| 欧美日韩一区二区免费在线观看| 国产高清不卡视频| 天天操天天综合网| 精品无码一区二区三区| www中文字幕在线观看| 日本成人小视频| 99视频国产精品| 99精品美女| 亚洲AV无码成人精品区明星换面| 性农村xxxxx小树林| 亚洲电影免费| 男女在线观看视频| 欧美多人爱爱视频网站| 色哟哟国产精品免费观看| 国产porny蝌蚪视频| 国产网站在线| 久久久久无码精品国产sm果冻| 欧美综合社区国产| 国产精品videosex极品| 6080成人| 超碰在线播放97| 日本人添下边视频免费| 日本韩国欧美在线| www.成人av.com| 这里只有精品免费视频| 久久综合伊人77777尤物| 日韩精品一区二区三区电影| 成人日韩欧美| 成人网欧美在线视频| 久久国产精品久久久| 国产永久免费| xxxxxx在线观看| 久久人人爽人人爽人人片av高清| 欧美v亚洲v综合v国产v仙踪林| 欧美激情第10页| 国产欧美日韩影院| 欧美18视频| 久久成人精品电影| 免费网站看黄yyy222| 国产富婆一区二区三区| 婷婷综合久久一区二区三区| 91精品视频专区| 国产精品久久毛片av大全日韩| 亚洲天堂av在线免费| 在线观看精品视频看看播放| 伊甸园精品99久久久久久| 91免费视频网址| 亚洲国产精品久久久久蝴蝶传媒| 国产人妻精品一区二区三区| av中文资源在线资源免费观看| 国产精品亚洲一区二区在线观看| 91青青草视频| 五月婷婷视频在线观看| 亚洲欧美激情插| 成人在线app| 黄大色黄女片18免费| 日本人69视频| 亚洲欧美成人一区二区三区| 自拍偷拍欧美视频| 久久久久久久免费视频了| 精精国产xxxx视频在线| 激情小说 在线视频| 秋霞综合在线视频| 国产精品白丝一区二区三区| 国产毛片久久久久| av国产在线观看| 天堂在线中文| 国产精品欧美一区二区| 国产秀色在线www免费观看| 日本亚洲欧洲色| 天天久久夜夜| 精品三级久久久| 精品视频在线播放色网色视频| 久久国产精品无码网站| 两个人日本在线观看视频| 亚洲精品福利在线观看| 久久a爱视频| 姝姝窝人体www聚色窝| 日韩在线观看电影完整版高清免费| 欧美大胆在线视频| 国产欧美一区二区三区鸳鸯浴| 日本成人中文字幕在线视频| 亚洲欧美中文另类| 欧美日韩中文字幕一区二区三区| 久久久久久毛片免费看| 四虎成人精品免费影院| 欧美丰满美乳xxx高潮www| 色婷婷在线观看视频| 免费福利视频一区二区三区| 欧美伊人久久大香线蕉综合69| 亚洲激情图片| 精品久久视频| 一本二本三本亚洲码| 亚洲理论电影在线观看| 91麻豆精品国产自产在线观看一区| 激情综合婷婷| 狠狠色噜噜狠狠狠狠色吗综合| 国产视频久久网| 国内一卡2卡三卡四卡在线| 亚洲一区二区电影| 亚洲午夜在线观看视频在线| 亚洲国产精品精华液2区45| 成人午夜福利一区二区| 一区二区三区网| 国产又粗又长又大的视频| 668精品在线视频| 欧美中文在线观看| 高清电影在线观看免费| 国产精品日韩在线播放| 91视频你懂的| 日本美女爱爱视频| 色噜噜成人av在线| www.久久色| 红桃成人av在线播放| 成人永久免费网站| 日本精品免费在线观看| 亚洲国产精品一区在线观看不卡| 99视频精品全国免费| 97久久精品人人爽人人爽蜜臀| 99久久婷婷国产综合精品青牛牛| 五月激情五月婷婷| 娇小的粉嫩xxx极品| 久久久久亚洲av无码a片| 久久精品亚洲精品| 国家队第一季免费高清在线观看| 波多野结衣中文字幕一区| 精品乱码一区二区三区| 亚洲一区 在线播放| 97久久久免费福利网址| 欧美性一级生活| av在线免费播放网站| 2020色愉拍亚洲偷自拍| 99精品1区2区| 99精品视频播放| 国产激情视频一区二区三区欧美| 国产毛片精品久久| 欧美人成免费网站| 亚洲国产岛国毛片在线| 狂野欧美xxxx韩国少妇| 国产乱人视频免费播放| 亚洲欧洲闷骚av少妇影院| 美女露胸一区二区三区| 最新精品国产| 性感美女一区二区三区| 国产精品久久久久aaaa| 国产999精品久久久影片官网| 99久久婷婷国产一区二区三区| 无码粉嫩虎白一线天在线观看| 成人自拍视频| 人妻激情偷乱频一区二区三区| yellow视频在线观看一区二区| 尤物国产精品| 久久精品道一区二区三区| 中文字幕在线亚洲三区| 日本亚洲欧洲色α| 天天操夜夜操夜夜操| 91精品国产综合久久男男| 中文字幕无码不卡免费视频| a视频在线免费看| 精品久久久久久中文字幕一区奶水| 久久久精品高清| xxxcom在线观看| 欧美一区二区三区成人精品| 久久亚洲精品无码va白人极品| 99久久国产视频| 国产精品日韩高清| 日韩欧美在线国产| 亚洲欧美在线精品| 国产精品美女久久久久| 欧美另类极品videosbest最新版本| 亚洲图片欧洲图片日韩av| 成人欧美一区二区三区小说| 精品av综合导航| 一区二区三区四区| 久久午夜剧场| 成年人午夜剧场| 国产精品乱战久久久| 久久精品视频一| 99伊人久久| 熟女熟妇伦久久影院毛片一区二区| 日本韩国福利视频| 国产在线精品一区二区三区》|