在我们的生活中常常要用到各种底色要求的证件电子照,红底、蓝底、或者白底,而假如你手上只有一种底色的证件照,你又不想再去拍又不会PS怎么办?今天教你们用OpenCV和Python给你的证件照换底色。

  • Python3

  • numpy函数库

  • OpenCV库

  • Windows10 + Anaconda+Pycharm

1.读取要换底色的图片

导入OpenCV库,使用imread函数读取图片。

import cv2
import numpy as np# 读取照片并显示
image=cv2.imread('yang.jpg')
cv2.imshow('image',image)

2.对图片进行缩放

证件照原图太大,不易显示,cv2.resize函数进行缩放处理。

# 图像缩放并显示
img = cv2.resize(image,None,fx=0.5,fy=0.5)
rows,cols,channels = img.shape
print(rows,cols,channels)
cv2.imshow('img',img)

3.将图片转换为灰度图像

cv2.cvtColor函数将读取的图像默认是BGR格式转换为HSV格式,将彩色图片转换为hsv灰度图片,之后才能进行腐蚀和膨胀操作。

# 图片转换为灰度图并显示
hsv = cv2.cvtColor(img,cv2.COLOR_BGR2HSV)
cv2.imshow('hsv',hsv)

4.对图片进行二值化处理

通过cv2.inRange函数对图片进行二值化操作,获取背景的mask,二值化处理视为了将灰度图片转换为黑白图片,如下图将红色的背景用白色表示,白色区域就是我们后面遍历像素点替换的条件,就是将白色的区域替换为蓝色。

