线检测二进制图像使用OpenCV的
答
使用图像直接作为输入,你将不得不颠倒它(白色=线检测)。
我会得到这些结果与HoughLinesP
,如果你扩张的倒影,一旦你得到这样的结果:
与此代码:
int main()
{
cv::Mat color = cv::imread("../inputData/LineDetectionCrosses.png");
cv::Mat gray;
// convert to grayscale
cv::cvtColor(color, gray, CV_BGR2GRAY);
cv::Mat mask = 255-gray;
//cv::dilate(mask, mask, cv::Mat());
// detect HoughLinesP
std::vector<cv::Vec4i> lines;
cv::HoughLinesP(mask, lines, 1, CV_PI/2880, 50, 300, 10);
for(size_t i = 0; i < lines.size(); i++)
{
cv::Vec4i l = lines[i];
cv::line(color, cv::Point(l[0], l[1]), cv::Point(l[2], l[3]), cv::Scalar(0,0,255), 3, CV_AA);
}
// display results
cv::imshow("mask",mask);
cv::imshow("output", color);
cv::waitKey(0);
}
但是如果它是我的项目,我可能会尝试首先检测这些圆圈,并找到/提取具有已知中心点的行!
您应该先找到轮廓。 – 2014-10-07 14:29:13