霍夫变换-直线
Hough Line Transform用来做直线检测
前提条件:边缘检测已经完成
平面空间到极坐标空间转换
相关API:
cv::HoughLinesP(
InputArray src.//输入图像,必须8-bit的灰度图像
OutputArray lines,//输出的极坐标来表示直线
double rho,//生成极坐标时候的像素扫描步长
double theta,//生成极坐标时候的角度步长,一般取值PI/180
int threshold,//阈值,只有获得足够交点的极坐标点才被看成是直线
double minLineLength=0,//最小直线长度,小于这个长度则不被认为是直线
double maxLineGap=0//最大间隔,直线中断超过这么长,则不被认为是一条直线,可能为两条哈哈
)
//OpenCV3霍夫变换-直线
#include<iostream>
#include<opencv2/opencv.hpp>
using namespace std;
using namespace cv;
int main(int argc, char** argv) {
const char* file = "a.jpg";
//读取图像
Mat img = imread(file);
//如果读取错误
if (img.empty()) {
cout << "img is null" << endl;
}
imshow("img", img);
//转换色彩空间
cvtColor(img, img, CV_BGR2GRAY);
imshow("gray", img);
//均值滤波-降噪声
blur(img, img, Size(3, 3), Point(-1, -1), BORDER_DEFAULT);
imshow("blur_img", img);
//Canny边缘检测
Canny(img, img, 50, 50 * 2, 3, false);
//50为边缘检测相关因素值
//50为低阈值
//50*2为高阈值
imshow("canny_img", img);
//霍夫变换-直线
vector<Vec4d>plines;//存放发现的点,每个元素有四个元素如[100,12,323,43]
HoughLinesP(img, plines, 1, CV_PI / 180.0, 10, 0, 0);
//把直线画上直线
Mat newimg = imread(file);
for (size_t i = 0; i < plines.size(); ++i) {
line(newimg,Point( plines[i][0], plines[i][1]),Point( plines[i][2], plines[i][3]), Scalar(255, 0, 0), 5, 8);
}
imshow("img_line", newimg);
waitKey(0);
return 0;
}