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

首頁 > 編程 > HTML > 正文

canvas拼圖功能實(shí)現(xiàn)代碼示例

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

最近做項目的時候遇到照片拼圖的功能,便在這里分享自己的封裝的canvas拼圖功能,可能代碼寫的不好,如果有疑問或者是有更好的方法的,可以私聊我,或者是評論指出,感謝各位

實(shí)現(xiàn)的思路其實(shí)挺簡單的,主要是通過服務(wù)端獲取圖片鏈接,圖片寬度,圖片高度,然后利用簡單的遞歸實(shí)現(xiàn)就行了(注意移動端需要采用2倍數(shù)的比例,否則會出現(xiàn)圖片模糊的問題)

/**     * canvas繪圖數(shù)據(jù)     * @param {Object[]} option.photoData     * @param {string} option.photoData[].photo - 照片的鏈接地址     * @param {number} option.photoData[].width -  照片的寬度     * @param {number} option.photoData[].height -  照片的高度     * @param {Object[]} option.wordData     * @param {string} option.wordData[].color - 文字的顏色     * @param {number} option.wordData[].fontSize - 文字的大小     * @param {string} option.wordData[].fontWeight -  文字的粗細(xì)     * @param {number} option.wordData[].left - 文字的左邊距     * @param {number} option.wordData[].top -  文字的上邊距     * @param {string} option.wordData[].word -  文字的內(nèi)容     * @param {Object[]} option.iconData     * @param {string} option.iconData[].photo - icon的鏈接地址     * @param {number} option.iconData[].left -  icon的左邊距     * @param {number} option.iconData[].top -  icon的上邊距     * @param {number} option.iconData[].width -  icon的寬度     * @param {number} option.iconData[].height -  icon的高度     *    */function canvasDraw(option){        var canvas = document.createElement('canvas'),            ctx = canvas.getContext('2d'),            clientWidth = document.documentElement.clientWidth,            canvasHeight = 0,            distance = 0,            photoCount = 0,            iconCount = 0;        // canvas中手機(jī)上一倍繪圖會模糊,需采用兩倍,pc端不會。            clientWidth = clientWidth > 480? 480 * 2 : clientWidth * 2;         option.photoData.forEach(function(item,index,picArr){            if (!index) {                item.distance = 0;            }else if(index){                distance += Math.floor(clientWidth / option.photoData[index - 1].width * option.photoData[index - 1].height)                item.distance = distance;            }            canvasHeight += Math.floor(clientWidth / item.width * item.height);            item.imgHeight = Math.floor(clientWidth / item.width * item.height);        })                console.log(option.photoData)        if (ctx) {            canvas.width = clientWidth;            canvas.height  = canvasHeight + clientWidth / 4 * 2                    ctx.fillStyle = '#fff'            ctx.fillRect(0, 0, canvas.width, canvas.height)            // 繪制圖片文字            if(option.wordData.length){                option.wordData.forEach(function(item,index){                    ctx.fillStyle = item.color;                    ctx.font = 'normal normal ' + item.fontWeight + ' ' + calculate(item.fontSize) + 'px Microsoft YaHei';                    ctx.textAlign = 'left';                    ctx.fillText(item.word, calculate(item.left), canvasHeight + calculate(item.top));                    })            }            //按比例計算不同手機(jī)的百分比間距            function calculate(num){                return Math.floor(clientWidth * num / 750)            }            drawPhoto('photo0')            function drawPhoto(photoDom){                var photoDom = new Image();                    photoDom.setAttribute('crossOrigin', 'Anonymous');                photoDom.src = option.photoData[photoCount].photo;                photoDom.onload = function(){                    ctx.drawImage(photoDom, 0, option.photoData[photoCount].distance, clientWidth, option.photoData[photoCount].imgHeight);                    photoCount++;                    if (photoCount == option.photoData.length) {                        drawIcon('icon0')                        function drawIcon(iconDom){                            var iconDom = new Image();                                iconDom.setAttribute('crossOrigin', 'Anonymous');                            iconDom.src = option.iconData[iconCount].icon;                            iconDom.onload = function(){                                ctx.drawImage(iconDom, calculate(option.iconData[iconCount].left), canvasHeight + calculate(option.iconData[iconCount].top), calculate(option.iconData[iconCount].width), calculate(option.iconData[iconCount].height))                                iconCount++;                                if (iconCount == option.iconData.length) {                                    var imageURL = canvas.toDataURL("image/jpeg")                                    document.getElementsByClassName('shareImg')[0].setAttribute('src', imageURL)                                    //將閉包引用清除,釋放內(nèi)存;                                    drawPhoto = null;                                }else{                                    drawIcon('icon' + iconCount)                                }                            }                            }                                                     }else{                        drawPhoto('photo'+ photoCount)                                            }                    }                                                            }        }else{            console.log('不支持canvas')        }    }

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


注:相關(guān)教程知識閱讀請移步到HTML教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
插我舔内射18免费视频| 久久精品国产av一区二区三区| 草草影院在线观看| ts人妖交友网站| 日韩一级网站| 久久美女视频| 欧美久久久久久久久久久久久久| 推川ゆうり中文亚洲二区| 中文字幕成在线观看| 精品一区二区视频在线观看| 在线观看黄色av| 在线播放一区二区三区| www.久久伊人| 中文字幕高清在线播放| 亚洲一区二区伦理| 曰韩不卡视频| 911精品国产一区二区在线| 亚洲一区二区三区爽爽爽爽爽| 色综合导航网站| 日韩不卡视频在线| 免费av网站在线观看| 欧日韩不卡视频| 国产精品夜色7777狼人| 91精品国产自产91精品| 亚洲免费伊人电影在线观看av| 欧美这里有精品| 美女爽到高潮91| 亚洲精选成人| 一级毛片在线视频| 欧美老妇交乱视频| 日日夜夜天堂| 亚洲福利视频二区| 日韩免费高清视频网站| 国产精品91视频| 久久久久久毛片| 国产精品丝袜一区二区三区| 91在线网站| 午夜精品一区二区三| 99久久精品国产一区| 欧美精品一二| 精品国产九九九| 欧美挠脚心网站| 一级特黄录像免费播放全99| 天天操天天操天天色天天要| 午夜精品福利一区二区蜜股av| 精品乱色一区二区中文字幕| seseavlu视频在线| 国产欧美日韩网站| 亚洲v欧美v另类v综合v日韩v| av影视在线| 免费看日产一区二区三区| 久久这里只有精品1| 啪啪免费网站| 日本一区二区三区视频在线| 欧美成人高清视频在线观看| 黄色激情视频网址| 成人婷婷网色偷偷亚洲男人的天堂| 99久久夜色精品国产亚洲1000部| 国产区在线观看| 国产精品熟女一区二区不卡| 国产中文字幕在线看| 综合网中文字幕| 精品国产二区在线| 日本大片在线看黄a∨免费| 亚洲永久精品国产| 四虎永久在线精品| 青青草原av在线| 麻豆网站免费在线观看| 日本孕妇大胆孕交无码| 日本精品久久久| av一区二区三| 日韩福利在线| 日本激情视频一区二区三区| 久久人妻少妇嫩草av无码专区| 爱爱爱免费视频在线观看| 偷窥自拍欧美色图| 小早川怜子影音先锋在线观看| 偷拍自拍亚洲色图| 成人免费网站视频www| 在线一区二区三区精品| 欧美性感美女一区二区| 中文av一区二区三区| 色综合天天狠天天透天天伊人| 久久伊人蜜桃av一区二区| 成人午夜sm精品久久久久久久| 中文字幕视频网| 国产精品100| 超碰在线中文| 老司机av在线免费看| 中文字幕在线观看亚洲| 国产午夜精品一区二区三区欧美| 日本成人在线电影网| 暧暧视频在线免费观看| 综合欧美一区二区三区| 婷婷六月天丁香| 欧美丝袜第三区| 欧美国产日韩一区二区在线观看| 亚洲国产精品一区制服丝袜| 成人国产精品久久久网站| ,亚洲人成毛片在线播放| 久久久久久一区| 一级免费在线观看| 精品国产人妻一区二区三区| 亚洲自拍另类欧美丝袜| 国产视频在线观看视频| 国产亚洲成aⅴ人片在线观看| 色诱视频在线观看| 亚洲欧洲无码一区二区三区| 天天爽夜夜爽夜夜爽精品| 佐佐木明希电影| 成熟亚洲日本毛茸茸凸凹| 日韩中文字幕视频| 九九综合九九综合| 3dmax动漫人物在线看| 国产日韩精品在线播放| 波多野结衣在线aⅴ中文字幕不卡| 亚洲a级在线观看| 日韩精品无码一区二区三区久久久| 在线观看www91| 天天色棕合合合合合合合| 国产 日韩 欧美 在线| 色七七在线观看| 922tv免费观看在线| 日本免费一区二区视频| 亚洲 美腿 欧美 偷拍| 九九热免费精品视频| 在线欧美一级视频| 国产婷婷在线视频| 澳门永久av免费网站| 色综合天天做天天爱| 大片免费在线看视频| 最新国产在线| 久久久国产精品免费| 国产精品一级在线观看| 日本精品600av| 99视频在线观看一区三区| 精品一区二区三区在线视频| 亚洲专区区免费| 在线观看欧美亚洲| 久久黄色av网站| 欧美videossexotv100| 欧美在线观看黄| 久久香蕉精品香蕉| 亚洲男子天堂网| 69堂成人精品免费视频| 国产69精品久久久久毛片| 国产农村妇女精品一区| 国产成人小视频在线观看| 美女做爰内谢全过程视频| av中文资源在线| 黄视频免费在线看| 国产一在线精品一区在线观看| 亚洲美女在线视频| 日韩一区日韩二区| 国产精品一区二区三区观看| 少妇av一区二区三区无码| 激情视频亚洲| 狠狠色丁香久久婷婷综| 久久精品日产第一区二区三区乱码| 狠狠色丁香婷婷综合久久片| 91九色丨porny丨极品女神| 国产成人无码一区二区三区在线| 伊人久久男人天堂| 少妇精品久久久一区二区三区| 96成人在线视频| 日本午夜视频在线观看| 亚洲狼人国产精品| 欧美极品少妇与黑人| 色猫猫成人app| 九色porny自拍视频在线播放| 国产精品视频免费在线| 秋霞蜜臀av久久电影网免费| av电影在线播放高清免费观看| 大胆人体一区二区| 亚洲精品视频免费| 欧美成人精品3d动漫h| 老司机在线视频二区| 91亚洲天堂| 欧美探花视频资源| 一个人看的日本www的免费视频| 久久电影tv| 亚洲高清视频的网址| 5566日本婷婷色中文字幕97| av成人网在线| 97欧美成人| 国产精品久久久久久婷婷天堂| 精品久久一区二区| 国产精品视频yy9299一区| 国产精品被窝福利一区| 国产一区二区三区久久久| 欧美中文字幕亚洲一区二区va在线| 国产成人在线观看免费网站| 黄网站app在线观看下载视频大全官网| 欧美精品久久久久久久久46p| 欧美精品亚州精品| 日韩精品视频中文字幕| 污软件在线观看| 日韩精品免费一区二区夜夜嗨| 欧美精品自拍偷拍动漫精品| 欧美性www| 国产精品一区二区三区免费观看| 欧美视频三区在线播放| 在线看国产精品| 免费在线视频一级不卡| 日韩欧美国产骚| 午夜免费福利视频| 久久九九视频| 四虎国产成人永久精品免费| 高潮在线视频| 女女互磨互喷水高潮les呻吟| 国产精品高潮呻吟av| av一本在线| 国产精品一二三四五区| 亚洲视频1区| 狠狠色狠狠色综合人人| 男人插女人下面免费视频| 三级影片在线观看| 免费女人黄页| 自拍亚洲国产| 曰批又黄又爽免费视频| 麻豆91精品视频| 成人免费网站观看| 日韩欧美中字| 一区国产精品视频| 国产精品日日摸夜夜摸av| 伊人狠狠色j香婷婷综合| 欧美性猛交xxxx免费看久久| 91国偷自产一区二区使用方法| 超级碰碰久久| 综合一区av| 久久亚洲精品中文字幕| 五十度飞在线播放| 99久久久国产精品免费调教网站| 三级在线视频观看| 亚洲一区 视频| 91性高湖久久久久久久久_久久99| 久久久国产视频| 三级ai视频| 亚洲日本在线观看视频| 久久青草伊人| 一区二区三区日韩精品| 亚洲在线视频播放| 天天看天天干| 免费下载黄色软件| 九九**精品视频免费播放| 最新国产中文字幕| 亚洲女人av| 中文字幕另类日韩欧美亚洲嫩草| 国产91ⅴ在线精品免费观看| 日本韩国在线视频| av电影在线观看一区| 九色porny视频在线观看| 国产精品入口免费| 免费黄色在线播放| 99在线观看| 久青草国产97香蕉在线视频| 国产极品精品在线观看| 中文字幕欧美区| 久久激情五月婷婷| 一区二区三区在线观看免费| 91麻豆国产香蕉久久精品| 99reav在线| 久久视频一区二区三区| 884aa四虎免费影库4h| www婷婷av久久久影片| 成人黄色生活片| 成人免费在线播放| 欧美另类极限扩张| 日韩国产欧美在线视频| 又黄又爽的视频在线观看| 亚洲第一精品在线观看| 亚洲精品自在久久| 国产曰批免费观看久久久| 欧美黑人做爰爽爽爽| 欧美国产激情视频| 亚洲人成自拍网站| 精品少妇人妻av免费久久洗澡| 欧美高清视频一区二区三区在线观看| 亚洲精品在线网址| www日本黄色| 亚洲欧洲日产国码二区| 欧美精品videossex变态| 久久视频一区| 欧美精品一区二区三区很污很色的| 91国产在线播放| 久久久久99精品成人片我成大片| 亚洲免费网站在线观看| 懂色av蜜桃av| 亚洲精品视频在线观看免费| www.麻豆av.com| 欧美日一区二区在线观看| 亚洲高清久久| 日韩精品在线免费看| 国产无套内射又大又猛又粗又爽| 日韩的一区二区| 中文字幕自拍偷拍| 欧美91精品久久久久国产性生爱| 日本国产在线| 免费黄色福利视频| 久久97超碰国产精品超碰| 精品九九在线| 老熟妇精品一区二区三区| 国产在线天堂www网在线观看| 国内成人精品视频| 24小时成人在线视频| 91蝌蚪精品视频| 日韩色性视频| 成人无码一区二区三区| 不卡在线观看av| 国产精品亚洲第一区在线暖暖韩国| av免费播放网站| 国产欧美综合在线| 久久久久九九九| 欧美伦理91| 日韩伦理在线| 亚洲人成电影在线| 在线免费看污网站| 久久久久久成人| av一区在线| 日韩三级影视| 日韩中文字幕免费看| 99国产精品久久一区二区三区| 婷婷在线视频| 99久久久无码国产精品| 国产夫妻自拍av| 一区二区在线中文字幕电影视频| 欧美日韩国产区| 综合电影一区二区三区|