点击 机器学习算法与Python学习 选择加星标

精彩内容不迷路

新的一年,新气象。

不少人都会选择换一个微信头像,迎接新的一年。

这期小F就来教大家,如何使用Python生成emoji风格的头像。

效果大致如下图,由很多的emoji图片方块组成一张新的头像图片

细节图~

主要是通过matplotlib、pillow和numpy这三个库来实现的。

import matplotlib.pyplot as plt
from scipy import spatial
from PIL import Image
import numpy as np

对于numpy和matplotlib(以及几乎所有的图像处理库)而言,图像基本上只是一个矩阵(例如A),其中每个像素(p)都是A的元素。

如果是灰度图像,则每个像素(p)只是一个数字(或标量)。如果为浮点数,则为[0, 1]。如果为整数,则为[0, 255]。

如果不是灰度级(例如在这次的情况下),则每个像素都是尺寸为3-红色(R),绿色(G)和蓝色(B)或尺寸为4-RGBA的矢量(A代表Alpha,表示的是透明度)。

首先读取图像,并且将图像尺寸缩小。

# 读取图片,并且修改图片大小
G_sm = np.array(Image.open( fans.png ).resize([50, 50]).getdata()).reshape([50, 50, 3])/256# 显示图片
plt.figure()
plt.imshow(G_sm)
plt.title( Original Image )
plt.show()

然后读取emoji图像数据,一共是有近1600个emoji图像数据。

# 读取emoji数据
emoji_array = np.load("emojis_16.npy")# 获取emoji的平均颜色值
emoji_mean_array = np.array([ar.mean(axis=(0,1)) for ar in emoji_array]) # 将得到的每个emoji平均颜色值存储在树中以加快搜索速度
tree = spatial.KDTree(emoji_mean_array)

整个图像的平均颜色计算公式如下。

np.load,读取磁盘数组数据的函数,通常数组是以未压缩的原始二进制格式保存在扩展名为.npy的文件中。

indices = []
# 平整数组,一维
flattened_img = G_sm.reshape(-1, G_sm.shape[-1])
print(flattened_img.shape)# 匹配最相似的表情符号的像素
for pixel in flattened_img:pixel_ = np.concatenate((pixel, [1]))# 查询最近的索引_, index = tree.query(pixel_)indices.append(index)

将原图上每个像素点的颜色均值和emoji的颜色均值配对上。

# 从索引中获取对应的表情符号
emoji_matches = emoji_array[indices]# 获取图片的高度
dim = G_sm.shape[0]
print(dim)# 设置最终生成图像的大小,每个表情符号的形状都是(16,16,4),R, G, B, alpha
resized_ar = emoji_matches.reshape((dim, dim, 16, 16,4))

设置生成图像的大小,每个emoji图片的大小设置成16*16。

# 转换单个表情符号补丁(5维)
# 使用numpy块生成完整的图像(三维)
final_img = np.block([[[x] for x in row] for row in resized_ar]) 

生成最终结果图像,并且保存。

# 设置画布
plt.figure()
# 去除坐标轴
plt.axis( off )
# 显示图片
plt.imshow(final_img)# 保存emoji马赛克风格图像,去除白边
plt.savefig( image_emoji.png , bbox_inches="tight", pad_inches=0.0)
plt.show()

通过设置plt.savefig的参数,去除图像白边,保存图片。

下面就使用小F的微信头像为例,来实验一波~

生成的emoji图看起来不是很细腻,可以设置一下图片参数为100。

G_sm = np.array(Image.open( weixin.png ).resize([100, 100]).getdata()).reshape([100, 100, 3])/256

得到结果如下。

看起来还不错,大家伙也可以使用自己喜欢的头像去生成~


  • 你点的每个“在看”,我都认真当成了AI

