欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2020年08月03日 09:47:01   作者:葉庭云  
這篇文章主要介紹了Python 利用OpenCV給照片換底色,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

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

1. 讀入并顯示圖片

import cv2

# 讀入圖片
img = cv2.imread(r'D:\test\test_001.jpg', 1)

# 顯示圖像
cv2.imshow('img', img)

# 窗口等待命令 0表示無限等待
cv2.waitKey(0)

運行效果如下:

在這里插入圖片描述

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)

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

在這里插入圖片描述

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

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

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)

運行效果如下:

在這里插入圖片描述

4. 圖片二值化處理

二值化處理是為了將圖片轉(zhuǎn)換為黑白圖片,目的是濾除太大或太小值像素、消除噪聲,從而從灰度圖中獲取二值圖像(將圖像的灰度值設置為0或255),實現(xiàn)增強整個圖像呈現(xiàn)更為明顯的黑白效果,同時也大大減少了數(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)

運行效果如下:

在這里插入圖片描述

5. 圖像的腐蝕和膨脹

圖像的膨脹(Dilation)和腐蝕(Erosion)是兩種基本的形態(tài)學運算,主要用來尋找圖像中的極大區(qū)域和極小區(qū)域。其中膨脹類似于“領域擴張”,將圖像中的高亮區(qū)域或白色部分進行擴張,其運行結(jié)果圖比原圖的高亮區(qū)域更大;腐蝕類似于“領域被蠶食”,將圖像中的高亮區(qū)域或白色部分進行縮減細化,其運行結(jié)果圖比原圖的高亮區(qū)域更小。

  • 圖像被腐蝕后,去除了噪聲,但是會壓縮圖像。
  • 對腐蝕過的圖像,進行膨脹處理,可以去除噪聲,并且保持原有形狀。
# 腐蝕膨脹
erode = cv2.erode(binary_img, None, iterations=1)
dilate = cv2.dilate(erode, None, iterations=1)
cv2.imshow('dilate', dilate)

6. 遍歷像素點進行顏色替換

圖像是由每一個像素點組成的,找到腐蝕后得到圖片的白色底色處的像素點,然后將原圖中對應位置處的像素點,替換為紅色或者白色,即可實現(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()

運行效果如下:

在這里插入圖片描述
在這里插入圖片描述

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

7. 其他說明

測試所用圖片來源于百度圖片搜索,圖片僅用于圖像處理知識交流和學習,如有侵權(quán)請聯(lián)系我刪除!

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

相關(guān)文章

  • django實現(xiàn)用戶注冊實例講解

    django實現(xiàn)用戶注冊實例講解

    在本篇文章里小編給大家整理的是關(guān)于django用戶注冊的相關(guān)實例內(nèi)容,有興趣的朋友們學習下。
    2019-10-10
  • Python+Pygame實戰(zhàn)之炫舞小游戲的實現(xiàn)

    Python+Pygame實戰(zhàn)之炫舞小游戲的實現(xiàn)

    提到QQ炫舞,可能很多人想到的第一個詞是“青春”?;腥婚g,這個承載了無數(shù)人回憶與時光的游戲品牌,已經(jīng)走到了第十幾個年頭。今天小編就來給大家嘗試做一款簡單的簡陋版的小游戲——《舞動青春*炫舞》,感興趣的可以了解一下
    2022-12-12
  • pyqt5 實現(xiàn)工具欄文字圖片同時顯示

    pyqt5 實現(xiàn)工具欄文字圖片同時顯示

    今天小編就為大家分享一篇pyqt5 實現(xiàn)工具欄文字圖片同時顯示的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-06-06
  • Python裝飾器如何實現(xiàn)修復過程解析

    Python裝飾器如何實現(xiàn)修復過程解析

    這篇文章主要介紹了Python裝飾器如何實現(xiàn)修復過程解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-09-09
  • matlab、python中矩陣的互相導入導出方式

    matlab、python中矩陣的互相導入導出方式

    這篇文章主要介紹了matlab、python中矩陣的互相導入導出方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-06-06
  • numpy 數(shù)組拷貝地址所引起的同步替換問題

    numpy 數(shù)組拷貝地址所引起的同步替換問題

    本文主要介紹了numpy 數(shù)組拷貝地址所引起的同步替換問題,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-02-02
  • Python?ndarray?數(shù)組的變形詳情

    Python?ndarray?數(shù)組的變形詳情

    這篇文章主要介紹了Python?ndarray數(shù)組的變形詳情,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-09-09
  • 解決Python 寫文件報錯TypeError的問題

    解決Python 寫文件報錯TypeError的問題

    這篇文章主要介紹了解決Python 寫文件報錯TypeError的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-10-10
  • python SQLAlchemy的Mapping與Declarative詳解

    python SQLAlchemy的Mapping與Declarative詳解

    這篇文章主要介紹了python SQLAlchemy的Mapping與Declarative詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-07-07
  • matplotlib圖形整合之多個子圖繪制的實例代碼

    matplotlib圖形整合之多個子圖繪制的實例代碼

    matplotlib繪制多個子圖的時候,我們可以根據(jù)自己的想法去排列子圖的順序,也可以生成不同的子圖數(shù)量,本文就詳細的介紹了matplotlib 多子圖繪制,具有一定的參考價值,感興趣的可以了解一下
    2022-04-04

最新評論