国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

Python 利用OpenCV給照片換底色的示例代碼

瀏覽:52日期:2022-07-15 11:56:47

OpenCV的全稱是:Open Source Computer Vision Library。OpenCV是一個(gè)基于BSD許可(開(kāi)源)發(fā)行的跨平臺(tái)計(jì)算機(jī)視覺(jué)庫(kù),可以運(yùn)行在Linux、Windows和Mac OS操作系統(tǒng)上。它輕量級(jí)而且高效——由一系列 C 函數(shù)和少量 C++ 類構(gòu)成,同時(shí)提供了Python、Ruby、MATLAB等語(yǔ)言的接口,實(shí)現(xiàn)了圖像處理和計(jì)算機(jī)視覺(jué)方面的很多通用算法。相比于PIL庫(kù)來(lái)說(shuō)OpenCV更加強(qiáng)大, 可以做更多更復(fù)雜的應(yīng)用,比如人臉識(shí)別等。

1. 讀入并顯示圖片

import cv2# 讀入圖片img = cv2.imread(r’D:testtest_001.jpg’, 1)# 顯示圖像cv2.imshow(’img’, img)# 窗口等待命令 0表示無(wú)限等待cv2.waitKey(0)

運(yùn)行效果如下:

Python 利用OpenCV給照片換底色的示例代碼

2. 縮放圖片

import cv2# 讀入圖片img = cv2.imread(r’D:testtest_001.jpg’, 1)rows, cols, channels = img.shapeprint(rows, cols, channels)new_img = cv2.resize(img, None, fx=0.5, fy=0.5)rows, cols, channels = new_img.shapeprint(rows, cols, channels)# 顯示圖像cv2.imshow(’new_img’, new_img)# 窗口等待命令 0表示無(wú)限等待cv2.waitKey(0)

將圖片尺寸按比例縮小一半,運(yùn)行效果如下:

Python 利用OpenCV給照片換底色的示例代碼

3. 彩色圖像轉(zhuǎn)換為灰度圖像

彩色圖片有RGB三個(gè)顏色通道,無(wú)法進(jìn)行腐蝕和膨脹的操作。這個(gè)就需要我們將彩色圖片轉(zhuǎn)換為hsv灰度圖像后,再進(jìn)行腐蝕和膨脹的操作。

import cv2img = cv2.imread(r’D:testtest_001.jpg’, 1)new_img = cv2.resize(img, None, fx=0.5, fy=0.5)rows, cols, channels = new_img.shapeprint(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)行效果如下:

Python 利用OpenCV給照片換底色的示例代碼

4. 圖片二值化處理

二值化處理是為了將圖片轉(zhuǎn)換為黑白圖片,目的是濾除太大或太小值像素、消除噪聲,從而從灰度圖中獲取二值圖像(將圖像的灰度值設(shè)置為0或255),實(shí)現(xiàn)增強(qiáng)整個(gè)圖像呈現(xiàn)更為明顯的黑白效果,同時(shí)也大大減少了數(shù)據(jù)量。

import cv2import numpy as npimg = cv2.imread(r’D:testtest_001.jpg’, 1)new_img = cv2.resize(img, None, fx=0.5, fy=0.5)rows, cols, channels = new_img.shapeprint(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)行效果如下:

Python 利用OpenCV給照片換底色的示例代碼

5. 圖像的腐蝕和膨脹

圖像的膨脹(Dilation)和腐蝕(Erosion)是兩種基本的形態(tài)學(xué)運(yùn)算,主要用來(lái)尋找圖像中的極大區(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ì)腐蝕過(guò)的圖像,進(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 cv2import numpy as npimg = cv2.imread(r’D:testtest_001.jpg’, 1)new_img = cv2.resize(img, None, fx=0.5, fy=0.5)rows, cols, channels = new_img.shapeprint(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表示無(wú)限等待cv2.waitKey(0)cv2.destroyAllWindows()

運(yùn)行效果如下:

Python 利用OpenCV給照片換底色的示例代碼Python 利用OpenCV給照片換底色的示例代碼

程序運(yùn)行成功,可以將照片的藍(lán)底換為紅底或者白底,成功利用opencv實(shí)現(xiàn)給照片換底色。

7. 其他說(shuō)明

測(cè)試所用圖片來(lái)源于百度圖片搜索,圖片僅用于圖像處理知識(shí)交流和學(xué)習(xí),如有侵權(quán)請(qǐng)聯(lián)系我刪除!

到此這篇關(guān)于Python 利用OpenCV給照片換底色的示例代碼的文章就介紹到這了,更多相關(guān)python照片換底色內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 柯坪县| 田东县| 肇东市| 高要市| 英吉沙县| 滨州市| 响水县| 桂阳县| 武汉市| 门源| 新和县| 修武县| 石棉县| 恩施市| 太仆寺旗| 铜川市| 五华县| 招远市| 温宿县| 图木舒克市| 南安市| 水富县| 上林县| 水富县| 永兴县| 平乐县| 宁海县| 乌拉特中旗| 逊克县| 东乌| 将乐县| 马关县| 仙居县| 贵定县| 西充县| 太仓市| 东明县| 赣榆县| 安吉县| 宣城市| 晋中市|