摘要:有時(shí)候,我們需要顯示一個(gè)許多用戶組合的一個(gè)頭像,像扣扣的討論組頭像,微信的群頭像,下面是一個(gè)簡(jiǎn)單的實(shí)現(xiàn)方法首先,獲取你需要的頭像圖片地址,保存在一個(gè)對(duì)象里面,例如然后可以限定組合圖片的最大個(gè)數(shù),比如限定四個(gè),那么久判斷數(shù)據(jù)庫里的圖片個(gè)數(shù)是否
有時(shí)候,我們需要顯示一個(gè)許多用戶組合的一個(gè)頭像,像扣扣的討論組頭像,微信的群頭像,下面是一個(gè)簡(jiǎn)單的實(shí)現(xiàn)方法:
首先,獲取你需要的頭像圖片地址,保存在一個(gè)對(duì)象里面,例如:
var data = []; 然后可以限定組合圖片的最大個(gè)數(shù),比如限定四個(gè),那么久判斷數(shù)據(jù)庫里的圖片個(gè)數(shù)是否大于4,如果大于4,那么就取前四個(gè),如果不大于4,那么就取完。
隨后,看注釋:
var base64 = []; //用來裝合成的圖片 var c = document_createElement_x_x("canvas"); //創(chuàng)建一個(gè)canvas var ctx = c.getContext("2d");//返回一個(gè)用于在畫布上繪圖的2維環(huán)境 var len = data.length; //獲取需要組合的頭像圖片的張數(shù) var a = 0; //初始化需要組合頭像的長度 var b = 0; //初始化需要組合頭像的寬度 c.width = 290; //定義canvas畫布的寬度 c.height = 290; //定義canvas畫布的高度 ctx.rect(0, 0, c.width, c.height); //畫矩形 ctx.fillStyle = "#fff"; //設(shè)置矩形顏色 ctx.fill(); //關(guān)閉并填充該路徑
接下來就需要寫一個(gè)function開始畫:
?functiondrawing(n){ //參數(shù)n是傳入的是數(shù)字,0表示畫第一張圖片,1表示第二張。在這里先根據(jù)不同的需求設(shè)置a,b的大小?,我在這里是4張圖是極限,設(shè)置的是,n=0時(shí)a=b=40;n=1時(shí)a=150,b=40,n=2時(shí)a=40,b=150,n=3時(shí)a=b=150 ? if(n < len){//當(dāng)n<需要組合頭像圖片個(gè)數(shù)時(shí)就不再重復(fù)這個(gè)函數(shù) var img = new Image();? //創(chuàng)建一個(gè)image對(duì)象 img.src = data[n];//將圖片地址賦值給image對(duì)象的src img.onload = function(){//圖片預(yù)加載 ctx.drawImage(img, a, b, 100, 100); //在畫布上繪制image對(duì)象的圖片 drawing(n+ 1); //再執(zhí)行此函數(shù) }? }else{ //如果執(zhí)行完了,也就是都畫完了,就要顯示畫好的圖像 base64.push(c.toDataURL("image/jpg")); //將畫好的圖像放入base64對(duì)象 //這里可以寫一個(gè)返回這個(gè)對(duì)象,也可以把base64賦值給一個(gè)全局變量 } }??
最后,執(zhí)行這個(gè)function:
drawing(0);?
完成操作,在html頁面中的img的src里面引用base64的值,就可以顯示出來了,但是要注意,這段js要在html頁面執(zhí)行之前執(zhí)行,不然顯示不出來的哦
這是效果:
在這里封裝好了一個(gè)js:
function groupPic(Images, imgId) { //Images是圖片地址數(shù)組,imgId是html頁面的img標(biāo)簽的id屬性值 var base64 = []; var canvas = document.createElement("canvas"); var context = canvas.getContext("2d"); var len = Images.length; if (len > 9) { len = 9; } //len=8; var a = 0; var b = 0; var k = 80; var l = 80; if (len > 4) { k = 60; l = 60; } canvas.width = 290; canvas.height = 290; context.rect(0, 0, canvas.width, canvas.height); context.fillStyle = "#fff"; context.fill(); function drawing(n) { if (n < len) { if (len <= 4) { if (len != 3) { if (n == 0) { a = b = 40; } else if (n == 1) { a = 130; b = 40; } else if (n == 2) { a = 40; b = 130; } else if (n == 3) { a = b = 130; } } else { if (n == 0) { a = 75; b = 40; } else if (n == 1) { a = 40; b = 130; } else if (n == 2) { a = 130; b = 130; } } } if (len == 5) { if (n == 0) { a = 70; b = 40; } else if (n == 1) { a = 140; b = 40; } else if (n == 2) { a = 40; b = 110; } else if (n == 3) { a = b = 110; } else { a = 180; b = 110; } } if (len == 6) { if (n == 0) { a = 40; b = 40; } else if (n == 1) { a = 110; b = 40; } else if (n == 2) { a = 180; b = 40; } else if (n == 3) { a = 40; b = 110; } else if (n == 4) { a = b = 110 } else { a = 180; b = 110; } } if (len == 7) { if (n == 0) { a = 110; b = 40; } else if (n == 1) { a = 40; b = 110; } else if (n == 2) { a = 110; b = 110; } else if (n == 3) { a = 180; b = 110; } else if (n == 4) { a = 40; b = 180; } else if (n == 5) { a = 110; b = 180; } else { a = b = 180; } } if (len == 8) { if (n == 0) { a = 70; b = 40; } else if (n == 1) { a = 140; b = 40; } else if (n == 2) { a = 40; b = 110; } else if (n == 3) { a = 110; b = 110; } else if (n == 4) { a = 180; b = 110; } else if (n == 5) { a = 40; b = 180; } else if (n == 6) { a = 110; b = 180; } else { a = b = 180; } } if (len == 9) { if (n == 0) { a = 40; b = 40; } else if (n == 1) { a = 110; b = 40; } else if (n == 2) { a = 180; b = 40; } else if (n == 3) { a = 40; b = 110; } else if (n == 4) { a = 110; b = 110; } else if (n == 5) { a = 180; b = 110; } else if (n == 6) { a = 40; b = 180; } else if (n == 7) { a = 110; b = 180; } else { a = b = 180; } } var img = new Image(); img.src = Images[n]; img.onload = function(){ context.drawImage(img, a, b, k, l); drawing(n + 1); } } else { base64.push(canvas.toDataURL("image/jpg")); document.getElementById(imgId).src = base64[0]; } } drawing(0); }
使用方法:在html頁面中添加下面的js:
window.onload = function(){ var Images = ["1.jpg","2.jpg","3.jpg","4.jpg"]; var fun = groupPic; fun(Images, "imageId"); }
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/50961.html
摘要:有時(shí)候,我們需要顯示一個(gè)許多用戶組合的一個(gè)頭像,像扣扣的討論組頭像,微信的群頭像,下面是一個(gè)簡(jiǎn)單的實(shí)現(xiàn)方法首先,獲取你需要的頭像圖片地址,保存在一個(gè)對(duì)象里面,例如然后可以限定組合圖片的最大個(gè)數(shù),比如限定四個(gè),那么久判斷數(shù)據(jù)庫里的圖片個(gè)數(shù)是否 有時(shí)候,我們需要顯示一個(gè)許多用戶組合的一個(gè)頭像,像扣扣的討論組頭像,微信的群頭像,下面是一個(gè)簡(jiǎn)單的實(shí)現(xiàn)方法: 首先,獲取你需要的頭像圖片地址,保存...
摘要:在繪制琦玉的頭像時(shí),最重要的一個(gè)屬性就是,我們用它可以畫出圓形橢圓及各種變體。以下的樣式能夠畫出琦玉的臉部形狀在調(diào)整后,可畫出眼鼻嘴的形狀介紹屬性也是一個(gè)很強(qiáng)大的屬性,能夠?qū)υ刈龈鞣N變形。 寫這篇博客的起因是我看了Medium上的這篇文章:How I started drawing CSS Images,然后哇哦?,同樣是前端開發(fā),這區(qū)別怎么這么大呢?這位作者和我完全點(diǎn)了不同的技能點(diǎn)...
摘要:是一個(gè)為應(yīng)用添加觸摸手勢(shì)的非常受歡迎的庫文中將看到結(jié)合一起使用是多么的簡(jiǎn)單原文示例是針對(duì)版本經(jīng)過測(cè)試在目前最新的版本中此教程依然適用文章將以來統(tǒng)一代稱版本名詞滑動(dòng)和類似但滑動(dòng)更快速無粘滯左滑右滑上滑下滑頭像輪播簡(jiǎn)介我們將構(gòu)建一個(gè)頭像輪播可以 HammerJS 是一個(gè)為 web 應(yīng)用添加觸摸手勢(shì)的非常受歡迎的庫,文中,將看到 Angular 結(jié)合 HammerJS 一起使用是多么的簡(jiǎn)單 ...
摘要:介紹結(jié)合框架作手機(jī)頁面的登錄注冊(cè)組件登錄注冊(cè)相關(guān)知識(shí)點(diǎn)和的作用個(gè)人理解,如果不到位,懇請(qǐng)指出我的電腦通過請(qǐng)求登錄某一個(gè)網(wǎng)頁,登錄成功之后,服務(wù)器會(huì)返回一個(gè)給我的電腦。 介紹 結(jié)合`vue`框架作手機(jī)H5頁面的登錄注冊(cè)組件 登錄注冊(cè)相關(guān)知識(shí)點(diǎn) 1.cookie和token的作用(個(gè)人理解,如果不到位,懇請(qǐng)指出) token: 我的電腦通過http請(qǐng)求登錄某一個(gè)網(wǎng)頁,登錄成功之后,服務(wù)...
閱讀 1650·2019-08-30 15:44
閱讀 2572·2019-08-30 11:19
閱讀 406·2019-08-30 11:06
閱讀 1567·2019-08-29 15:27
閱讀 3084·2019-08-29 13:44
閱讀 1629·2019-08-28 18:28
閱讀 2357·2019-08-28 18:17
閱讀 1987·2019-08-26 10:41