Python 利用OpenCV給照片換底色的示例代碼
OpenCV的全稱是:Open Source Computer Vision Library。OpenCV是一個(gè)基于BSD許可(開源)發(fā)行的跨平臺(tái)計(jì)算機(jī)視覺庫,可以運(yùn)行在Linux、Windows和Mac OS操作系統(tǒng)上。它輕量級(jí)而且高效——由一系列 C 函數(shù)和少量 C++ 類構(gòu)成,同時(shí)提供了Python、Ruby、MATLAB等語言的接口,實(shí)現(xiàn)了圖像處理和計(jì)算機(jī)視覺方面的很多通用算法。相比于PIL庫來說OpenCV更加強(qiáng)大, 可以做更多更復(fù)雜的應(yīng)用,比如人臉識(shí)別等。
1. 讀入并顯示圖片
import cv2 # 讀入圖片 img = cv2.imread(r'D:\test\test_001.jpg', 1) # 顯示圖像 cv2.imshow('img', img) # 窗口等待命令 0表示無限等待 cv2.waitKey(0)
運(yùn)行效果如下:
2. 縮放圖片
import cv2 # 讀入圖片 img = cv2.imread(r'D:\test\test_001.jpg', 1) rows, cols, channels = img.shape print(rows, cols, channels) new_img = cv2.resize(img, None, fx=0.5, fy=0.5) rows, cols, channels = new_img.shape print(rows, cols, channels) # 顯示圖像 cv2.imshow('new_img', new_img) # 窗口等待命令 0表示無限等待 cv2.waitKey(0)
將圖片尺寸按比例縮小一半,運(yùn)行效果如下:
3. 彩色圖像轉(zhuǎn)換為灰度圖像
彩色圖片有RGB三個(gè)顏色通道,無法進(jìn)行腐蝕和膨脹的操作。這個(gè)就需要我們將彩色圖片轉(zhuǎn)換為hsv灰度圖像后,再進(jìn)行腐蝕和膨脹的操作。
import cv2 img = cv2.imread(r'D:\test\test_001.jpg', 1) new_img = cv2.resize(img, None, fx=0.5, fy=0.5) rows, cols, channels = new_img.shape print(rows, cols, channels) # 顯示圖像 cv2.imshow('new_img', new_img) # 將圖片轉(zhuǎn)換為灰度圖片 gray_img = cv2.cvtColor(new_img, cv2.COLOR_BGR2HSV) cv2.imshow('hsv', gray_img) cv2.waitKey(0)
運(yùn)行效果如下:
4. 圖片二值化處理
二值化處理是為了將圖片轉(zhuǎn)換為黑白圖片,目的是濾除太大或太小值像素、消除噪聲,從而從灰度圖中獲取二值圖像(將圖像的灰度值設(shè)置為0或255),實(shí)現(xiàn)增強(qiáng)整個(gè)圖像呈現(xiàn)更為明顯的黑白效果,同時(shí)也大大減少了數(shù)據(jù)量。
import cv2 import numpy as np img = cv2.imread(r'D:\test\test_001.jpg', 1) new_img = cv2.resize(img, None, fx=0.5, fy=0.5) rows, cols, channels = new_img.shape print(rows, cols, channels) # 顯示圖像 cv2.imshow('new_img', new_img) # 將圖片轉(zhuǎn)換為灰度圖片 gray_img = cv2.cvtColor(new_img, cv2.COLOR_BGR2HSV) cv2.imshow('hsv', gray_img) # 圖片二值化處理 low_value = np.array([90, 70, 70]) high_value = np.array([110, 255, 255]) binary_img = cv2.inRange(gray_img, low_value, high_value) cv2.imshow('binary_img', binary_img) cv2.waitKey(0)
運(yùn)行效果如下:
5. 圖像的腐蝕和膨脹
圖像的膨脹(Dilation)和腐蝕(Erosion)是兩種基本的形態(tài)學(xué)運(yùn)算,主要用來尋找圖像中的極大區(qū)域和極小區(qū)域。其中膨脹類似于“領(lǐng)域擴(kuò)張”,將圖像中的高亮區(qū)域或白色部分進(jìn)行擴(kuò)張,其運(yùn)行結(jié)果圖比原圖的高亮區(qū)域更大;腐蝕類似于“領(lǐng)域被蠶食”,將圖像中的高亮區(qū)域或白色部分進(jìn)行縮減細(xì)化,其運(yùn)行結(jié)果圖比原圖的高亮區(qū)域更小。
- 圖像被腐蝕后,去除了噪聲,但是會(huì)壓縮圖像。
- 對(duì)腐蝕過的圖像,進(jìn)行膨脹處理,可以去除噪聲,并且保持原有形狀。
# 腐蝕膨脹 erode = cv2.erode(binary_img, None, iterations=1) dilate = cv2.dilate(erode, None, iterations=1) cv2.imshow('dilate', dilate)
6. 遍歷像素點(diǎn)進(jìn)行顏色替換
圖像是由每一個(gè)像素點(diǎn)組成的,找到腐蝕后得到圖片的白色底色處的像素點(diǎn),然后將原圖中對(duì)應(yīng)位置處的像素點(diǎn),替換為紅色或者白色,即可實(shí)現(xiàn)給照片換底色。
import cv2 import numpy as np img = cv2.imread(r'D:\test\test_001.jpg', 1) new_img = cv2.resize(img, None, fx=0.5, fy=0.5) rows, cols, channels = new_img.shape print(rows, cols, channels) # 顯示圖像 cv2.imshow('new_img', new_img) # 將圖片轉(zhuǎn)換為灰度圖片 gray_img = cv2.cvtColor(new_img, cv2.COLOR_BGR2HSV) # 圖片二值化處理 low_value = np.array([90, 70, 70]) high_value = np.array([110, 255, 255]) binary_img = cv2.inRange(gray_img, low_value, high_value) # 腐蝕膨脹 erode = cv2.erode(binary_img, None, iterations=1) dilate = cv2.dilate(erode, None, iterations=1) # cv2.imshow('dilate', dilate) # 遍歷替換 for i in range(rows): for j in range(cols): if dilate[i, j] == 255: # 此處替換顏色,為BGR通道 new_img[i, j] = (0, 0, 255) # (0, 0, 255)替換為紅底 (255, 255, 255)替換為白底 cv2.imshow('red_bg_img', new_img) # 窗口等待命令 0表示無限等待 cv2.waitKey(0) cv2.destroyAllWindows()
運(yùn)行效果如下:
程序運(yùn)行成功,可以將照片的藍(lán)底換為紅底或者白底,成功利用opencv實(shí)現(xiàn)給照片換底色。
7. 其他說明
測(cè)試所用圖片來源于百度圖片搜索,圖片僅用于圖像處理知識(shí)交流和學(xué)習(xí),如有侵權(quán)請(qǐng)聯(lián)系我刪除!
到此這篇關(guān)于Python 利用OpenCV給照片換底色的示例代碼的文章就介紹到這了,更多相關(guān)python照片換底色內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
django實(shí)現(xiàn)用戶注冊(cè)實(shí)例講解
在本篇文章里小編給大家整理的是關(guān)于django用戶注冊(cè)的相關(guān)實(shí)例內(nèi)容,有興趣的朋友們學(xué)習(xí)下。2019-10-10Python+Pygame實(shí)戰(zhàn)之炫舞小游戲的實(shí)現(xiàn)
提到QQ炫舞,可能很多人想到的第一個(gè)詞是“青春”?;腥婚g,這個(gè)承載了無數(shù)人回憶與時(shí)光的游戲品牌,已經(jīng)走到了第十幾個(gè)年頭。今天小編就來給大家嘗試做一款簡(jiǎn)單的簡(jiǎn)陋版的小游戲——《舞動(dòng)青春*炫舞》,感興趣的可以了解一下2022-12-12pyqt5 實(shí)現(xiàn)工具欄文字圖片同時(shí)顯示
今天小編就為大家分享一篇pyqt5 實(shí)現(xiàn)工具欄文字圖片同時(shí)顯示的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-06-06Python裝飾器如何實(shí)現(xiàn)修復(fù)過程解析
這篇文章主要介紹了Python裝飾器如何實(shí)現(xiàn)修復(fù)過程解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-09-09matlab、python中矩陣的互相導(dǎo)入導(dǎo)出方式
這篇文章主要介紹了matlab、python中矩陣的互相導(dǎo)入導(dǎo)出方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-06-06解決Python 寫文件報(bào)錯(cuò)TypeError的問題
這篇文章主要介紹了解決Python 寫文件報(bào)錯(cuò)TypeError的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-10-10python SQLAlchemy的Mapping與Declarative詳解
這篇文章主要介紹了python SQLAlchemy的Mapping與Declarative詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-07-07matplotlib圖形整合之多個(gè)子圖繪制的實(shí)例代碼
matplotlib繪制多個(gè)子圖的時(shí)候,我們可以根據(jù)自己的想法去排列子圖的順序,也可以生成不同的子圖數(shù)量,本文就詳細(xì)的介紹了matplotlib 多子圖繪制,具有一定的參考價(jià)值,感興趣的可以了解一下2022-04-04