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

首頁 > 編程 > HTML > 正文

canvas繪圖按照contain或者cover方式適配并居中顯示

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

canvas繪圖時(shí)drawImage,需要繪制的圖片大小不同,比例各異,所以就需要像html+css布局那樣,需要contain和cover來滿足不同的需求。

contain

保持縱橫比縮放圖片,使圖片的長邊能完全顯示出來。也就是說,可以完整地將圖片顯示出來。

圖片按照contain模式放到固定盒子的矩形內(nèi),則需要對(duì)圖片進(jìn)行一定的縮放。

原則是:

如果圖片寬高不等,使圖片的長邊能完全顯示出來,則原圖片高的一邊縮放后等于固定盒子對(duì)應(yīng)的一邊,等比例求出另外一邊,

如果圖片寬高相等,則根據(jù)固定盒子的寬高來決定縮放后圖片的寬高,固定盒子的寬大于高,則縮放后的圖片高等于固定盒子的高度,對(duì)應(yīng)求出另外一邊即可,反之亦然。

        /**         * @param {Number} sx 固定盒子的x坐標(biāo),sy 固定盒子的y左標(biāo)         * @param {Number} box_w 固定盒子的寬, box_h 固定盒子的高         * @param {Number} source_w 原圖片的寬, source_h 原圖片的高         * @return {Object} {drawImage的參數(shù),縮放后圖片的x坐標(biāo),y坐標(biāo),寬和高},對(duì)應(yīng)drawImage(imageResource, dx, dy, dWidth, dHeight)         */        function containImg(sx, sy , box_w, box_h, source_w, source_h){            var dx = sx,                dy = sy,                dWidth = box_w,                dHeight = box_h;            if(source_w > source_h || (source_w == source_h && box_w < box_h)){                dHeight = source_h*dWidth/source_w;            dy =  sy + (box_h-dHeight)/2;            }else if(source_w < source_h || (source_w == source_h && box_w > box_h)){                dWidth = source_w*dHeight/source_h;                dx = sx + (box_w-dWidth)/2;            }            return{                dx,                dy,                dWidth,                dHeight            }        }        var c=document.getElementById("myCanvas");        var ctx=c.getContext("2d");        ctx.fillStyle = '#e1f0ff';        //固定盒子的位置和大小--圖片需要放在這個(gè)盒子內(nèi)        ctx.fillRect(30, 30, 150, 200);        var img = new Image();        img.onload = function () {            console.log(img.width,img.height);                        var imgRect = containImg(30,30,150,200,img.width,img.height);            console.log('imgRect',imgRect);            ctx.drawImage(img, imgRect.dx, imgRect.dy, imgRect.dWidth, imgRect.dHeight);                     }        img.src = "./timg2.jpg";          //注:img預(yù)加載模式下,onload應(yīng)該放在為src賦值的上面,以避免已有緩存的情況下無法觸發(fā)onload事件從而導(dǎo)致onload中的事件不執(zhí)行的情況發(fā)生

cover

保持縱橫比縮放圖片,只保證圖片的短邊能完全顯示出來。也就是說,圖片通常只在水平或垂直方向是完整的,另一個(gè)方向?qū)?huì)發(fā)生截取。

原理:

