阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

用字母替代图片脚本:LetterAvatar

501次阅读
没有评论

共计 3686 个字符,预计需要花费 10 分钟才能阅读完成。

基于 canvas,通过 toDataURL 动态生成 base64 图片。目前我主题的 Gravatar 头像,就是利用这个 LetterAvatar 脚本实现未设置 Gravatar 头像则读取 ALT 标签,自动生成首字图片替代默认的头像图片。

用字母替代图片脚本:LetterAvatar

之前已有 WP 爱好者制作了一款:mk-letter-avatar 字母头像插件,试了一下很好用,不过打开浏览器开者工具发现产生大量 404 错误,看了一下源代码,该插件是通过无头像返回 404 错误,触发 onerror 事件用自动生成的字母图片替换 src 图片地址,判断方式不是很合理,如果不是因为个缺点我都想直接拿来用了,如果作者再优化一下,绝对是款优秀实用的插件。

我的实现原理和插件不同,配合头像本地缓存功能,判断无头像后,直接为无头像的图片添加特定的 class 类,然后通过 LetterAvatar 脚本替换图片。

需要注意的是上面提到的插件,Gravatar 头像图片必须有 alt 标签属性,否则不会生成正常的图片,可惜大部分主题默认 Gravatar 头像 alt 标签属性是空的 …..

如果想自动为 Gravatar 头像添加 alt 标签属性,可以将下面的代码添加到当前主题函数模板 functions.php 中:

function zm_gravatar_alt($altgravatar) {if (have_comments()) {$alt = get_comment_author();
	}
	else {$alt = get_the_author_meta('display_name');
	}
	$altgravatar= str_replace('alt=\'\'','alt=\''. $alt .'\'title=\'Gravatar for '. $alt .'\'', $altgravatar);
	return $altgravatar;
}
add_filter('get_avatar', 'zm_gravatar_alt');

之后,自动将评论者昵称做为 alt 属性。

本文只是自己做个记录,并不是教大家怎么弄这个头像,如果认为这字母头像还不错,请直接使用上面介绍的插件。

展开 收缩

另附 LetterAvatar 脚本演示代码:

<!DOCTYPE html>
<html>
<h1>Letter Avatar</h1>

<small><strong> 用法:</strong></small>
<pre>
<code>&lt;img src=&quot;&quot; class=&quot;avatar photo&quot; width=&quot;256&quot; height=&quot;256&quot; alt=&quot; 知更鸟 &quot; color=&quot;#c40000&quot;&gt;</code>
</pre>

<img src=""class="avatar photo"height="240"width="240"alt=" 知更鸟 "color="#c40000" />
<img src=""class="avatar photo"height="240"width="240"alt=" 更鸟 "color="#99CC66" />
<img src=""class="avatar photo"height="240"width="240"alt=" 鸟 "color="#0D8ABC" />

<style>
	body {font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;}

	pre {
	  margin: 20px 0;
	  padding: 20px;
	  background: #fafafa;
	}

	.avatar {border-radius: 50%;}
</style>
<script src="http://libs.baidu.com/jquery/3.2.1/jquery.min.js"></script>
<script>
	/*
	 * LetterAvatar
	 * 
	 * Artur Heinze
	 * Create Letter avatar based on Initials
	 * based on https://gist.github.com/leecrossley/6027780
	 */
	(function(w, d){function LetterAvatar (name, size, color) {

			name  = name || '';
			size  = size || 60;

			var colours = [
					"#1abc9c", "#2ecc71", "#3498db", "#9b59b6", "#34495e", "#16a085", "#27ae60", "#2980b9", "#8e44ad", "#2c3e50", 
					"#f1c40f", "#e67e22", "#e74c3c", "#ecf0f1", "#95a5a6", "#f39c12", "#d35400", "#c0392b", "#bdc3c7", "#7f8c8d"
				],

				nameSplit = String(name).split(' '),
				initials, charIndex, colourIndex, canvas, context, dataURI;


			if (nameSplit.length == 1) {initials = nameSplit[0] ? nameSplit[0].charAt(0):'?';
			} else {initials = nameSplit[0].charAt(0) + nameSplit[1].charAt(0);
			}

			if (w.devicePixelRatio) {size = (size * w.devicePixelRatio);
			}
				
			charIndex     = (initials == '?' ? 72 : initials.charCodeAt(0)) - 64;
			colourIndex   = charIndex % 20;
			canvas        = d.createElement('canvas');
			canvas.width  = size;
			canvas.height = size;
			context       = canvas.getContext("2d");
			 
			context.fillStyle = color ? color : colours[colourIndex - 1];
			context.fillRect (0, 0, canvas.width, canvas.height);
			context.font = Math.round(canvas.width/2)+"px Arial";
			context.textAlign = "center";
			context.fillStyle = "#FFF";
			context.fillText(initials, size / 2, size / 1.5);

			dataURI = canvas.toDataURL();
			canvas  = null;

			return dataURI;
		}

		LetterAvatar.transform = function() {Array.prototype.forEach.call(d.querySelectorAll('img[alt]'), function(img, name, color) {name = img.getAttribute('alt');
				color = img.getAttribute('color');
				img.src = LetterAvatar(name, img.getAttribute('width'), color);
				img.removeAttribute('avatar');
				img.setAttribute('alt', name);
			});
		};


		// AMD support
		if (typeof define === 'function' && define.amd) {define(function () {return LetterAvatar;});
		
		// CommonJS and Node.js module support.
		} else if (typeof exports !== 'undefined') {// Support Node.js specific `module.exports` (which can be a function)
			if (typeof module != 'undefined' && module.exports) {exports = module.exports = LetterAvatar;}

			// But always support CommonJS module 1.1.1 spec (`exports` cannot be a function)
			exports.LetterAvatar = LetterAvatar;

		} else {
			
			window.LetterAvatar = LetterAvatar;

			d.addEventListener('DOMContentLoaded', function(event) {LetterAvatar.transform();
			});
		}
	})(window, document);
