随着圣诞的到来,想给给自己的头像加上一顶圣诞帽。如果不是头像,就加一个圣诞老人陪伴。

用Python给头像加上圣诞帽,看了下大概也都是来自2017年大神的文章:https://zhuanlan.zhihu.com/p/32283641

主要流程

素材准备

人脸检测与人脸关键点检测

调整大小,添加帽子

用dlib的正脸检测器进行人脸检测,用dlib提供的模型提取人脸的五个关键点

# dlib人脸关键点检测器

predictor_path = "shape_predictor_5_face_landmarks.dat"

predictor = dlib.shape_predictor(predictor_path)

# dlib正脸检测器

detector = dlib.get_frontal_face_detector()

# 正脸检测

dets = detector(img, 1)

# 如果检测到人脸

if len(dets)>0:

for d in dets:

x,y,w,h = d.left(),d.top(), d.right()-d.left(), d.bottom()-d.top()

# x,y,w,h = faceRect

cv2.rectangle(img,(x,y),(x+w,y+h),(255,0,0),2,8,0)

# 关键点检测,5个关键点

shape = predictor(img, d)

for point in shape.parts():

cv2.circle(img,(point.x,point.y),3,color=(0,255,0))

cv2.imshow("image",img)

cv2.waitKey()

调整帽子大小,带帽

选取两个眼角的点,求中心作为放置帽子的x方向的参考坐标,y方向的坐标用人脸框上线的y坐标表示。然后我们根据人脸检测得到的人脸的大小调整帽子的大小,使得帽子大小合适。

# 选取左右眼眼角的点

point1 = shape.part(0)

point2 = shape.part(2)

# 求两点中心

