OpenCV3霍夫变换检测直线

霍夫变换-直线

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;
}

在这里插入图片描述

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

高万禄

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值