按照固定盒子的比例截取圖片的部分

        /**         * @param {Number} box_w 固定盒子的寬, box_h 固定盒子的高         * @param {Number} source_w 原圖片的寬, source_h 原圖片的高         * @return {Object} {截取的圖片信息},對(duì)應(yīng)drawImage(imageResource, sx, sy, sWidth, sHeight, dx, dy, dWidth, dHeight)參數(shù)        */        function coverImg(box_w, box_h, source_w, source_h){            var sx = 0,                sy = 0,                sWidth = source_w,                sHeight = source_h;            if(source_w > source_h || (source_w == source_h && box_w < box_h)){                sWidth = box_w*sHeight/box_h;                sx = (source_w-sWidth)/2;            }else if(source_w < source_h || (source_w == source_h && box_w > box_h)){                sHeight = box_h*sWidth/box_w;                sy = (source_h-sHeight)/2;            }            return{                sx,                sy,                sWidth,                sHeight            }        }        var c=document.getElementById("myCanvas");        var ctx=c.getContext("2d");        ctx.fillStyle = '#e1f0ff';        //固定盒子的位置和大小--圖片需要放在這個(gè)盒子內(nèi)        ctx.fillRect(30, 30, 150, 200);        var img = new Image();        img.onload = function () {            console.log(img.width,img.height);                        var imgRect = coverImg(150,200,img.width,img.height);            console.log('imgRect',imgRect);            ctx.drawImage(img, imgRect.sx, imgRect.sy, imgRect.sWidth, imgRect.sHeight, 30, 30, 150, 200);         }        img.src = "./timg2.jpg";          //注:img預(yù)加載模式下,onload應(yīng)該放在為src賦值的上面,以避免已有緩存的情況下無法觸發(fā)onload事件從而導(dǎo)致onload中的事件不執(zhí)行的情況發(fā)生

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


