用 Python 给你一个圣诞帽

网站建设5年前发布
34 0 0

圣诞将至,虽然咱不过这洋节,但是热闹还是要凑一下的,相信已经有很多圣诞帽相关的周边在流传了,今天咱们就自己动手,给头像增加一个圣诞帽,在计算机中,图像是以矩阵的形式保存的,先行后列。所以,一张宽×高×颜色通道=480×256×3的图片会保存在一个256×480×3的三维张量中。图像处理时也是按照这种思想进行计算的(其中就包括 OpenCV 下的图像处理),即 高×宽×颜色通道。,对于一幅的数字图像,我们看到的是 肉眼可见的一幅真正的图片,但是计算机看来,这副图像只是一堆亮度各异的点。一副尺寸为 M × N 的图像可以用一个 M × N 的矩阵来表示,矩阵元素的值表示这个位置上的像素的亮度,一般来说像素值越大表示该点越亮。,一般来说,灰度图用 2 维矩阵表示,彩色(多通道)图像用 3 维矩阵(M× N × 3)表示。,描述一个像素点,如果是灰度,那么只需要一个数值来描述它,就是单通道。如果一个像素点,有RGB三种颜色来描述它,就是三通道。而四通道图像,就是R、G、B加上一个A通道,表示透明度。一般叫做alpha通道,表示透明度。,Setting Region of Interest (ROI),翻译成白话为,设置感兴趣的区域。mask是做图像掩膜处理,相当于把我们不关心的部位覆盖住,留下ROI部分。上面说的alpha就可以作为mask。,矩阵索引、切片等,这里我自己掌握的也不好,就不多说了,小伙伴儿们可以自行学习。,有了基础知识后,我们来简单看下代码。,首先安装需要要用到的 OpenCV​ 和 dlib 库,使用pip分别安装之,然后手工在网上下载数据模型文件 shape_predictor_5_face_landmarks.dat,地址如下:http://dlib.net/files/,下载后放到项目目录下。,有兴趣的同学可以玩玩那个 shape_predictor_68_face_landmarks.dat,识别出的人脸关键点有68个之多呢。,20230306152921c3df22d915475699b73591499e0e8a56601278394,我们首先要做的就是处理帽子,我们使用的图片如下,20230306152550f7fc66513a330a6374b945497e7adf3e5dcaa0446,先提取帽子图片的rgb和alpha值,我们得到的效果如下:,rgb图,2023030615292183a159174660a15d5e2853e72054915bf2b482400,alpha图,20230306152551c879408569304880519822a9ffe8d3b726a9f9884,对于的打印出的a数值如下:,下面进行人脸检测,使用dlib处理。,接下来是按照比例缩小帽子的图片,进行 ROI 提取,mask 变量,取出了帽子的区域。,2023030615255171f09a6718905144fea56574fb556f7056d75c602,mask_inv 变量,用来取出人脸图片中安装帽子的区域。,20230307014516b8374fb051bdc358736082f4c5d8c9c06ac401655,接下来在人脸图片中取出安装帽子的区域(ROI),再接下来在人脸图片中取出帽子形状区域,这里是把图片默认的uint8​类型转换成了float类型进行运算,最后又转换回来。,20230306152551c430db0951cd2074ef7923a3a4a4a8cae7be10637,黑黑的部分就是我们要放置帽子的地方。,在帽子图片中提取帽子部分。,使用刚刚调整大小的帽子图片来提取。,2023030615255206e8be611c9f16f9d54631da1b274ab299b204502,可以看到,除了帽子部分,其他区域已经掩模处理了。,以上就是提取ROI的过程,比较难懂,需要好好琢磨,尤其是矩阵的切片、mask处理部分。,最后一步就是把人脸图片与帽子合成到一起了,也就是把人脸空余帽子部分的图片区域和帽子只展示帽子区域的图片区域(有点拗口)合并在一起。,效果如下:,2023030615293018284e790fcb9fbfde5444cc92e16e3a0fa614803,刚刚好,完美叠加图片。,最后把这个片段放回人脸原图中,展示图片,2023030615255349cd0ce72b2244f5457225a134369fd4d720c1236,美美的图片就出来啦!,我们再尝试几张不同的图片。,2023030615255348e394381b30bec61b11586e104ece120dcdde675,20230306152554320ba09429941b4e6dc7952eaf109e77ea4bfd527,整体效果还不错哦,需要注意的是,在测试的时候,我们尽量选择人脸占比比较大的图片来合成,效果要好很多哦~

© 版权声明

相关文章