1. 程式人生 > 程式設計 >js實現文字頭像的生成程式碼

js實現文字頭像的生成程式碼

使用canvas畫出文字就好啦

function gen_text_img(size,s) {
 let colors = [
 "rgb(239,150,26)",'rgb(255,58,201)',"rgb(111,75,255)","rgb(36,174,34)","rgb(80,80,80)"
 ];
 let cvs = document.createElement("canvas");
 cvs.setAttribute('width',size[0]);
 cvs.setAttribute('height',size[1]);
 let ctx = cvs.getContext("2d");
 ctx.fillStyle = colors[Math.floor(Math.random()*(colors.length))];
 ctx.fillRect(0,size[0],size[1]);
 ctx.fillStyle = 'rgb(255,255,255)';
 ctx.font = size[0]*0.6+"px Arial";
 ctx.textBaseline = "middle";
 ctx.textAlign = "center";
 ctx.fillText(s,size[0]/2,size[1]/2);

 return cvs.toDataURL('image/jpeg',1);
}

效果如下某些瀏覽器文字不能水平居中,暫時沒有找到解決辦法:

js實現文字頭像的生成程式碼

知識點補充:前端小結:中文轉顏色 - 實現根據名字自動生成頭像

1、需求

專案中有個需求,要求顯示人員頭像和名稱列表

js實現文字頭像的生成程式碼

而頭像是名字的第一個文字和背景顏色生成,文字顏色為白色,背景自動生成。

2、分析

由於名字影象是自動生成,背景顏色不一樣,可以考慮一下幾種方法:

1)使用隨機數來自動生成一個16進位制顏色字串,作為頭像的背景顏色;

2)獲取名字的第一個字,轉換成16進位制文字顏色字串,作為頭像背景顏色;

這裡會有朋友說,為什麼不使用base64轉碼為顏色值呢,在這裡小編也測試過,通過base64轉碼後的值,很多轉換成了F之後的字母,在轉換成顏色時,取值無效,截圖如下:

js實現文字頭像的生成程式碼

所以這裡不使用這樣方法。

第一種方法比較簡單,但是不可控(同一個名字的頭像背景顏色可能不一樣),所以我們採用第二種方式;

3、實現

// 獲取名字第一個文字,轉換成16進位制顏色值
const { name } = this.props;
let firstName = name.substring(1,0);
 
tranColor = (name) => {
 var str ='';
 for(var i=0; i<name.length; i++) {
  str += parseInt(name[i].charCodeAt(0),10).toString(16);
 }
 return '#' + str.slice(1,4);
}
const bgColor = this.tranColor(name)

這樣就可以生成一個合法的16進位制顏色字串,如果需要配置不同的透明度,可以多取一位str.slice(1,5),因為這裡轉換為16進位制,所以這裡只取前3位(1 ~ 4)

4、結果

轉換果如下:

js實現文字頭像的生成程式碼

效果:

js實現文字頭像的生成程式碼

可以看到名字相同時,頭像背景顏色也是相同的,比隨機數要好很多

總結

到此這篇關於js實現文字頭像的生成程式碼的文章就介紹到這了,更多相關js 文字頭像內容請搜尋我們以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援我們!