jsmubanlogo
  • 首页
  • 网页模板
  • 特效代码
  • 博文源码
  • 插件下载
  •    

Python 利用OpenCV给照片换底色

收藏    

作者第十天    2021-11-14

      

OpenCV的全称是:Open Source Computer Vision Library。OpenCV是一个基于BSD许可(开源)发行的跨平台计算机视觉库,可以运行在linux、Windows和Mac OS操作系统上。它轻量级而且高效——由一系列 C 函数和少量 C++ 类构成,同时提供了python、Ruby、MATLAB等语言的接口,实现了图像处理和计算机视觉方面的很多通用算法。相比于PIL库来说OpenCV更加强大, 可以做更多更复杂的应用,比如人脸识别等。

1. 读入并显示图片

  1. import cv2
  2.  
  3. # 读入图片
  4. img = cv2.imread(r'D:\test\test_001.jpg', 1)
  5.  
  6. # 显示图像
  7. cv2.imshow('img', img)
  8.  
  9. # 窗口等待命令 0表示无限等待
  10. cv2.waitKey(0)

运行效果如下:

在这里插入图片描述

2. 缩放图片

  1. import cv2
  2. # 读入图片
  3. img = cv2.imread(r'D:\test\test_001.jpg', 1)
  4. rows, cols, channels = img.shape
  5. print(rows, cols, channels)
  6.  
  7. new_img = cv2.resize(img, None, fx=0.5, fy=0.5)
  8.  
  9. rows, cols, channels = new_img.shape
  10. print(rows, cols, channels)
  11.  
  12. # 显示图像
  13. cv2.imshow('new_img', new_img)
  14.  
  15. # 窗口等待命令 0表示无限等待
  16. cv2.waitKey(0)

将图片尺寸按比例缩小一半,运行效果如下:

在这里插入图片描述

3. 彩色图像转换为灰度图像

彩色图片有RGB三个颜色通道,无法进行腐蚀和膨胀的操作。这个就需要我们将彩色图片转换为hsv灰度图像后,再进行腐蚀和膨胀的操作。

  1. import cv2
  2.  
  3. img = cv2.imread(r'D:\test\test_001.jpg', 1)
  4. new_img = cv2.resize(img, None, fx=0.5, fy=0.5)
  5.  
  6. rows, cols, channels = new_img.shape
  7. print(rows, cols, channels)
  8.  
  9. # 显示图像
  10. cv2.imshow('new_img', new_img)
  11.  
  12. # 将图片转换为灰度图片
  13. gray_img = cv2.cvtColor(new_img, cv2.COLOR_BGR2HSV)
  14. cv2.imshow('hsv', gray_img)
  15. cv2.waitKey(0)

运行效果如下:

在这里插入图片描述

4. 图片二值化处理

二值化处理是为了将图片转换为黑白图片,目的是滤除太大或太小值像素、消除噪声,从而从灰度图中获取二值图像(将图像的灰度值设置为0或255),实现增强整个图像呈现更为明显的黑白效果,同时也大大减少了数据量。

  1. import cv2
  2. import numpy as np
  3.  
  4. img = cv2.imread(r'D:\test\test_001.jpg', 1)
  5. new_img = cv2.resize(img, None, fx=0.5, fy=0.5)
  6.  
  7. rows, cols, channels = new_img.shape
  8. print(rows, cols, channels)
  9.  
  10. # 显示图像
  11. cv2.imshow('new_img', new_img)
  12.  
  13. # 将图片转换为灰度图片
  14. gray_img = cv2.cvtColor(new_img, cv2.COLOR_BGR2HSV)
  15. cv2.imshow('hsv', gray_img)
  16.  
  17. # 图片二值化处理
  18. low_value = np.array([90, 70, 70])
  19. high_value = np.array([110, 255, 255])
  20. binary_img = cv2.inRange(gray_img, low_value, high_value)
  21. cv2.imshow('binary_img', binary_img)
  22.  
  23. cv2.waitKey(0)

运行效果如下:

在这里插入图片描述

5. 图像的腐蚀和膨胀

