opencv grabCut前景后景分割去除背景

参考:

https://zhuanlan.zhihu.com/p/523954762

https://docs.opencv.org/3.4/d8/d83/tutorial_py_grabcut.html

环境本次:

python 3.10

提取前景:

1、需要先把前景物体框出来

需要坐标信息,可以用windows自带的画图简单提取像素

矩形的格式为 (x, y, width, height)

rect = (118, 120, 732, 835)

定义了一个矩形区域,该区域用于初始化 GrabCut 算法。这个矩形区域的参数表示:

118:矩形左上角的 x 坐标。

120:矩形左上角的 y 坐标。

732:矩形的宽度。

835:矩形的高度。

因此,这个矩形从图像的坐标 (118, 120) 开始,宽度为 732 像素,高度为 835 像素。

2、完整代码

bash 复制代码
import cv2
import numpy as np
import matplotlib.pyplot as plt

# 读取图像
image = cv2.imread(r"C:\Users***\long.png")

# 创建一个与图像大小相同的掩码
mask = np.zeros(image.shape[:2], np.uint8)

# 创建两个数组,用于存储算法内部使用的临时数组
bgdModel = np.zeros((1, 65), np.float64)
fgdModel = np.zeros((1, 65), np.float64)

# 定义一个矩形区域,该区域包含我们想要分割的前景物体
# 矩形的格式为 (x, y, width, height)
rect = (118, 120, 732, 835)

# 应用 GrabCut 算法
cv2.grabCut(image, mask, rect, bgdModel, fgdModel, 5, cv2.GC_INIT_WITH_RECT)

# 创建一个新的掩码,将可能的前景和确定的前景合并
mask2 = np.where((mask == 2) | (mask == 0), 0, 1).astype('uint8')

# 将掩码应用于图像
result = image * mask2[:, :, np.newaxis]

# 显示原始图像和分割结果
plt.subplot(121), plt.imshow(cv2.cvtColor(image, cv2.COLOR_BGR2RGB))
plt.title('Original Image'), plt.xticks([]), plt.yticks([])
plt.subplot(122), plt.imshow(cv2.cvtColor(result, cv2.COLOR_BGR2RGB))
plt.title('Segmented Image'), plt.xticks([]), plt.yticks([])
plt.show()
相关推荐
共绩算力3 分钟前
更小模型实现更强视觉 OCR
人工智能·ocr·共绩算力
胡乱编胡乱赢6 分钟前
关于联邦学习中的Decaf攻击基础知识
人工智能·深度学习·机器学习
五度易链-区域产业数字化管理平台10 分钟前
如何构建高质量产业数据信息库?五度易链的“八大核心库”与数据治理实践
大数据·人工智能
优宁维生物13 分钟前
DNA 提取的基础方法
人工智能·算法
Elastic 中国社区官方博客19 分钟前
用 Elasticsearch 构建一个 ChatGPT connector 来查询 GitHub issues
大数据·人工智能·elasticsearch·搜索引擎·chatgpt·github·全文检索
奔跑的石头_36 分钟前
如何用AI创建一个适合你的编程社区用户名
人工智能
yuhaiqun198937 分钟前
10分钟快速get:零基础AI人工智能学习路线
人工智能·学习
m0_6501082439 分钟前
Co-MTP:面向自动驾驶的多时间融合协同轨迹预测框架
论文阅读·人工智能·自动驾驶·双时间域融合·突破单车感知局限·帧间轨迹预测·异构图transformer
向阳逐梦40 分钟前
电子烟的4种屏幕驱动集成语音方案介绍
人工智能·语音识别
蓝耘智算41 分钟前
蓝耘元生代GPU算力调度云平台深度解析:高性价比算力云与GPU算力租赁首选方案
人工智能·ai·gpu算力·蓝耘