新的一年,新气象。

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

这期小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),其中每个像素§都是A的元素。

很多人学习python,不知道从何学起。
很多人学习python,掌握了基本语法过后,不知道在哪里寻找案例上手。
很多已经做案例的人,却不知道如何去学习更加高深的知识。
那么针对这三类人,我给大家提供一个好的学习平台,免费领取视频教程,电子书籍,以及课程的源代码!
QQ群:810735403

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

如果不是灰度级(例如在这次的情况下),则每个像素都是尺寸为3-红色®,绿色(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

得到结果如下。

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

在这里还是要推荐下我自己建的Python开发交流学习(qq)群:810735403,群里都是学Python开发的,如果你正在学习Python ,欢迎你加入,大家都是软件开发党,不定期分享干货(只有Python软件开发相关的),包括我自己整理的一份2020最新的Python进阶资料和高级开发教程,欢迎进阶中和想深入Python的小伙伴!

新年新气象,2021来了,用Python换一张头像迎新年吧!相关推荐

  1. 2021来了,用Python换一张头像到新年!

    点击 机器学习算法与Python学习 ,选择加星标 精彩内容不迷路 新的一年,新气象. 不少人都会选择换一个微信头像,迎接新的一年. 这期小F就来教大家,如何使用Python生成emoji风格的头像. ...

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

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

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

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

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

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

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

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

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

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

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

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

  8. 【2021最新版】Python 并发编程实战,用多线程、多进程、多协程加速程序运行

    [2021最新版]Python 并发编程实战,用多线程.多进程.多协程加速程序运行 视频地址:https://www.bilibili.com/video/BV1bK411A7tV/ P1 Pytho ...

  9. python在手机上如何模拟登录_用 Python 换个姿势「模拟登录」

    原标题:用 Python 换个姿势「模拟登录」 作者:librauee 今天给大家介绍Python一个非常有意思的库PyUserInput,它集成了PyMouse和PyKeyboard这俩模块,能够模 ...

最新文章

  1. TensorFlow平台搭建
  2. LevelDb系列之简介
  3. 整理Silverlight资源列表(四)——Silverlight案例补充
  4. Android Studio NDK 代码 Source Insight调试 (NDK 目前开发方案 | NDK 编译 | 导入 so 库 | 项目编码转换)
  5. jupyter notebook即原来的Ipython notebook的使用方法
  6. html5和前端精要(1)-架构与基础(1)
  7. 知道坐标matlab三维作图,已知点坐标,要求根据坐标作出三维曲面图
  8. 机智云小程序启蒙:WebSocket网页控制
  9. 看代码学知识之(2) ListView无数据时显示其他View
  10. java 参数代替所有类_Java中的常用类
  11. windows apche php mysql zend_Windows XP上安装配置 Apache+PHP+Mysql+Zend
  12. 计算机系统设计 片上系统 pdf,一种基于过程级编程模型的可重构片上系统设计方法.pdf...
  13. 中国联通辟谣“不支持华为”:恶意诽谤 将通过法律手段维护权益
  14. 【笔记】LR配置ODBC连接数据库进行参数化(mysql )未完待续
  15. 使用socket模块,多线程扫描指定ip的端口开放情况
  16. linux查看串口驱动
  17. Jmeter基础教程
  18. C# WinForm制作登录界面
  19. 深度解析Eureka的自我保护机制
  20. 3.2 电话号码对应英语单词

热门文章

  1. 电脑配置jdk环境变量_苹果电脑配置环境变量
  2. 大牛讲解信号与系统以及数字信号处理
  3. 生产环境nginx集群高可用方案
  4. 腾讯云存储产品全线升级,满足更多高性能存储场景
  5. linux人员最爱用的键盘,Linux工作者必备-filco 87 忍者2代 黑色青轴
  6. 计算机视觉注意力网络(一)——简介
  7. 投影仪不能显示桌面图标(文字)
  8. 计算机屏幕位置高低,电脑显示器的最佳位置
  9. 网页上显示word和Excel
  10. RLC电阻电容电感基础知识——电容篇