轻松玩转自定义头像 – 用Multiface打造你的专属形象

boyanx4个月前技术教程24

从社交媒体平台到专业网络,用户对展示自己个性的方式有着更高的需求。为了满足这种需求,我们开发了一个简单但功能强大的工具——Multiface,它能够为每个用户提供独一无二的自动生成头像。


Multiface是什么?

Multiface是一个基于Node.js和Koajs构建的服务,旨在根据用户的请求生成独特的头像。通过利用@multiavatar/multiavatar库,我们的服务可以创建丰富多彩、风格各异的SVG格式头像,并能将其转换为PNG格式,以便更广泛的应用场景。


技术栈

  • @multiavatar/multiavatar:用于生成多样化的头像。
  • koa:一个轻量级的Node.js框架,帮助我们快速搭建服务器。
  • crypto:用于生成哈希值,确保文件名唯一性。
  • svg2img:将SVG格式的头像转换为PNG格式,便于在更多场合下使用。

代码概览

我们的项目结构非常简洁,核心逻辑位于src/service.js中。每当有请求到达时,服务会检查请求路径来决定是生成一个新的头像还是返回已存在的头像。对于需要PNG格式的情况,我们将首先以SVG形式生成头像,然后使用svg2img将其转换为PNG格式并保存至本地。这样做不仅保证了头像的独特性,还提高了加载速度和用户体验。

const Koa = require('koa');
const app = new Koa();
const crypto = require('crypto')
const fs = require('fs')
const path = require('path')
const multiavatar = require('@multiavatar/multiavatar')
const svg2img = require('svg2img');

app.use(ctx => {
  const faceName = (ctx.path ? (ctx.path === '/' ? Date.now() : ctx.path) : Date.now()).toString()
  const faceSuffix = faceName.substring(faceName.lastIndexOf('.') + 1)
  const svgCode = multiavatar(faceName);
  if (faceSuffix === 'png') {
    svg2img(svgCode, (error, buffer) => {
      const hash256 = crypto.createHash('sha256').update(faceName).digest('hex')
      const filePath = path.join(__dirname, '../face/' + hash256 + '.png')
      const isExisted = fs.existsSync(filePath)
      if (isExisted) {
        const file = fs.readFileSync(filePath, 'binary')
        ctx.res.writeHead(200),
        ctx.res.write(file, 'binary')
        ctx.res.end()
      } else {
        ctx.set('content-type', 'image/png');
        fs.writeFileSync(filePath, buffer)
        ctx.body = buffer
      }
    })
  } else {
    ctx.body = svgCode
  }
})

app.listen(3001)

如何使用?

只需运行npm start启动服务后,在浏览器地址栏输入http://localhost:3001/或指定特定名称(如
http://localhost:3001/yourname.png)即可获取一个随机生成的头像。如果再次访问相同的URL,你将会得到同样的头像,因为我们使用SHA-256算法为每一个头像生成唯一的文件名并存储它们。

{
  "name": "multiface",
  "version": "0.0.1",
  "description": "multiface",
  "author": "ivup@ivup.cn",
  "scripts": {
    "start": "node src/service.js"
  },
  "dependencies": {
    "@multiavatar/multiavatar": "^1.0.7",
    "crypto": "^1.0.1",
    "koa": "^2.15.3",
    "svg2img": "^1.0.0-beta.2"
  },
  "main": "src/service.js",
  "devDependencies": {},
  "keywords": [
    "multiface"
  ],
  "license": "MIT"
}

结语

Multiface提供了一种便捷的方式来为用户生成个性化头像,无论是用于个人博客、企业网站还是其他任何需要显示用户图像的地方都非常适用。未来,我们计划添加更多定制选项,比如允许用户选择颜色主题或添加额外的设计元素,让每位用户都能找到最符合自己个性的头像。

让我们一起迎接更加多彩多姿的数字身份时代吧!

标签: svg 生成

相关文章

AI一键生成思维导图/流程图/PPT!有这神器,办公再也不发愁!

DeepSeek大火,对普通人而言,除了像之前和AI各种侃大山聊天,其实DeepSeek推理模式的使用场景非常广泛,可在我们的工作、学习、生活方方面面发挥作用,助我们达成各种目标。诚然DeepSeek...

还能用 AI 生成 SVG(可缩放矢量图像)?我们来聊聊 SVG

文章链接:https://mp.weixin.qq.com/s/uWu4_yM5wb-eFkBlMBD-TA什么是 SVGSVG(Scalable Vector Graphics,可缩放矢量图形)基于...

DeepSeek+Drawio+SVG绘制架构图-一种真正可行实用的方法和思路

Hello,大家好,我是人月聊IT。今天接着跟大家聊采用DeepSeek工具来绘制软件功能架构图。对于场景的流程图,包括软件设计里面的用例图,序列图讲这块的已经很多了。即通过DeepSeek工具来生成...

刚刚开源!SVG 向量图形生成模型

StarVector 这个开源项目有点意思,3 天前开源的:可以把图像和文本生成高质量的可缩放编辑 SVG 图形。由 ServiceNow Research、Mila 等机构联合开发,并已被 CVPR...

AI转矢量|10秒将图片转换成可编辑的svg文件

灵力AI简直就是AI届对神器,可以轻松将AI绘画生成对图片转换矢量文件。也可以上传图片进行矢量转换,以后用素材太方便了...

DeepSeek怎么生成流程图?用这2个绘图软件一键绘制!

DeepSeek从小范围内流行到爆火出圈,用了不到半个月时间,其热度从目前公开的数据可见一斑,一个月内迅速斩获1.25亿用户,日活也随之突破3000万,超越此前表现亮眼的AI工具豆包。DeepSeek...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。