OpenCV处理-边缘检测和裁剪

问题描述 投票:1回答:1

如何从预处理的图像中删除不规则的白色像素。

我尝试进行腐蚀,这会使所有像素变黑。

预处理后:

enter image description here

要求:

enter image description here

我的代码:

Mat  img, edges, erode, blurred, element;
element = getStructuringElement(cv::MORPH_RECT, cv::Size(7, 7), cv::Point(-1,-1) ); 

img = imread("img1925.jpeg");    //  read the image
cv::Canny(img, edges, 30, 255, 3);    // detect the edges with threshold limit

//    cv::erode(edges, erode, element);

GaussianBlur(edges, blurred, cv::Size(7, 7), 0);    // blurring

//    Rect ROI = boundingRect(blurred);       // draw rect for ROI
//    Mat src = thresh(ROI);

namedWindow("image", WINDOW_NORMAL);
imshow("image", blurred);
waitKey(0);
return 0;

正在寻找建议!

c++ opencv crop edge-detection image-preprocessing
1个回答
2
投票

我不确定从预处理图像中删除不规则的白色像素是什么意思,但是如果您的目标是提取对象的ROI,则可以采用以下方法:

  • 将图像转换为灰度,将高斯模糊转换为平滑图像
  • 获得二进制图像的自适应阈值
  • 使用轮廓区域查找轮廓并进行过滤
  • 提取图像中最大的轮廓并裁剪ROI

这是结果

enter image description here

如果在阈值图像上裁剪了ROI,则结果为

enter image description here

我在Python中实现了它,但是您可以在C ++中遵循相同的步骤

import cv2

image = cv2.imread('1.jpg')
gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)
blur = cv2.GaussianBlur(gray, (7,7), 0)
thresh = cv2.adaptiveThreshold(blur,255,cv2.ADAPTIVE_THRESH_GAUSSIAN_C, cv2.THRESH_BINARY_INV,11,3)

cnts = cv2.findContours(thresh, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)
cnts = cnts[0] if len(cnts) == 2 else cnts[1]
cnts = sorted(cnts, key=cv2.contourArea, reverse=True)
for c in cnts:
    x,y,w,h = cv2.boundingRect(c)
    ROI = image[y:y+h, x:x+w]
    break

cv2.imwrite('ROI.png', ROI)
cv2.waitKey()
© www.soinside.com 2019 - 2024. All rights reserved.