婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Canvas圖片分割效果的實現

Canvas圖片分割效果的實現

熱門標簽:欣鼎電銷機器人 效果 智能電銷機器人被禁用了么 黃石ai電銷機器人呼叫中心 如何查看地圖標注 惡搞電話機器人 ok電銷機器人 電話機器人技術 地圖標注軟件打印出來 高德地圖標注商戶怎么標

之前在逛cssdesignawards時發現了一個把圖片內容分割的效果(網址:https://weareludwig.com),大家可以點進去看看,感覺挺炫酷的,于是自己試著實現了一下,效果還不錯。效果查看https://codepen.io/geeknoble/pen/OQaOVG

分析

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

初始工作

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

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;                       //當前圖片序號
            this.width = width;                  //畫布寬高
            this.height = height;
            this.area = height/12;                     //小矩形長度
            this.countX = width / this.area;             //水平和垂直方向小矩形個數
            this.countY = height / this.area;
            this.wx = this.imgWidth / this.countX;      //圖片在小矩形中的寬高
            this.wy = this.imgHeight / this.countY;
            this.state = true;                   //圖片狀態,true表示未拆分
            this.dataFlag = true;                //小矩形坐標狀態,true表示未加上隨機值
            this.duration = 1000;                 //動畫時間
            this.duration2 = 1500;
            this.startTime = 0;
            this.data = [];                       //小矩形坐標信息
            this.randoms = [];                    //位置隨機值
            //初始化矩形坐標
            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);
                    //儲存矩形坐標
                    this.data.push({
                        x1: x1,
                        y1: y1,
                        x: x,
                        y: y
                    });
                    //添加隨機值
                    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();
        }

檢測邊緣

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

//檢測邊緣
        checkMargin: function () {
            var self = this;
            this.data.forEach(function (item, index) {
                if (index % 2 == 0) {  // 下標為2的倍數時移動x軸,否則移動y軸
                    if ( item.x1 + self.randoms[index] < 0)
                        // 改為正數
                        self.randoms[index] = -self.randoms[index];
                    if (item.x1 + self.wx + self.randoms[index] > self.imgWidth )
                        // 改為負數
                        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])
                }
            })
        }

分離和復原

動畫的內容的分離和復原就是更新矩形坐標的值,打亂內容只要將data里的坐標加上隨機值,而復原就是減去隨機值,

//檢測邊緣
        checkMargin: function () {
            var self = this;
            this.data.forEach(function (item, index) {
                if (index % 2 == 0) {  // 下標為2的倍數時移動x軸,否則移動y軸
                    if ( item.x1 + self.randoms[index] < 0)
                        // 改為正數
                        self.randoms[index] = -self.randoms[index];
                    if (item.x1 + self.wx + self.randoms[index] > self.imgWidth )
                        // 改為負數
                        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])
                }
            })
        }

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

blockAnimation: function () {
            var flag = 1;
            if (this.state) {  // 判斷是打亂圖片還是還原圖片
                this.update(true)
            } else {
                flag = -1;
                this.update(false);
            }
            var self = this;
            this.startTime = +new Date();  // 獲取當前時間

            this.state = !this.state;
            (function animation() {
                var t = +new Date();
                if (t >= self.startTime + self.duration) {  // 動畫結束條件
                    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);   // 計算出每幀移動的距離
                        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);
            })();
        }

到這里就已經實現了分離和復原的動畫了

圖片切換

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

//垂直滑動動畫
        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--;  //調整圖片順序
                    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);
                    // 更新當前圖片坐標
                    self.context.drawImage(self.img[self.index], item.x1, item.y1 + pos, self.wx, self.wy, item.x, item.y, self.area, self.area);
                    // 更新下張圖片坐標
                    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軸的切換也是同理,現在所有功能都差不多完成了,完整代碼可以在codepen里查看。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

標簽:聊城 綏化 阿壩 萍鄉 赤峰 金昌 盤錦 中山