</script>
</html>

原项目地址:https://github.com/daolavi/LetterAvatar

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-22发表,共计3686字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中

星哥玩云

星哥玩云
星哥玩云
分享互联网知识
用户数
4
文章数
19351
评论数
4
阅读量
7986293
文章搜索
热门文章
星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛 NAS-6:抖音视频同步工具,视频下载自动下载保存 前言 各位玩 NAS 的朋友好,我是星哥!...
星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛 NAS-3:安装飞牛 NAS 后的很有必要的操作 前言 如果你已经有了飞牛 NAS 系统,之前...
我把用了20年的360安全卫士卸载了

我把用了20年的360安全卫士卸载了

我把用了 20 年的 360 安全卫士卸载了 是的,正如标题你看到的。 原因 偷摸安装自家的软件 莫名其妙安装...
再见zabbix!轻量级自建服务器监控神器在Linux 的完整部署指南

再见zabbix!轻量级自建服务器监控神器在Linux 的完整部署指南

再见 zabbix!轻量级自建服务器监控神器在 Linux 的完整部署指南 在日常运维中,服务器监控是绕不开的...
飞牛NAS中安装Navidrome音乐文件中文标签乱码问题解决、安装FntermX终端

飞牛NAS中安装Navidrome音乐文件中文标签乱码问题解决、安装FntermX终端

飞牛 NAS 中安装 Navidrome 音乐文件中文标签乱码问题解决、安装 FntermX 终端 问题背景 ...
阿里云CDN
阿里云CDN-提高用户访问的响应速度和成功率
随机文章
自己手撸一个AI智能体—跟创业大佬对话

自己手撸一个AI智能体—跟创业大佬对话

自己手撸一个 AI 智能体 — 跟创业大佬对话 前言 智能体(Agent)已经成为创业者和技术人绕...
星哥带你玩飞牛NAS-4:飞牛NAS安装istore旁路由,家庭网络升级的最佳实践

星哥带你玩飞牛NAS-4:飞牛NAS安装istore旁路由,家庭网络升级的最佳实践

星哥带你玩飞牛 NAS-4:飞牛 NAS 安装 istore 旁路由,家庭网络升级的最佳实践 开始 大家好我是...
星哥带你玩飞牛NAS硬件 01:捡垃圾的最爱双盘,暴风二期矿渣为何成不老神话?

星哥带你玩飞牛NAS硬件 01:捡垃圾的最爱双盘,暴风二期矿渣为何成不老神话?

星哥带你玩飞牛 NAS 硬件 01:捡垃圾的最爱双盘,暴风二期矿渣为何成不老神话? 前言 在选择 NAS 用预...
零成本上线!用 Hugging Face免费服务器+Docker 快速部署HertzBeat 监控平台

零成本上线!用 Hugging Face免费服务器+Docker 快速部署HertzBeat 监控平台

零成本上线!用 Hugging Face 免费服务器 +Docker 快速部署 HertzBeat 监控平台 ...
CSDN,你是老太太喝粥——无齿下流!

CSDN,你是老太太喝粥——无齿下流!

CSDN,你是老太太喝粥——无齿下流! 大家好,我是星哥,今天才思枯竭,不写技术文章了!来吐槽一下 CSDN。...

免费图片视频管理工具让灵感库告别混乱

一言一句话
-「
手气不错
恶意团伙利用 PHP-FPM 未授权访问漏洞发起大规模攻击

恶意团伙利用 PHP-FPM 未授权访问漏洞发起大规模攻击

恶意团伙利用 PHP-FPM 未授权访问漏洞发起大规模攻击 PHP-FPM(FastCGl Process M...
一句话生成拓扑图!AI+Draw.io 封神开源组合,工具让你的效率爆炸

一句话生成拓扑图!AI+Draw.io 封神开源组合,工具让你的效率爆炸

一句话生成拓扑图!AI+Draw.io 封神开源组合,工具让你的效率爆炸 前言 作为天天跟架构图、拓扑图死磕的...
星哥带你玩飞牛NAS-16:飞牛云NAS换桌面,fndesk图标管理神器上线!

星哥带你玩飞牛NAS-16:飞牛云NAS换桌面,fndesk图标管理神器上线!

  星哥带你玩飞牛 NAS-16:飞牛云 NAS 换桌面,fndesk 图标管理神器上线! 引言 哈...
小白也能看懂:什么是云服务器?腾讯云 vs 阿里云对比

小白也能看懂:什么是云服务器?腾讯云 vs 阿里云对比

小白也能看懂:什么是云服务器?腾讯云 vs 阿里云对比 星哥玩云,带你从小白到上云高手。今天咱们就来聊聊——什...
如何安装2026年最强个人助理ClawdBot、完整安装教程

如何安装2026年最强个人助理ClawdBot、完整安装教程

如何安装 2026 年最强个人助理 ClawdBot、完整安装教程 一、前言 学不完,根本学不完!近期,一款名...