js實(shí)現(xiàn)文字頭像的生成代碼
使用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, 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);
}
效果如下某些瀏覽器文字不能水平居中,暫時(shí)沒有找到解決辦法:
知識(shí)點(diǎn)補(bǔ)充:前端小結(jié):中文轉(zhuǎn)顏色 - 實(shí)現(xiàn)根據(jù)名字自動(dòng)生成頭像
1、需求
項(xiàng)目中有個(gè)需求,要求顯示人員頭像和名稱列表
![]()
而頭像是名字的第一個(gè)文字和背景顏色生成,文字顏色為白色,背景自動(dòng)生成。
2、分析
由于名字圖像是自動(dòng)生成,背景顏色不一樣,可以考慮一下幾種方法:
1)使用隨機(jī)數(shù)來自動(dòng)生成一個(gè)16進(jìn)制顏色字符串,作為頭像的背景顏色;
2)獲取名字的第一個(gè)字,轉(zhuǎn)換成16進(jìn)制文字顏色字符串,作為頭像背景顏色;
這里會(huì)有朋友說,為什么不使用base64轉(zhuǎn)碼為顏色值呢,在這里小編也測試過,通過base64轉(zhuǎn)碼后的值,很多轉(zhuǎn)換成了F之后的字母,在轉(zhuǎn)換成顏色時(shí),取值無效,截圖如下:

所以這里不使用這樣方法。
第一種方法比較簡單,但是不可控(同一個(gè)名字的頭像背景顏色可能不一樣),所以我們采用第二種方式;
3、實(shí)現(xiàn)
// 獲取名字第一個(gè)文字,轉(zhuǎn)換成16進(jìn)制顏色值
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)
這樣就可以生成一個(gè)合法的16進(jìn)制顏色字符串,如果需要配置不同的透明度,可以多取一位 str.slice(1, 5),因?yàn)檫@里轉(zhuǎn)換為16進(jìn)制,所以這里只取前3位(1 ~ 4)
4、結(jié)果
轉(zhuǎn)換果如下:

效果:

可以看到名字相同時(shí),頭像背景顏色也是相同的,比隨機(jī)數(shù)要好很多
總結(jié)
到此這篇關(guān)于js實(shí)現(xiàn)文字頭像的生成代碼的文章就介紹到這了,更多相關(guān)js 文字頭像內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- javascript頭像上傳代碼實(shí)例
- vue.js+elementUI實(shí)現(xiàn)點(diǎn)擊左右箭頭切換頭像功能(類似輪播圖效果)
- Django+JS 實(shí)現(xiàn)點(diǎn)擊頭像即可更改頭像的方法示例
- javascript填充默認(rèn)頭像方法
- JS實(shí)現(xiàn)延遲隱藏功能的方法(類似QQ頭像鼠標(biāo)放上展示信息)
- 使用cropper.js裁剪頭像的實(shí)例代碼
- jQuery用戶頭像裁剪插件cropbox.js使用詳解
- web前端開發(fā)upload上傳頭像js示例代碼
- JavaScript頭像上傳插件源碼分享
- js實(shí)現(xiàn)頭像上傳并且可預(yù)覽提交
相關(guān)文章
d3.js入門教程之?dāng)?shù)據(jù)綁定詳解
這篇文章主要介紹了關(guān)于d3.js數(shù)據(jù)綁定的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)只d3.js具有一定的參考價(jià)值,需要的朋友下面來一起看看吧。2017-04-04
javascript循環(huán)變量注冊dom事件 之強(qiáng)大的閉包
是在循環(huán)過程過this被改變,注冊過的事件也被隨之改變,找到了一種解決方法2010-09-09
JavaScript的9個(gè)陷阱及評點(diǎn)分析
以下是JavaScript容易犯錯(cuò)的九個(gè)陷阱。雖然不是什么很高深的技術(shù)問題,但注意一下,會(huì)使您的編程輕松些,即所謂make life easier. 筆者對某些陷阱會(huì)混雜一些評點(diǎn)。2008-05-05
微信小程序使用swiper組件實(shí)現(xiàn)層疊輪播圖
這篇文章主要為大家詳細(xì)介紹了微信小程序使用swiper組件實(shí)現(xiàn)層疊輪播圖,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-11-11
極力推薦一款小巧玲瓏的可視化編輯器bootstrap-wysiwyg
這篇文章主要為大家極力推薦一款小巧玲瓏的可視化編輯器bootstrap-wysiwyg,是一款基于jquery和bootstrap的可視化編輯器,感興趣的小伙伴們可以參考一下2016-05-05
Egg Vue SSR 服務(wù)端渲染數(shù)據(jù)請求與asyncData
這篇文章主要介紹了Egg Vue SSR 服務(wù)端渲染數(shù)據(jù)請求與asyncData,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11
uniapp實(shí)現(xiàn)全局設(shè)置字體大小(小中大的字體切換)
隨著UniApp的流行,越來越多的開發(fā)者選擇使用它來構(gòu)建跨平臺(tái)應(yīng)用程序,下面這篇文章主要給大家介紹了關(guān)于uniapp實(shí)現(xiàn)全局設(shè)置字體大小(小中大的字體切換)的相關(guān)資料,需要的朋友可以參考下2023-06-06

