minidenticons

minidenticons

客户端轻量级SVG头像生成器 无依赖快速生成

minidenticons是一款客户端SVG头像生成器,无需依赖即可基于用户名创建像素化头像。它能提升加载速度、减少带宽使用,并遵守GDPR规定。该项目支持自定义元素和函数调用,允许调整头像饱和度和亮度,适配多种网站风格。生成的头像独特易识别,可有效替代传统的字母初始头像。

MinidenticonsSVGidenticon头像生成无依赖Github开源项目

Minidenticons

超轻量级 SVG 身份图标生成器。无依赖。

压缩并使用 brotli 的大小 压缩并使用 zip 的大小 <sup>(仅使用 minidenticon() 函数)</sup>

压缩并使用 brotli 的大小 压缩并使用 zip 的大小 <sup>(使用包含的自定义元素)</sup>

依赖 类型 npm 许可证

<img src="https://yellow-cdn.veclightyear.com/ab5030c0/43d864d9-aade-4704-9cb8-d8b7c87c5386.svg" style="width:100%" alt="Minidenticons">

为什么使用

  • 在客户端从用户名生成身份图标(像素化头像),而不是从服务器获取图像。更快、节省带宽且符合 GDPR
  • 用易记的图形头像替代单调的初始头像,如 <sub><img src="https://yellow-cdn.veclightyear.com/ab5030c0/0e96c140-02fc-4489-87b7-971e08613d99.svg" alt="laurent 身份图标" width="24" height="24"></sub>
  • 为哈希值或任何 ID 字符串提供可视化表示。

在线演示 :video_game:

这里试用。

使用包含的自定义元素的基本用法

Minidenticons 使用 ES 模块,现在浏览器已广泛支持。从 minidenticons.min.js 文件中导入 minidenticonSvg 自定义元素。该文件可以位于 CDN(如下例所示)或复制到您网站的任何目录中(以获得更好的性能并符合 GDPR,因为您不需要连接到第三方服务器)。

<script type="module"> import { minidenticonSvg } from 'https://cdn.jsdelivr.net/npm/minidenticons@4.2.1/minidenticons.min.js' </script>

然后简单地使用带有 username 属性的 minidenticon-svg 标签 :joy:

<minidenticon-svg username="laurent"></minidenticon-svg>