2021来了,用Python换一张头像到新年!相关推荐

  1. 新年新气象,2021来了,用Python换一张头像迎新年吧!

    新的一年,新气象. 不少人都会选择换一个微信头像,迎接新的一年. 这期小F就来教大家,如何使用Python生成emoji风格的头像. 效果大致如下图,由很多的emoji图片方块组成一张新的头像图片 细 ...

  2. 2021年11月Python小屋编程比赛获奖名单

    中国大学MOOC"Python程序设计基础"第5次开课 推荐图书: <Python程序设计基础(第2版)>,ISBN:9787302490562,董付国,清华大学出版社 ...

  3. 2021年10月Python小屋编程比赛获奖名单

    全国高校教师Python课程高级研修班(线上,11月20-21日) 中国大学MOOC"Python程序设计基础"第5次开课 推荐图书: <Python程序设计基础(第2版)& ...

  4. 2021年6月Python小屋编程比赛获奖名单

    推荐图书: <Python程序设计基础(第2版)>,ISBN:9787302490562,董付国,清华大学出版社,第19次印刷,清华大学出版社2019.2020年度畅销图书,山东省高等教育 ...

  5. 使用Python判断俩张图像相同或以某种方式相似

    使用Python判断俩张图像相同或以某种方式相似 1. 均方误差(MSE) 2. 结构相似性指数(SSIM) 3. 效果图 4. 总结 参考 比较图像有俩种方案: 使用图像哈希/感知哈希/差分哈希比较 ...

  6. tp5的验证码点击刷新看不清 换一张

    tp5的验证码功能已经集成到框架的扩展之中了,只是官方手册上没有仔细的介绍,导致不知道该如何像tp3一样实现点击刷新验证码&更换验证,其实蛮简单的. 首先使用Composer安装think-c ...

  7. 数据3分钟丨​PingCAP DevCon 2021回顾;openGauss社区颁发首张OGCA认证证书

    数据 3 分钟 由 ACDU (中国 DBA 联盟) 与墨天轮联合出品的全新视频节目上线啦-三分钟带你来了解数据行业动态,节目内容主要包含数据行业最新的产品发布.公司大事件.行业新闻等. 本期内容概览 ...

  8. 2021年12月Python小屋编程比赛获奖名单

    首先祝所有朋友元旦快乐,在新的一年里天天开心,在技术上每天都有新突破! 中国大学MOOC"Python程序设计基础"免费学习地址 推荐图书: <Python程序设计基础(第2 ...

  9. 2021年8月Python小屋编程比赛获奖名单

    推荐图书: <Python程序设计基础(第2版)>,ISBN:9787302490562,董付国,清华大学出版社,第19次印刷,清华大学出版社2019.2020年度畅销图书,山东省高等教育 ...

最新文章

  1. 键盘 Input子系统
  2. python 导入包 作用域_Python 包、模块、函数、变量作用域
  3. 【机器学习】端到端机器学习实践
  4. 学习DX编程中的一个很丢脸,但是不知道是为什么的问题
  5. MATLAB图像去雾算法
  6. 纠删码(Erasure Code)及其演进LRC(Locally Repairable Codes)原理讲解
  7. https证书格式转换(cer转bks)
  8. 新手小白如何短时间内熟练运营微信公众号
  9. 2805076 /system/WTD/android.fg_blocked_67fc4997-ims导致binder耗尽
  10. 云深互联:跨越界限的集成者
  11. 微信分享(JS-SDK权限签名算法)-Java实现
  12. 两台深信服防火墙主备部署在出口,前置两台运营商线路接入交换机场景的配置方法
  13. Vue动画没效果问题
  14. 谈谈百度搜索为什么那么快?
  15. HTML学习笔记(一)——文本标签整合
  16. 抖音火山版批量无水印下载(python)脚本
  17. Android--Notification横幅通知栏
  18. windows安装mysql5.7简单详细教程(带百度云)
  19. Uni-APP+Vite+Vue3+TS+Vant 搭建项目
  20. JS immutable组件

热门文章

  1. html中引用js文件无效,为什么HTML中无法调用引用JS文件中方法?
  2. html怎么调用node.js,javascript – 在HTML中使用Node.js模块
  3. [SDOI2010] 魔法猪学院
  4. 2022-2028年全球与中国自动细胞分选机行业市场深度调研及投资预测分析
  5. linux启动常用软件命令,Linux常用软件启动、停止、重启命令
  6. 基于Java+Swing+Mysql实现旅游管理信息系统
  7. 爆肝整理!2022年字节跳动 java 后端开发岗面试题整理
  8. 腾讯一面 SNG 腾讯云 安全运营开发
  9. Qt,优化QTreeWidget的三态:勾选,未勾选,半勾选
  10. 9 种开源的服务网格比较