cv2.inRange(hsv, lower_red, upper_red):在lower_red和upper_red两个阈值内的像素值设置为白色(255),而不在阈值区间内的像素值设置为黑色(0

# 图片的二值化处理
#红底变蓝底
#将在两个阈值内的像素值设置为白色(255),而不在阈值区间内的像素值设置为黑色(0)
lower_red= np.array([0,135,135])
upper_red = np.array([180,245,230])
mask = cv2.inRange(hsv, lower_red, upper_red)
# 显示图像
cv2.imshow('mask',mask)
# #蓝底变红底
# lower_blue = np.array([90,70,70])
# upper_blue = np.array([110,255,255])
# mask = cv2.inRange(hsv, lower_blue, upper_blue)
# 显示图像
# cv2.imshow('mask',mask)

5.对图片进行腐蚀和膨胀

在进行二值化操作之后,我们可以看到黑色区域有一些噪声,嘴的部分是白的,还有少数白点,就cv2.erode或者cv2.dilate函数对图片再进行腐蚀和膨胀操作,均可以有效消除噪声。

#腐蚀膨胀
erode=cv2.erode(mask,None,iterations=1)
cv2.imshow('erode',erode)dilate=cv2.dilate(erode,None,iterations=1)
cv2.imshow('dilate',dilate)

6.遍历像素点替换背景颜色

对上述进行了腐蚀或者膨胀操作的图片进行像素点遍历,将白色区域的像素点的位置,也就是原图的背景部分的像素的对应的位置,替换成你想要替换的底色即可。

dilate[i,j]==255:  像素点为255表示的是白色,我们就要将白色处的像素点,替换为你想要的照片底色。

img[i,j]=(0,0,255): 此处替换颜色,为BGR通道,不是RGB通道,若是想要将红底变成蓝底img[i,j]=(255,0,0),若是想将蓝底变为红底则img[i,j]=(0,0,255),若是想变白底img[i,j]=(255,255,255)

# 遍历每个像素点,进行颜色的替换
for i in range(rows):for j in range(cols):if dilate[i,j]==255:    #像素点255表示白色img[i,j]=(255,0,0)  # 此处替换颜色,为BGR通道,不是RGB通道
cv2.imshow('res',img)
# 窗口等待的命令,0表示无限等待
cv2.waitKey(0)

红底变蓝底

蓝底变红底

变白底

完整代码,关注微信公众号:码农的后花园,在后台回复关键字:证件照,即可下载使用。

扫描二维码

获取更多精彩

码农的后花园

文章都看完了不点个

教你用OpenCV 和 Python给证件照换底色(蓝底 <->红底->白底)相关推荐

  1. 教你用OpenCV 和 Python给证件照换底色(蓝底 -红底-白底)

    在我们的生活中常常要用到各种底色要求的证件电子照,红底.蓝底.或者白底,而假如你手上只有一种底色的证件照,你又不想再去拍又不会PS怎么办?今天教你们用OpenCV和Python给你的证件照换底色. P ...

  2. python怎么改成白底_教你用OpenCV 和 Python给证件照换底色(蓝底 -红底-白底)...

    ​在我们的生活中常常要用到各种底色要求的证件电子照,红底.蓝底.或者白底,而假如你手上只有一种底色的证件照,你又不想再去拍又不会PS怎么办?今天教你们用OpenCV和Python给你的证件照换底色.P ...

  3. 基于python的证件照_20行代码教你用python给证件照换底色的方法示例

    1.图片来源 该图片来源于百度图片,如果侵权,请联系我删除!图片仅用于知识交流. 2.读取图片并显示 imread():读取图片: imshow():展示图片: waitkey():设置窗口等待,如果 ...

  4. python换照片底色_详解Python给照片换底色(蓝底换红底)

    现在网上出现了很多在线换底色的网页版工具是这么做的呢?其实用Python就可以实现. 环境要求 Python3 numpy函数库 opencv库 安装 下载适应版本的numpy函数库,我电脑是WIN1 ...

  5. 用python把图片换成蓝底_详解Python给照片换底色(蓝底换红底)

    现在网上出现了很多在线换底色的网页版工具是这么做的呢?其实用Python就可以实现. 环境要求 Python3 numpy函数库 opencv库 安装 下载适应版本的numpy函数库,我电脑是WIN1 ...

  6. python换图片_详解Python给照片换底色(蓝底换红底)

    现在网上出现了很多在线换底色的网页版工具是这么做的呢?其实用Python就可以实现. 环境要求 Python3 numpy函数库 opencv库 安装 下载适应版本的numpy函数库,我电脑是WIN1 ...

  7. python黑屏改成白底_详解Python给照片换底色(蓝底换红底)

    现在网上出现了很多在线换底色的网页版工具是这么做的呢?其实用Python就可以实现. 环境要求 Python3 numpy函数库 opencv库 安装 下载适应版本的numpy函数库,我电脑是WIN1 ...

  8. python界面怎么改颜色_20行代码教你用python给证件照换底色

    1.图片来源 该图片来源于百度图片,如果侵权,请联系我删除!图片仅用于知识交流.本文只是为了告诉大家:python其实有很多黑科技(牛逼的库),我们既可以用python处理工作中的一些事儿,同时我们也 ...

  9. python读取身份证照片信息_20行代码教你用Python改变身份证照片的背景色,python,给,证件照,换,底色...

    1.图片来源 该图片来源于百度图片,如果侵权,请联系我删除!图片仅用于知识交流. 2.读取图片并显示 imread():读取图片: imshow():展示图片: waitkey():设置窗口等待,如果 ...

最新文章

  1. Java爬取解析去哪儿景点信息
  2. MongoDB数据库(二:高级操作)
  3. java-vector hashtable过时?
  4. Win 10 或可以运行安卓APP
  5. postMessage解决跨域问题
  6. LeetCode: Single Number I II
  7. 深度学习实战 Tricks —— 梯度消失与梯度爆炸(gradient exploding)
  8. 沪漂6年,我终于在上海买了第一套房
  9. mac下安装pyaudio
  10. web开发实现火星坐标、百度坐标、WGS84坐标互相转换
  11. 微信公众号实现人脸识别功能
  12. 用texstudio写伪代码
  13. 新建销售群开场语句_销售会议开场白台词
  14. WIN10任务栏卡死,鼠标一直转圈(亲测有效)
  15. 紫光云这匹黑马,了解一下
  16. 不能换行 俄语 前端h5_H5兼容问题及解决方法
  17. 99%的人都不知道内网、外网、宽带、带宽、流量、网速之间的区别与联系
  18. C语言【atoi函数】
  19. 简单的Python五子棋
  20. slowfast代码实现和论文理解

热门文章

  1. 中国开发者将迎来黄金十年
  2. [ICPC Asia Nanjing 2019] Holy Grail (spfa最短路)
  3. nyoj-1016-德莱联盟(向量叉乘判断线段相交)
  4. 第八章 磁盘存储器的管理
  5. 拿下 ACM 金牌!
  6. Kafka集群搭建过程(kafka2.5+eagle)
  7. html复制粘贴的文字自动换行,如何解决Word中粘贴网页上的文字自动换行的现象...
  8. 用c语言编写九九乘法表
  9. 每日一题(二三)function Foo(){ Foo.a = function(){console.log(1); } this.a = function(){console.log(2)}) Fo
  10. STM32与串口屏交互(USART HMI)