opencv python照片去背景,从图像opencv python中删除背景色

本文介绍了一种使用OpenCV和Python去除图片背景的方法。通过K-means颜色量化将图像分割成多个区域,然后进行二值化处理,找到并绘制最大的包含圆,最后通过位运算得到去除背景的结果。
摘要由CSDN通过智能技术生成

I have many images of specimen which have uncontrollable background color. Some of them have black background. Some of them have white background. Some of them have green background, etc.

I would like to remove these background color of a given image where the object in the image is just only one specimen. I try this code but it does not work as i expect.

def get_holes(image, thresh):

gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)

im_bw = cv2.threshold(gray, thresh, 255, cv2.THRESH_BINARY)[1]

im_bw_inv = cv2.bitwise_not(im_bw)

_, contour, _ = cv2.findContours(im_bw_inv, cv2.RETR_CCOMP, cv2.CHAIN_APPROX_SIMPLE)

for cnt in contour:

cv2.drawContours(im_bw_inv, [cnt], 0, 255, -1)

nt = cv2.bitwise_not(im_bw)

im_bw_inv = cv2.bitwise_or(im_bw_inv, nt)

return im_bw_inv

def remove_background(image, thresh, scale_factor=.25, kernel_range=range(1, 15), border=None):

border = border or kernel_range[-1]

holes = get_holes(image, thresh)

small = cv2.resize(holes, None, fx=scale_factor, fy=scale_factor)

bordered = cv2.copyMakeBorder(small, border, border, border, border, cv2.BORDER_CONSTANT)

for i in kernel_range:

kernel = cv2.getStructuringElement(cv2.MORPH_ELLIPSE, (2

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值