图像的膨胀(Dilation)和腐蚀(Erosion)是两种基本的形态学运算,主要用来寻找图像中的极大区域和极小区域。其中膨胀类似于“领域扩张”,将图像中的高亮区域或白色部分进行扩张,其运行结果图比原图的高亮区域更大;腐蚀类似于“领域被蚕食”,将图像中的高亮区域或白色部分进行缩减细化,其运行结果图比原图的高亮区域更小。

  • 图像被腐蚀后,去除了噪声,但是会压缩图像。
  • 对腐蚀过的图像,进行膨胀处理,可以去除噪声,并且保持原有形状。
  1. # 腐蚀膨胀
  2. erode = cv2.erode(binary_img, None, iterations=1)
  3. dilate = cv2.dilate(erode, None, iterations=1)
  4. cv2.imshow('dilate', dilate)

6. 遍历像素点进行颜色替换

图像是由每一个像素点组成的,找到腐蚀后得到图片的白色底色处的像素点,然后将原图中对应位置处的像素点,替换为红色或者白色,即可实现给照片换底色。

  1. import cv2
  2. import numpy as np
  3.  
  4. img = cv2.imread(r'D:\test\test_001.jpg', 1)
  5. new_img = cv2.resize(img, None, fx=0.5, fy=0.5)
  6.  
  7. rows, cols, channels = new_img.shape
  8. print(rows, cols, channels)
  9.  
  10. # 显示图像
  11. cv2.imshow('new_img', new_img)
  12.  
  13. # 将图片转换为灰度图片
  14. gray_img = cv2.cvtColor(new_img, cv2.COLOR_BGR2HSV)
  15.  
  16. # 图片二值化处理
  17. low_value = np.array([90, 70, 70])
  18. high_value = np.array([110, 255, 255])
  19. binary_img = cv2.inRange(gray_img, low_value, high_value)
  20.  
  21. # 腐蚀膨胀
  22. erode = cv2.erode(binary_img, None, iterations=1)
  23. dilate = cv2.dilate(erode, None, iterations=1)
  24. # cv2.imshow('dilate', dilate)
  25.  
  26. # 遍历替换
  27. for i in range(rows):
  28. for j in range(cols):
  29. if dilate[i, j] == 255:
  30. # 此处替换颜色,为BGR通道
  31. new_img[i, j] = (0, 0, 255) # (0, 0, 255)替换为红底 (255, 255, 255)替换为白底
  32.  
  33. cv2.imshow('red_bg_img', new_img)
  34. # 窗口等待命令 0表示无限等待
  35. cv2.waitKey(0)
  36. cv2.destroyAllWindows()

运行效果如下:

在这里插入图片描述
在这里插入图片描述

程序运行成功,可以将照片的蓝底换为红底或者白底,成功利用opencv实现给照片换底色。

7. 其他说明

测试所用图片来源于百度图片搜索,图片仅用于图像处理知识交流和学习,如有侵权请联系我删除!

到此这篇关于Python 利用OpenCV给照片换底色的示例代码的文章就介绍到这了,更多相关python照片换底色内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

本文标题: Python 利用OpenCV给照片换底色的示例代码本文地址: http://www.cppcns.com/jiaoben/python/329952.html


免责声明:
      1、 资源售价只是赞助,不代表代码或者素材本身价格。收取费用仅维持本站的日常运营所需。
      2、 本站资源来自用户上传,仅供用户学习使用,不得用于商业或者非法用途,违反国家法律一切后果用户自负。用于商业用途,请购买正版授权合法使用。
      3、 本站资源不保证其完整性和安全性,下载后自行检测安全,在使用过程中出现的任何问题均与本站无关,本站不承担任何技术及版权问题,不对任何资源负法律责任。
      4、 如有损害你的权益,请联系275551777@qq.com及时删除。

关于我们 | 积分获取 | 联系我们 | 用户协议 | 标签搜索 | 网站地图.html | 网站地图.xml | 网站地图.txt

Copyright © 2021-2023 All Right Reserved
陕公网安备 61082202000148号      陕ICP备2025078528号-1
js模板网 -陕西千手码农科技有限责任公司