文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

C++OpenCV实战之形状识别

2024-04-02 19:55

关注

前言

本案例通过使用OpenCV中的approxPolyDP进行多边形近似,进而进行基础形状识别(圆、三角形、矩形、星形…)。下面就一起来看看具体是如何实现的吧。

一、图像预处理

原图如图所示:

首先第一步先进行图像预处理,得到二值图像。

	Mat gray;
	cvtColor(src, gray, COLOR_BGR2GRAY);

	Mat gaussian;
	GaussianBlur(gray, gaussian, Size(3, 3), 0);

	Mat thresh;
	threshold(gaussian, thresh, 0, 255, THRESH_BINARY_INV | THRESH_OTSU);

结果如图所示。接下来,需要对此二值图像进行轮廓提取,进而识别物体形状。

二、形状识别

本案例使用approxPolyDP进行形状识别,关于approxPolyDP OpenCV给出的定义是:

void approxPolyDP(InputArray curve, OutputArray approxCurve, double epsilon, bool closed);

我们通过统计多边形的“边”数来识别物体形状。

三、源码

#include<iostream>
#include<opencv2/opencv.hpp>
using namespace std;
using namespace cv;

//基础几何形状识别
bool Pattern_Recognition(Mat& src)
{
	//图像预处理
	Mat gray;
	cvtColor(src, gray, COLOR_BGR2GRAY);

	Mat gaussian;
	GaussianBlur(gray, gaussian, Size(3, 3), 0);

	Mat thresh;
	threshold(gaussian, thresh, 0, 255, THRESH_BINARY_INV | THRESH_OTSU);

	//轮廓查找
	vector<vector<Point>>contours;//轮廓点集
	findContours(thresh, contours, RETR_EXTERNAL, CHAIN_APPROX_SIMPLE);
	vector<vector<Point>>conPoly(contours.size());//多边形逼近结果,与轮廓一一对应

	for (int i = 0; i < contours.size(); i++)
	{
		double area = contourArea(contours[i]); //轮廓面积

		if (area > 1000)
		{
			Rect rect = boundingRect(contours[i]);//外界矩形

			double ratio = double(rect.width) / double(rect.height);//长宽比

			double peri = arcLength(contours[i], true);//周长

			approxPolyDP(contours[i], conPoly[i], 0.02 * peri, true);//多边形近似

			int objSize = conPoly[i].size();//折线数--通过判断轮廓有几条边来识别图形

			string objName;
			Scalar color;
			if (objSize == 3)
			{
				objName = "Triangle";//三角形
				color = Scalar(0, 0, 255);
			}
			if (objSize == 4)
			{
				//通过长宽比判断正方形/长方形
				if (ratio > 0.99 && ratio < 1.01)
				{
					objName = "Square";//正方形
					color = Scalar(0, 255, 255);
				}
				else
				{
					objName = "Rectangle";//长方形
					color = Scalar(0, 255, 0);
				}
			}
			if (objSize == 8)
			{
				objName = "Circle";//圆形
				color = Scalar(255, 255, 0);
			}
			if (objSize == 10)
			{
				objName = "Star";//星形
				color = Scalar(255, 0, 255);
			}

			//效果绘制
			rectangle(src, rect, color, 2);
			putText(src, objName, rect.tl(), FONT_HERSHEY_SIMPLEX, 1, color, 2);
		}
	}

	return true;
}

int main()
{
	Mat src = imread("src.jpeg");
	if (src.empty())
	{
		cout << "No Image!" << endl;
		system("pause");
		return -1;
	}
	
	if (!Pattern_Recognition(src))return false;

	namedWindow("test", WINDOW_NORMAL);
	imshow("test", src);
	waitKey(0);
	system("pause");
	return 0;
}

四、结果显示

总结

本文使用OpenCV C++ 进行基础形状识别,其实原理很简单,主要操作有以下几点。

1、图像预处理

2、物体轮廓提取

3、使用approxPolyDP进行多边形近似,进而统计出该物体的“边”数,从而识别出物体形状。

到此这篇关于C++ OpenCV实战之形状识别的文章就介绍到这了,更多相关C++ OpenCV形状识别内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