巨人網絡通訊聲明:本文標題《Canvas圖片分割效果的實現》,本文關鍵詞  Canvas,圖片,分割,效果,的,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Canvas圖片分割效果的實現》相關的同類信息!
  • 本頁收集關于Canvas圖片分割效果的實現的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    亚洲成人动漫在线免费观看| 国产精品视频一区二区三区不卡| 波多野结衣中文字幕一区二区三区| 日本成人中文字幕| 免费欧美日韩国产三级电影| 午夜精彩视频在线观看不卡| 日韩**一区毛片| 精品一区二区三区蜜桃| 成人综合在线网站| 91免费看视频| 欧美疯狂性受xxxxx喷水图片| 欧美日韩一级二级| 日韩欧美一区在线| 国产女人18水真多18精品一级做| 欧美国产精品一区二区三区| 亚洲欧洲在线观看av| 亚洲欧美韩国综合色| 亚洲成av人片一区二区| 激情丁香综合五月| 波多野结衣精品在线| 欧美在线观看18| 精品美女被调教视频大全网站| 久久久亚洲精华液精华液精华液 | 日韩av一级片| 国产精品18久久久久久久久久久久 | 26uuu精品一区二区| 中文字幕久久午夜不卡| 亚洲品质自拍视频网站| 蜜臀av性久久久久蜜臀aⅴ四虎| 国产69精品久久久久毛片| 在线亚洲+欧美+日本专区| 精品国产亚洲一区二区三区在线观看 | 一二三区精品福利视频| 免费观看久久久4p| 97se狠狠狠综合亚洲狠狠| 欧美一区二区在线视频| 亚洲视频免费看| 精品一区二区三区蜜桃| 日本精品一区二区三区高清| 亚洲精品在线网站| 日韩激情一二三区| 99久久久久免费精品国产| 精品乱人伦小说| 亚洲自拍与偷拍| www.av亚洲| 久久精品亚洲精品国产欧美kt∨| 亚洲成人动漫精品| 日本韩国精品在线| 欧美激情一区二区在线| 麻豆国产一区二区| 7777精品久久久大香线蕉| 成人免费在线播放视频| 国产91高潮流白浆在线麻豆| 日韩精品中文字幕一区二区三区| 亚洲国产精品一区二区www在线| 99re这里只有精品首页| 国产色综合一区| 国产美女娇喘av呻吟久久| 日韩一区二区三免费高清| 天天操天天综合网| 欧美日韩视频在线观看一区二区三区 | 国产一区二区女| 日韩欧美高清一区| 丝袜美腿高跟呻吟高潮一区| 精品视频123区在线观看| 亚洲欧洲日韩综合一区二区| 成人午夜私人影院| 国产精品国产自产拍高清av王其| 国产真实精品久久二三区| 日韩精品中午字幕| 激情成人午夜视频| 久久久精品影视| 国产一区二区剧情av在线| 日韩免费高清视频| 国产在线观看一区二区| 久久久www成人免费毛片麻豆 | 欧美变态凌虐bdsm| 青青草97国产精品免费观看 | www欧美成人18+| 国产伦精品一区二区三区在线观看| 日韩精品最新网址| 国产99久久久久| 日韩理论电影院| 欧美精品一卡二卡| 另类小说综合欧美亚洲| 国产色婷婷亚洲99精品小说| 91丨porny丨蝌蚪视频| 亚洲九九爱视频| 欧美高清dvd| 欧美日韩精品一区二区| 91亚洲精品久久久蜜桃网站| 国产精品一区不卡| 亚洲同性同志一二三专区| 亚洲国产精品影院| 精品欧美乱码久久久久久| 国产成人av电影在线播放| 国产精品久久精品日日| 欧美专区日韩专区| 韩国三级电影一区二区| 亚洲日本一区二区三区| 日韩天堂在线观看| 成人av网站免费| 日韩精品一二区| 欧美精彩视频一区二区三区| 欧美吻胸吃奶大尺度电影 | 精品999在线播放| 91啪亚洲精品| 免费国产亚洲视频| 国产精品久久久久一区二区三区共| 91高清在线观看| 国产精品99久久久久久似苏梦涵 | 精品视频在线视频| 国产精品一区三区| 亚洲一区二区三区四区在线观看| 久久久综合精品| 欧美剧情片在线观看| caoporen国产精品视频| 久久精品国产网站| 亚洲www啪成人一区二区麻豆| 久久精品夜色噜噜亚洲aⅴ| 91麻豆精品国产91久久久久| av亚洲精华国产精华精| 狠狠色丁香九九婷婷综合五月| 亚洲美女视频在线| 欧美国产一区视频在线观看| 日韩一区二区电影网| 欧美在线观看18| 91女神在线视频| 成人h动漫精品| 粉嫩在线一区二区三区视频| 精品一区二区免费视频| 午夜精品久久久久久久99水蜜桃| 亚洲同性同志一二三专区| 中文字幕精品三区| 国产亚洲综合色| 欧美哺乳videos| 欧美大片拔萝卜| 日韩一区二区精品在线观看| 欧美精品一卡二卡| 555www色欧美视频| 欧美一级免费大片| 欧美久久一二三四区| 欧美日韩三级一区| 在线视频国内自拍亚洲视频| 91日韩一区二区三区| 在线免费观看日本一区| 91成人免费在线视频| 色婷婷激情一区二区三区| 日本丰满少妇一区二区三区| 色综合天天视频在线观看| 色悠久久久久综合欧美99| 91网上在线视频| 欧美在线三级电影| 欧美日韩亚洲高清一区二区| 7777精品伊人久久久大香线蕉| 欧美二区在线观看| 欧美一区二区三区视频免费| 欧美mv和日韩mv的网站| 久久久一区二区| 自拍偷自拍亚洲精品播放| 亚洲精品日韩专区silk| 偷拍一区二区三区四区| 国内精品写真在线观看| 成人免费的视频| 欧美中文字幕不卡| 欧美日韩高清一区| 国产亚洲一二三区| 亚洲人成小说网站色在线 | 午夜精品在线视频一区| 久久99国产精品尤物| 福利一区二区在线| 欧日韩精品视频| 欧美精品一区男女天堂| 亚洲图片你懂的| 免费精品99久久国产综合精品| 国产精品一区一区| 91碰在线视频| 欧美不卡一二三| 曰韩精品一区二区| 精品影视av免费| 91麻豆视频网站| 久久综合九色综合欧美98 | 在线播放91灌醉迷j高跟美女| 欧美一区日韩一区| 亚洲欧美在线观看| 六月丁香婷婷色狠狠久久| av日韩在线网站| 日韩免费在线观看| 亚洲一区二区三区激情| 国产69精品久久久久毛片| 欧美日本国产一区| 国产精品不卡一区二区三区| 美国毛片一区二区| 日本福利一区二区| 欧美激情一区二区三区蜜桃视频 | 久久免费美女视频| 亚洲成人免费在线| 99麻豆久久久国产精品免费| 日韩欧美一区二区久久婷婷| 亚洲一区二区中文在线|