有红又专的国庆节头像如何制作?

马上又要到中国人民的喜庆日子了,朋友圈估计又要开始泛滥国旗头像了。

我的已经准备好了,你们的准备好了吗?让我来教你怎么制作,只面向前端开发者哦!

实现原理

本质是两张图片,怎么合并到一起,作为前端开发者,可能会想到几种做法:

  • 使用两个 Image dom 堆叠到一起,形成合并的效果,然后使用 dom-to-canvas 生成图片
  • 使用 Canvas 读取两个图片,然后 writeImage 到一个 Canvas 中,在截图

这两种办法都可以,但是因为我们 AntV 具备有可视化的强大能力,和基础工具,所以从可视化角度来看,可以讲这两个图片都作为可视化画布的两个图片标注,然后通过调用 API 顺序,就可以迭代层级关系。

具体就是使用 AntV G2 的 Image mark。Image 标记和 Point 标记很类似,都是以 xy 数据通道作为位置居中定位,区别在于 Image 提供一个特殊的 src 数据通道,来指定图片的远程地址或者 base64。

这里有一个简单的浏览器占比数据,我们对它进行可视化,便于看到不同浏览器的占比对比。

具体代码

全量代码如下,Copy 到 G2 的 DEMO 中就可以运行出来效果了。代码非常简单,不过多介绍了。

ts 复制代码
import { Chart } from '@antv/g2';

const SIZE = 256;

const chart = new Chart({
  container: 'container',
  width: SIZE,
  height: SIZE,
});

// 五个模板
const FLAG_TEMPLATE = [
  'https://mdn.alipayobjects.com/huamei_qa8qxu/afts/img/A*FpxcQI7WEusAAAAAAAAAAAAADmJ7AQ/original',
  'https://mdn.alipayobjects.com/huamei_qa8qxu/afts/img/A*rx6ST7V6cA0AAAAAAAAAAAAADmJ7AQ/original',
  'https://mdn.alipayobjects.com/huamei_qa8qxu/afts/img/A*7rKcTJiP1rMAAAAAAAAAAAAADmJ7AQ/original',
  'https://mdn.alipayobjects.com/huamei_qa8qxu/afts/img/A*_GUISa64kgYAAAAAAAAAAAAADmJ7AQ/original',
  'https://mdn.alipayobjects.com/huamei_qa8qxu/afts/img/A*Wwy8TJAoCeUAAAAAAAAAAAAADmJ7AQ/original',
  'https://mdn.alipayobjects.com/huamei_qa8qxu/afts/img/A*DphFRIpOYWQAAAAAAAAAAAAADmJ7AQ/original'
];

// 换成你自己的,可以使用远程 CDN 地址,也可以使用 Base64 编码
const MY_PHOTO = 'https://mdn.alipayobjects.com/huamei_qa8qxu/afts/img/A*vYY6RrxEWKwAAAAAAAAAAAAADmJ7AQ/original'

chart
  .image()
  .data([{ x: 0.5, y: 0.5 }])
  .encode('x', 'x')
  .encode('y', 'y')
  .encode('src', MY_PHOTO)
  .encode('size', SIZE)
  .axis(false)
  .tooltip(false);

  chart
  .image()
  .data([{ x: 0.5, y: 0.5 }])
  .encode('x', 'x')
  .encode('y', 'y')
  .encode('src', FLAG_TEMPLATE[2]) // 换成你自己想要的模板,都试试吧
  .encode('size', SIZE)
  .axis(false)
  .tooltip(false);

chart.render();

最后

其实社区上很多了,但是开放代码的并不多,这里代码开发出来,快点基于这个去封装成小工具,蹭节日流量吧。

相关推荐
海市公约1 小时前
HTML网页开发从入门到精通:从标签到表单的完整指南
前端·ide·vscode·程序人生·架构·前端框架·html
3秒一个大1 小时前
HTML5 与 JavaScript 中的二进制数据处理:ArrayBuffer 与 TextEncoder/Decoder 实践
javascript
purpleseashell_Lili1 小时前
如何学习 AG-UI 和 CopilotKit
javascript·typescript·react
行云流水6261 小时前
前端树形结构实现勾选,半勾选,取消勾选。
前端·算法
diudiu_332 小时前
web漏洞--认证缺陷
java·前端·网络
阿珊和她的猫2 小时前
<video>` 和 `<audio>` 标签的常用属性解析
前端
LSL666_2 小时前
4 jQuery、JavaScript 作用域、闭包与 DOM 事件绑定
前端·javascript·html
草梅友仁3 小时前
草梅 Auth 1.11.1 版本发布与 AI 辅助代码重构实践 | 2025 年第 49 周草梅周报
开源·github·ai编程
yinuo3 小时前
前端跨页面通讯终极指南⑤:window.name 用法全解析
前端
小飞侠在吗3 小时前
vue computed 和 watch
前端·javascript·vue.js