<sup>(请注意,除了空元素外,所有元素都需要闭合标签 </minidenticon-svg></sup>

例如,使用 laurent 用户名,您将得到以下身份图标(不含边框):

<table><tr><td> <img src="https://yellow-cdn.veclightyear.com/ab5030c0/ece265d7-717f-4185-b838-ed44e0a985fe.svg" alt="laurent 身份图标" width="120" height="120"> </td></tr></table>

样式设置

为便于 CSS 样式设置:

  • Minidenticons 是 SVG 图像,会占用所有可用空间。 上面的图片已调整大小。

  • 背景是透明的。

  • 彩色方块矩阵周围有白色空间,以允许未裁剪的圆形头像。

因此,使用以下 CSS:

minidenticon-svg svg { border-radius: 50%; background-color: grey; height: 48px; width: 48px; };

您将得到:

带样式的 minidenticon

默认情况下,颜色饱和度设置为 95%,亮度设置为 45%。但您可以使用 saturation 和/或 lightness 属性更改这些值,例如:

<minidenticon-svg username="laurent" saturation="60" lightness="50"></minidenticon-svg>

演示中尝试,找到与您网站主题颜色(浅色、深色或其他)匹配的饱和度和亮度组合 :sunglasses:

Minidenticons 浅��色 Minidenticons 深色 Minidenticons 奇怪

性能

  • 自定义元素身份图标是记忆化的(存储在内存中,无需重新计算)。
  • 要查看您的浏览器生成 100 个身份图标自定义元素(适用于大页面)需要多长时间,请尝试在线浏览器基准测试

使用 minidenticon() 函数的高级用法

除了使用自定义元素外,您还可以使用 minidenticon() 函数在客户端(或服务器)生成 SVG 字符串。

minidenticon(seed: string, saturation?: number|string, lightness?: number|string, hashFn?: (str: string) => number): string

minidenticon() 函数将返回根据其种子字符串参数生成的 SVG 字符串。种子参数可以是用户名,但实际上可以是任何用作标识符的字符串。

可选的饱和度和亮度参数应为百分比;即介于 0 和 100 之间的数字(或字符串)。

如果需要,您可以在第四个参数(可选)中使用自己的哈希函数。您的自定义哈希函数必须接受一个字符串并返回一个数字。哈希的整数部分的最后 15 位将用于绘制方块。包含的自定义元素不使用此最后一个参数。

请注意,minidenticon() 函数本身进行记忆化。

NodeJS

请确保使用的 NodeJS 版本大于或等于 15.14.0

安装

npm install minidenticons

导入

import { minidenticon } from 'minidenticons'

minidenticonSvg 自定义元素应该从你的bundle中进行树摇,以获得更小的 minidenticons 大小 :grin:

性能

minidenticon() 函数非常快。你可以在 Minidenticons git 克隆的根目录运行 node benchmark/node 自己查看。在我的机器上得到以下结果:

为15个字符的随机种子生成10000个 minidenticon SVG 字符串的时间:
8毫秒(10次运行平均)

React

以下 React 组件示例 将 identicon 插入到 img 标签的 src 属性中。它还使用了 React 的 useMemo 来记忆 identicon。

import { minidenticon } from 'minidenticons' import { useMemo } from 'react' const MinidenticonImg = ({ username, saturation, lightness, ...props }) => { const svgURI = useMemo( () => 'data:image/svg+xml;utf8,' + encodeURIComponent(minidenticon(username, saturation, lightness)), [username, saturation, lightness] ) return (<img src={svgURI} alt={username} {...props} />) }

然后你可以将这个组件与 img 属性(如 widthheight)以及 minidenticons 的属性一起使用。除 username 外,所有属性都是可选的。

<MinidenticonImg username="laurent" saturation="90" width="150" height="150" />

有关此示例的 TypeScript 版本,请参阅 Dan Yishai原始问题评论

Workbox

在这个使用 Workbox 的示例中,路径以 minidenticons/<username>.svg 结尾的图像由 service worker 生成,并缓存一年。

import { minidenticon } from 'minidenticons' import { registerRoute } from 'workbox-routing' registerRoute( /minidenticons\/[^\/]+\.svg$/, async ({ url }) => { const username = url.pathname.match(/([^\/]+)\.svg$/)[1] return new Response( minidenticon(username), { headers: { "Content-Type": "image/svg+xml", "Cache-Control": "max-age=31536000" } } ) } )

Rust

Théo Battrel 制作了 Minidenticons 的 Rust 版本: minidenticons-rs

Elm

对于 Elm 爱好者,Elm 包仓库中有一个 Minidenticons 包: minidenticons-elm

碰撞

对于给定的用户名,你总会得到相同的 identicon。但不同的用户名有可能得到相同的 identicon。这就是碰撞

生成的 identicons 是具有垂直对称性的 5×5 矩阵,对于相同的饱和度和亮度可以有 9 种不同的色调。 这意味着可能有 2<sup>(3×5)</sup> × 9 = 294,912 种不同的 identicons,但在使用大量 identicons 时,重复是不可避免的。这应该不是问题,因为 identicons 不应该单独用于识别用户,而应该始终与唯一的用户名结合使用 :wink:

下面的 npm test 命令结果显示,在已经使用 10,000 个 identicons 的情况下,生成重复 identicon 的几率不到 2%。

0 collisions out of 100 (0.00%) 0 collisions out of 200 (0.00%) 0 collisions out of 300 (0.00%) 0 collisions out of 400 (0.00%) 0 collisions out of 500 (0.00%) 0 collisions out of 600 (0.00%) 0 collisions out of 700 (0.00%) 0 collisions out of 800 (0.00%) 1 collisions out of 900 (0.11%) 1 collisions out of 1000 (0.10%) 8 collisions out of 2000 (0.40%) 14 collisions out of 3000 (0.47%) 22 collisions out of 4000 (0.55%) 37 collisions out of 5000 (0.74%) 58 collisions out of 6000 (0.97%) 75 collisions out of 7000 (1.07%) 99 collisions out of 8000 (1.24%) 129 collisions out of 9000 (1.43%) 163 collisions out of 10000 (1.63%)

许可证

MIT

点赞者 :heart:

Stargazers repo roster for @laurentpayot/minidenticons

编辑推荐精选

TRAE编程

TRAE编程

AI辅助编程,代码自动修复

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
蛙蛙写作

蛙蛙写作

AI小说写作助手,一站式润色、改写、扩写

蛙蛙写作—国内先进的AI写作平台,涵盖小说、学术、社交媒体等多场景。提供续写、改写、润色等功能,助力创作者高效优化写作流程。界面简洁,功能全面,适合各类写作者提升内容品质和工作效率。

AI辅助写作AI工具蛙蛙写作AI写作工具学术助手办公助手营销助手AI助手
问小白

问小白

全能AI智能助手,随时解答生活与工作的多样问题

问小白,由元石科技研发的AI智能助手,快速准确地解答各种生活和工作问题,包括但不限于搜索、规划和社交互动,帮助用户在日常生活中提高效率,轻松管理个人事务。

热门AI助手AI对话AI工具聊天机器人
Transly

Transly

实时语音翻译/同声传译工具

Transly是一个多场景的AI大语言模型驱动的同声传译、专业翻译助手,它拥有超精准的音频识别翻译能力,几乎零延迟的使用体验和支持多国语言可以让你带它走遍全球,无论你是留学生、商务人士、韩剧美剧爱好者,还是出国游玩、多国会议、跨国追星等等,都可以满足你所有需要同传的场景需求,线上线下通用,扫除语言障碍,让全世界的语言交流不再有国界。

讯飞智文

讯飞智文

一键生成PPT和Word,让学习生活更轻松

讯飞智文是一个利用 AI 技术的项目,能够帮助用户生成 PPT 以及各类文档。无论是商业领域的市场分析报告、年度目标制定,还是学生群体的职业生涯规划、实习避坑指南,亦或是活动策划、旅游攻略等内容,它都能提供支持,帮助用户精准表达,轻松呈现各种信息。

AI办公办公工具AI工具讯飞智文AI在线生成PPTAI撰写助手多语种文档生成AI自动配图热门
讯飞星火

讯飞星火

深度推理能力全新升级,全面对标OpenAI o1

科大讯飞的星火大模型,支持语言理解、知识问答和文本创作等多功能,适用于多种文件和业务场景,提升办公和日常生活的效率。讯飞星火是一个提供丰富智能服务的平台,涵盖科技资讯、图像创作、写作辅助、编程解答、科研文献解读等功能,能为不同需求的用户提供便捷高效的帮助,助力用户轻松获取信息、解决问题,满足多样化使用场景。

热门AI开发模型训练AI工具讯飞星火大模型智能问答内容创作多语种支持智慧生活
Spark-TTS

Spark-TTS

一种基于大语言模型的高效单流解耦语音令牌文本到语音合成模型

Spark-TTS 是一个基于 PyTorch 的开源文本到语音合成项目,由多个知名机构联合参与。该项目提供了高效的 LLM(大语言模型)驱动的语音合成方案,支持语音克隆和语音创建功能,可通过命令行界面(CLI)和 Web UI 两种方式使用。用户可以根据需求调整语音的性别、音高、速度等参数,生成高质量的语音。该项目适用于多种场景,如有声读物制作、智能语音助手开发等。

咔片PPT

咔片PPT

AI助力,做PPT更简单!

咔片是一款轻量化在线演示设计工具,借助 AI 技术,实现从内容生成到智能设计的一站式 PPT 制作服务。支持多种文档格式导入生成 PPT,提供海量模板、智能美化、素材替换等功能,适用于销售、教师、学生等各类人群,能高效制作出高品质 PPT,满足不同场景演示需求。

讯飞绘文

讯飞绘文

选题、配图、成文,一站式创作,让内容运营更高效

讯飞绘文,一个AI集成平台,支持写作、选题、配图、排版和发布。高效生成适用于各类媒体的定制内容,加速品牌传播,提升内容营销效果。

热门AI辅助写作AI工具讯飞绘文内容运营AI创作个性化文章多平台分发AI助手
材料星

材料星

专业的AI公文写作平台,公文写作神器

AI 材料星,专业的 AI 公文写作辅助平台,为体制内工作人员提供高效的公文写作解决方案。拥有海量公文文库、9 大核心 AI 功能,支持 30 + 文稿类型生成,助力快速完成领导讲话、工作总结、述职报告等材料,提升办公效率,是体制打工人的得力写作神器。

下拉加载更多