注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到HTML教程頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
欧美h视频在线观看| 国产精品国产三级国产试看| 久久不见久久见中文字幕免费| 性做久久久久久| 国产一级视频| 26uuu色噜噜精品一区| 色哟哟免费视频| 91最新国产视频| 嫩草精品影院| 国产伦视频一区二区三区| 中文字幕一区二区人妻电影| 国产精品久久久久久久久免费相片| 亚洲欧洲精品一区二区三区波多野1战4| 猫咪在线永久网站| 一区二区三区日本视频| 日韩美女网站| 91在线一区| 天堂在线中文字幕| 一区二区三区四区亚洲| 在线免费一区二区| 五月精品在线| 亚洲欧洲国产精品久久| 久久99精品久久久久| 一区二区视频免费| 亚洲欧美精品中文字幕在线| 在线一区日本视频| 国产精品久久久久久久久果冻传媒| 亚洲私人影院| 一级黄色片免费看| 亚洲国产精品一区二区久久恐怖片| 国产一二三区在线观看| 国产精品户外野外| 好男人香蕉影院| 亚洲图片制服诱惑| 国产91一区二区三区| 国产视频一区在线观看一区免费| 国产亚洲精品福利| 国产精品888| 激情网址大全| 欧美日韩蜜桃| 黄漫在线观看| 中文字幕一区二区在线播放| 中文在线字幕观看| av中文资源在线资源免费观看| 男人操女人下面视频| 亚洲大奶少妇| 国产精品偷伦一区二区| 在线观看免费91| 成年人观看网站| 97超碰人人看人人| 精品精品欲导航| 中文字幕中文乱码欧美一区二区| 黄网站在线免费| 二区三区在线| 色偷偷成人一区二区三区91| 天堂社区日本电影超碰| 无码国产精品高潮久久99| 精品96久久久久久中文字幕无| 中中文字幕av在线| 欧美成人乱码一二三四区免费| 欧美日韩国产高清一区二区三区| 96av在线| 国产又粗又猛又爽又黄的视频小说| 成人女人a毛片在线看| 极品美女扒开粉嫩小泬| 国产一区二区三区影视| 国产jizz18女人高潮| 无码国产精品一区二区免费式直播| 日韩在线一区二区视频| 国产精品一区二区不卡视频| 欧美无人高清视频在线观看| 亚洲一区二区三区国产| 伊人久久一区| 91福利电影| 久久精品一级片| 五月婷婷综合色| 精品中文视频在线| 亚洲欧洲www| av久久久久久| 天堂av中文在线资源库| 中文字幕乱码在线观看| 日本欧美视频| 欧美大片欧美激情性色a∨久久| 136国产福利精品导航| 中文字幕少妇| 四虎国产精品成人免费入口| 久久综合一区二区三区| 国产羞羞视频在线播放| 欧美图区在线视频| 久久这里只有精品视频首页| 欧美性生活一级| 黄色三级小视频| 毛片在线视频| 欧美精品中文| 国产一区二区网址| 午夜一区二区三区| 成人免费淫片在线费观看| 999在线视频| 影音先锋国产在线资源| 蜜臀av一区二区在线观看| 欧美久久在线| 在线播放亚洲| 亚洲国产视频网站| 亚洲一区二区在线视频| 99久久久久免费精品国产| 久久精品人人爽| 8x8x视频在线| 国产精品99一区二区三区| 精品少妇一区二区三区在线播放| 成人羞羞动漫| 97一区二区三区| 国产精品国产三级欧美二区| 亚洲成人av高清| 四季av综合网站| 国产在线98福利播放视频| 6—12呦国产精品| 日韩精品一区二区三区在线| 国产又粗又猛又黄| 国产999精品久久久久久| 欧美理论片在线播放| 九色蝌蚪在线视频| 美女福利视频一区| 日韩成人在线看| 综合分类小说区另类春色亚洲小说欧美| 国产欧美一区二区三区在线看蜜臂| 自拍偷拍一区二区三区| 一区二区三区成人| free极度另类性欧美| 欧美久久久久久久久中文字幕| 俺去啦在线观看| 欧美精品999| 高清视频一区二区三区四区| 亚洲精品久久久狠狠狠爱| 国产乱妇乱子在线播视频播放网站| 国产一区二区精品久久99| 国产成人免费视频网站| 久久久久久无码精品大片| 一区二区三区精品牛牛| av一级在线| 午夜激情福利电影| 日韩免费小视频| 国产婷婷在线观看| 亚洲一区二区在线播放相泽| 日韩美女一区二区三区在线观看| 国产精品免费一区二区三区| 精品动漫av| 天堂久久午夜av| 午夜欧美精品久久久久久久| 亚洲精品无码久久久久| 免费黄色片网站| 国产在线高清精品| 伊人亚洲视频| 久久伊人亚洲| 欧美性xxxx69| 国产伦精品一区二区三区高清版| 国产人妖一区二区三区| 天堂av2024| 国产老熟妇精品观看| 成人区一区二区| av在线无限看| 精品福利影视| 9999精品视频| 国产精品黄色| 亚洲精品一区三区三区在线观看| 欧美日韩免费在线| 91视频你懂的| 亚洲一区二区在线看| 丝袜老师办公室里做好紧好爽| 在线观看免费小视频| 不卡在线观看av| 欧美一级手机免费观看片| 亚洲精品中文字幕乱码| 在线观看中文字幕一区| 男人网站在线观看| 国产精品一级伦理| 国产精品网红福利| 欧美日韩精品综合在线| 老牛影视av老牛影视av| 亚洲激情不卡| 免费看黄色一级大片| 久久白虎精品| 美女精品一区最新中文字幕一区二区三区| 日本高清在线观看wwwww色| 黑人巨大国产9丨视频| 黑人无套内谢中国美女| 中文精品一区二区| 欧美福利电影网| 四虎国产精品永远| 日本福利午夜视频在线| 亚洲一卡二卡区| 最近中文字幕2019免费| 午夜精品久久久久久久久久久久久蜜桃| 91电影91视频| 亚洲综合久久av一区二区三区| 久久午夜色播影院免费高清| 亚洲中文一区二区三区| 人人干人人爱人人爱| 制服.丝袜.亚洲.中文.综合| 久久99精品国产麻豆不卡| 91九色丨porny丨国产jk| 大波视频国产精品久久| 特级西西www444人体聚色| 狠狠狠狠狠狠狠| 久久精品无码一区二区三区毛片| 国产午夜精品一区二区三区嫩草| 全部孕妇毛片丰满孕妇孕| 在线亚洲一区二区| 黄网站免费看| 国产精品一区免费在线| 亚洲视频网站在线| 欧美在线 | 亚洲| 欧美成人午夜做爰视频在线观看| av三级在线观看| 成人性生交大片免费看网站| 91免费看视频| 国内久久久精品| 久久久久久亚洲精品| 九九九久久国产免费| 香蕉久久久久久av成人| 久久福利在线| 国产xxxx做受性欧美88| 午夜精品国产| 成人一区二区电影| 日韩亚洲精品视频| h视频在线免费观看| 夜夜爽夜夜操| 久久免费看av| 一区二区三区在线播| 中文日韩在线| 国产99视频精品免费视频36| 人人爽人人爽人人片| 欧美日本视频在线| 国产九九精品视频| 久草在线视频资源| 亚洲国产精品女人久久久| 国产传媒在线视频| 亚洲国产女人aaa毛片在线| 最新亚洲伊人网| 国产调教视频在线观看| h视频在线观看网站| 亚洲ⅴ国产v天堂a无码二区| 99热热99| 欧美freesextv| 欧美日韩三级在线观看| 丰满岳乱妇国产精品一区| 久久久久久久久久久久久夜| 99国产在线观看| 日韩成人免费电影| 精品亚洲成av人在线观看| 欧美性xxxx极品hd欧美| 精品麻豆一区二区三区| 亚洲激情婷婷| 777午夜精品电影免费看| 日本中文字幕在线视频观看| 三级成人在线视频| 玉米视频成人免费看| 国产一区二区三区色淫影院| 2018高清国产日本一道国产| www.xxx黄| 亚洲天堂成人在线视频| 欧美老熟妇一区二区三区| 加勒比色综合久久久久久久久| 天堂av电影在线观看| 精品产品国产在线不卡| 国语自产精品视频在线看8查询8| 欧美午夜精品久久久久久蜜| 欧美亚洲国产另类| 日韩男人的天堂| 亚洲日本久久久| 粉嫩tv在线播放| 亚洲国产裸拍裸体视频在线观看乱了| 四虎影视精品永久在线观看| 国产97免费视| 日韩精品有码在线观看| 久久久久99精品成人片| 欧美日韩中文国产| 午夜精品久久久久影视| 亚洲va欧美va国产综合剧情| 中文字幕亚洲综合久久五月天色无吗''| 神马久久久久久久| 日本中文字幕成人| 美女网站一区二区| 国产精品久久久免费视频| 97精品一区二区三区| 久久这里只有精品首页| 色哟哟网站入口亚洲精品| 一区二区欧美亚洲| 亚洲精品视频网上网址在线观看| 国产精品久久久91| 福利网在线观看| 怡红院成人在线| 视频一区二区三区国产| 亚洲影视综合| 亚洲第一视频网| 能直接看的av| 91夜夜蜜桃臀一区二区三区| 国产伦精品一区二区三区免费迷| 在线日韩网站| 深夜福利一区二区三区| 免费一级特黄录像| 亚洲精品久久区二区三区蜜桃臀| 国内精品免费在线观看| 美女视频一区在线观看| 欧美综合国产| 日韩成人午夜| 国产精品久久午夜夜伦鲁鲁| 久热这里只有精品在线| 欧美在线一级va免费观看| 亚洲免费中文| 欧美jizzhd精品欧美另类| 亚洲午夜羞羞片| 亚洲一区二三区| 日本免费黄色| 成人手机在线视频| 国产mv免费观看入口亚洲| 国产一区二区三区四区三区四| 成人网免费看| 蜜乳av中文字幕| yy6080午夜| 黄色无遮挡网站| 日本888xxxx| 国内精品免费视频精选在线观看| 日韩高清中文字幕一区二区| caoporm超碰国产精品| 裸体丰满少妇做受久久99精品| 香蕉视频网页版| 精品国产sm最大网站免费看| 99精品免费观看|