寻找直线--二值化,计算边缘,寻找直线

本文详细介绍了如何利用OpenCV库进行图像处理,通过二值化转换和边缘检测技术,有效地寻找图像中的直线。通过对图像进行预处理,然后应用Canny或Hough变换等算法,可以精确地识别并提取直线特征。
摘要由CSDN通过智能技术生成



int main()
{

	IplImage* src=cvLoadImage("C:\\Users\\Administrator\\Desktop\\OPenCV2官方练习\\images\\imageTextR.png",0);
	if(src!=0)
	{
		
		IplImage* dst=cvCreateImage(cvGetSize(src),8,1);
		IplImage* color_dst=cvCreateImage(cvGetSize(src),8,3);
		CvMemStorage* storage=cvCreateMemStorage(0);
		CvSeq* lines=0;
		int i=0;
		cvThreshold(src,src,120,255,CV_THRESH_BINARY);//二值化

		/*
		边缘检测---src,dst,小阈值,大阈值,算子内核大小
		小阈值:控制边缘链接
		大阈值:强边缘的初始分割
		*/
		cvCanny(src,dst,50,200,3);

		cvCvtColor(dst,color_dst,CV_GRAY2BGR);

#if 1	//直线穿过整个图形
		lines=cvHoughLines2(
			dst,
			storage,
			CV_HOUGH_STANDARD,
			1,
			CV_PI/180,
			150,
			0,
			0
			);

		for (int i = 0; i < MIN(lines->total,100); i++)
		{
			float* line=(float*)cvGetSeqElem(lines,i);
			float rho=line[0];
			float theta=line[1];//角度信息
			CvPoint pt1,pt2;
			double a&
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值