主頁 > 知識庫 > python opencv 找出圖像中的最大輪廓并填充(生成mask)

python opencv 找出圖像中的最大輪廓并填充(生成mask)

熱門標(biāo)簽:電銷機(jī)器人 金倫通信 鄭州智能外呼系統(tǒng)中心 賓館能在百度地圖標(biāo)注嗎 北京外呼電銷機(jī)器人招商 crm電銷機(jī)器人 南京crm外呼系統(tǒng)排名 400電話 申請 條件 云南地圖標(biāo)注 汕頭電商外呼系統(tǒng)供應(yīng)商

本文主要介紹了python opencv 找出圖像中的最大輪廓并填充,分享給大家,具體如下:

import cv2
import numpy as np
from PIL import Image
 
from joblib import Parallel
from joblib import delayed
# Parallel 和 delayed是為了使用多線程處理
# 使用前需要安裝joblib:pip install joblib
 
# img_stack的shape為:num, h, w
# 是三維的圖像,可以理解為是num張二維的圖像組成
# mask是用來保存最后的結(jié)果的
mask = np.ones_like(img_stack)
for i in range(num):
  # 閾值化
  _, binaryzation = cv2.threshold(img_stack[i], 5, 255, cv2.THRESH_BINARY_INV)
  # 找到所有的輪廓
  contours, _ = cv2.findContours(binaryzation, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_NONE)
  area = []
  # 找到最大的輪廓
  for k in range(len(contours)):
    area.append(cv2.contourArea(contours[k]))
  max_idx = np.argmax(np.array(area))
  # cv2.fillContexPoly(mask[i], contours[max_idx], 0)
  # 填充最大的輪廓
  cv2.drawContours(mask[i], contours, max_idx, 0, cv2.FILLED)
  del area 
 
 
# 保存
def _write_mask(mask, i):
  Image.fromarray(mask.astype(np.uint8)*255).save(os.path.join(path, 'm%d.png' % i))
 
# 使用多線程進(jìn)行保存
num_cores = 10
parallel = Parallel(n_jobs=num_cores, backend='threading')
parallel(delayed(_write_mask)(mask[i, :, :], i) for i in range(0, num))

之前偷懶直接將項目里面的代碼段扣下來放在這里,誤導(dǎo)了大家,抱歉

這次我重新放一個完整版本,希望對大家有所幫助~~

代碼在python 3.7.6 和opencv-python 4.3.0下測試成功

import cv2
import numpy as np
 
# 以灰度方式讀取圖像
img = cv2.imread('img.png', cv2.IMREAD_GRAYSCALE)
mask = img.copy()
 
# 二值化,100為閾值,小于100的變?yōu)?55,大于100的變?yōu)?
# 也可以根據(jù)自己的要求,改變參數(shù):
# cv2.THRESH_BINARY
# cv2.THRESH_BINARY_INV
# cv2.THRESH_TRUNC
# cv2.THRESH_TOZERO_INV
# cv2.THRESH_TOZERO
_, binaryzation = cv2.threshold(img, 100, 255, cv2.THRESH_BINARY_INV)
 
# 找到所有的輪廓
contours, _ = cv2.findContours(binaryzation, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_NONE)
 
area = []
 
# 找到最大的輪廓
for k in range(len(contours)):
	area.append(cv2.contourArea(contours[k]))
max_idx = np.argmax(np.array(area))
 
# 填充最大的輪廓
mask = cv2.drawContours(mask, contours, max_idx, 0, cv2.FILLED)
 
# 保存填充后的圖像
cv2.imwrite('masked.png', mask)

輸入圖像:

輸出圖像:

到此這篇關(guān)于python opencv 找出圖像中的最大輪廓并填充(生成mask)的文章就介紹到這了,更多相關(guān)opencv最大輪廓內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Python-OpenCV實現(xiàn)圖像缺陷檢測的實例
  • OpenCV-Python實現(xiàn)圖像平滑處理操作
  • OpenCV-Python直方圖均衡化實現(xiàn)圖像去霧
  • Python OpenCV 圖像平移的實現(xiàn)示例
  • python基于opencv 實現(xiàn)圖像時鐘
  • Python-OpenCV教程之圖像的位運算詳解

標(biāo)簽:昆明 懷化 石家莊 西寧 梅州 浙江 錫林郭勒盟 文山

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《python opencv 找出圖像中的最大輪廓并填充(生成mask)》,本文關(guān)鍵詞  python,opencv,找出,圖像,中的,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《python opencv 找出圖像中的最大輪廓并填充(生成mask)》相關(guān)的同類信息!
  • 本頁收集關(guān)于python opencv 找出圖像中的最大輪廓并填充(生成mask)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章