【发布时间】:2017-04-23 06:04:56
【问题描述】:
我正在学习 OpenCV,我已经达到了无论我做什么都会卡住的地步。 我要做的是将对象(矩形对象)与其背景隔离开来。
我想屏蔽该图像,以便唯一剩下的就是对象。
我尝试了以下方法:
- 阈值
- 使用 Canny 检测边缘
- 查找轮廓
- 买大一点的
但是我得到了一些奇怪的区域作为更大的区域。以下是生成的图片:
这是我正在使用的代码:
#include "opencv2/imgproc/imgproc.hpp"
#include "opencv2/highgui/highgui.hpp"
#include <stdlib.h>
#include <stdio.h>
using namespace cv;
using namespace std;
int main( int, char** argv )
{
Mat src, srcGray,srcBlur,srcCanny;
string file = "samsung";
src = imread(file + ".jpg");
cvtColor(src, srcGray, CV_BGR2GRAY);
//bilateralFilter(srcGray, srcBlur,11, 17, 17);
srcBlur = srcGray.clone();
imshow("Filtered", srcBlur);
imwrite(file+"-filtered.jpg",srcBlur);
Canny(srcBlur, srcCanny, 0, 100, 3, true);
imshow("Canny", srcCanny);
imwrite(file+"-canny.jpg",srcCanny);
vector< vector <Point> > contours; // Vector for storing contour
vector< Vec4i > hierarchy;
findContours( srcCanny.clone(), contours, hierarchy,CV_RETR_TREE, CV_CHAIN_APPROX_SIMPLE ); // Find the contours in the image
int largest_contour_index=0;
int largest_area=0;
for( int i = 0; i< contours.size(); i++ ){
double a=contourArea( contours[i],false); // Find the area of contour
if(a>largest_area){
largest_area=a;
largest_contour_index=i; //Store the index of largest contour
}
}
Mat dst(src.rows,src.cols,CV_8UC1,Scalar::all(0)); //create destination image
drawContours( dst,contours, largest_contour_index, Scalar(255,0,0),CV_FILLED, 8, hierarchy );
imshow("Largest", dst);
imwrite(file+"-largest.jpg",dst);
waitKey();
}
这段代码旨在获取对象的“掩码”,然后应该应用掩码,但我无法继续前进,因为我无法检测到对象
我的目标是检测不同图像中的矩形对象(每张图像只有一个对象)。
这个想法来自here,但我无法让该代码与像我这样的对比度较低的图像一起使用。
我也尝试过this,这与我想要的几乎相同。
我想隔离一个矩形对象(应该是图像中较大的对象)
提前致谢!
PS:虽然我可以将 Python 翻译成 C++,但我希望能直接在 C++ 中得到答案,这样我可以更快地对其进行测试。
【问题讨论】:
-
你试过Hough transform吗?
-
你需要注意两点:1)没有图像处理方法可以猜测你想要哪个“对象”(例如,你是在电池还是标签?)所以必须有一些选择规则在那里,至少是隐含的。 2) 最先进的技术仍然没有为我们提供好的分割方法。
-
欢迎来到非平凡的计算机视觉。前景和背景都无法控制的情况(例如,通过固定相机、有限的目标对象、照明等)通常很难解决。如果您可以做出一些假设(例如目标对象是矩形),那么可能会有更好的机会。
-
@slawekwin 我对霍夫线不是很熟悉。也许你可以发布一个解决方案?。
-
关于对象将始终是一个矩形的假设,我们还不知道是哪一个,但想法是用这个矩形抓取一张图片,如果需要(倾斜)删除它的背景修复透视图和然后处理它。但你是对的,最大的问题是处理照明条件和任何类型的背景
标签: c++ opencv edge-detection object-detection canny-operator