eyes_center = ((point1.x+point2.x)//2,(point1.y+point2.y)//2)

# cv2.circle(img,eyes_center,3,color=(0,255,0))

# cv2.imshow("image",img)

# cv2.waitKey()

# 根据人脸大小调整帽子大小

factor = 1.5

resized_hat_h = int(round(rgb_hat.shape[0]*w/rgb_hat.shape[1]*factor))

resized_hat_w = int(round(rgb_hat.shape[1]*w/rgb_hat.shape[1]*factor))

if resized_hat_h > y:

resized_hat_h = y-1

# 根据人脸大小调整帽子大小

resized_hat = cv2.resize(rgb_hat,(resized_hat_w,resized_hat_h))

添加小图标

当然有些同学的头像不是人物或不能准确的识别无关,所有添加了标识。(即在右下添加小图标)。

小图标避免单调,是从图标中随机选择一个:

代码如下:

# 水印图片

num = random.randint(1, 5)

logo = Image.open("img_icon/santa_" + str(num) + ".png")

img = Image.open(imgPath)

print(img.size, logo.size)

# 图层

layer = Image.new("RGBA", img.size, (255, 255, 255, 0))

layer.paste(logo, (img.size[0] - logo.size[0], img.size[1]-logo.size[1]))

# 覆盖

img_after = Image.composite(layer, img, layer)

# img_after.show()

img_after.save(outImgePath)

结果如下

代码获取:关注公众号,回复:20191224 或 圣诞

python画圣诞帽_用Python给头像加上圣诞帽或圣诞老人小图标相关推荐

  1. 用python画风车_用Python画小女孩放风筝的示例

    我就废话不多说了,直接上代码吧! # coding:utf-8 2import turtle as t 3import random 4# 画心 5def xin(): 6 def curvemove ...

  2. 用python画圆锥_用python画一幅美瞳,今日份来自程序员的浪漫

    如果说,眼睛是心灵的窗户,那么,美瞳就是心灵的彩窗,就像下图中这样. 而我们今天所要挑战的,就是用python画美瞳,而且是五分钟之内画三百副争奇斗艳.各领风骚.绝不重样的美瞳.作为这颗地球上最纯情的 ...

  3. 怎么用python画房子_用python画一个小房子

    用python画一个小房子 2020年07月22日 | 萬仟网IT编程 | 我要评论 如何用python画一个小房子?效果图如下:代码如下:import turtle# 前置p = turtle.Pe ...

  4. python画抛物线_在python中利用最小二乘拟合二次抛物线函数的方法

    1.最小二乘也可以拟合二次函数 我们都知道用最小二乘拟合线性函数没有问题,那么能不能拟合二次函数甚至更高次的函数呢?答案当然是可以的.下面我们就来试试用最小二乘来拟合抛物线形状的的图像. 对于二次函数 ...

  5. python turtle画房子代码里面的窗子,如何用python画房子_用python画一个小房子

    如何用python画一个小房子? 效果图如下: 代码如下: import turtle # 前置 p = turtle.Pen() # 作者要说的话 for i in range(6): print( ...

  6. 用python画佩奇_使用python画个小猪佩奇的示例代码

    基本原理 选好画板大小,设置好画笔颜色.粗细,定位好位置,依次画鼻子.头.耳朵.眼睛.腮.嘴.身体.手脚.尾巴,完事儿. 都知道,Turtle 是 Python 内置的一个比较有趣味的模块,俗称&qu ...

  7. 用python画皇冠_用python做数字油画或者从一幅画学习风格,去画另一幅画

    原博文 2018-08-30 17:12 − 1. 用python做数字油画 模块: pillow 2. 从一幅画学习风格,去画另一幅画 http://pytorch.org/tutorials/ad ...

  8. 利用python画曲线_利用python画出AUC曲线的实例

    以load_breast_cancer数据集为例,模型细节不重要,重点是画AUC的代码.1XS免费资源网 直接上代码:1XS免费资源网 from sklearn.datasets import loa ...

  9. 利用python画曲线_利用Python绘制血药浓度-时间曲线——口服吸收一室模型

    血药浓度-时间曲线一般是通过拟合所测定的血药浓度点而画出来的,但是在某些时候,如阅读文献时,我们需要根据别人报道的PK参数来画出药时曲线.Python语法简单,拥有丰富的开源库,下面尝试通过Pytho ...

  10. 用python画明星_用Python画一颗特别的心送给她

    [前言] 520刚过去了,大家有没有跟自己喜欢的对象在一起呢? 520 当天你还在送 玫瑰花?巧克力?情侣套装?... 小编就想说:你能不能换点新意呢,这些操作已经普通的不能再普通了吧!就像别人来例假 ...

最新文章

  1. fpga数据位宽截取_FPGA信号截位策略研究
  2. 在IOS开发中根据(id)sender获取UIButton的信息
  3. Linux Vi 删除全部内容,删除某行到结尾,删除某段内容 的方法
  4. windows分区的理解
  5. Ubuntu 14.04.02 安装openvswitch-2.3.1
  6. 提高数据库处理查询速度
  7. 【Kafka】Kafka如何开启SSL 控制台消费与生产 代码消费与生产
  8. 学前端有什么好方法,怎么才能更快学会前端?
  9. 20190909:(leetcode习题)第一个错误的版本
  10. IIS HTTP文件服务器搭建步骤
  11. 快速了解java语言
  12. 五子棋游戏代码(完整版)
  13. 计算机等级考试网络工程师介绍,全国计算机等级考试网络工程师
  14. 基于51单片机+LD3320语音模块+SYN6288语音合成——语音识别智能分类垃圾桶
  15. 什么是一维表 什么是二维表
  16. IIC方式读驱动AT24C16芯片
  17. 共享虚拟机是什么意思_苹果笔记本电脑MacBook双系统or虚拟机选择指南
  18. MySQL查看表结构及查看建表语句
  19. 夏普linux电视安装apk,海信电视u盘安装apk的两种方法,内附图文步骤
  20. Android Gradle权威指南

热门文章

  1. 支付宝小程序通用公共方法封装
  2. hdu 2121 Ice_cream’s world II
  3. 为什么MAR的位数对应存储单元的个数?
  4. 软件构造期末复习知识点总结
  5. 期货交易系统的基本结构
  6. 用java实现微信支付,退款,部分退款服务端
  7. 【零基础搭建网站】Wordpress零基础60元搭建网站
  8. 前端开发神器Hype3初体验-可视化、响应式、动效
  9. mysql创建数据库及中英文数据表--插入数据
  10. 03.19.03-test 感谢百万,乔恩·斯基特!