当前位置:   article > 正文

简单几何图形的识别与标记(opencv)_图形识别

图形识别

一.实现目标

手绘简单几何图形,拍照后处理可识别并标记图形相应关键点。

  1. 直线:识别并标记始末点
  2. 三角形:识别并标记三个角点
  3. 矩形:识别并标记四个角点

二.实现流程

通过Python与OpenCV进行编程,采用了获取图形角点数量的方式来识别图形,两个点为直线,三个点为三角形,四个点为矩形。

对于形状的识别与点的标记,编写了ShapeDetection函数进行处理,通过OpenCV的相关函数,首先使用cv2.findContours寻找图形轮廓点,接着通过cv2.approxPolyDP函数获取轮廓角点坐标,并对其数目进行统计,以此来判断图形形状,若识别为直线、三角形或矩形,则在获取的角点坐标位置上用蓝色圆点进行标记,完成对不同图形相应点的标记。

具体过程为:先使用 cv2.cvtColor函数将需要识别的图片转为灰度图,再使用cv2.GaussianBlur函数对其进行高斯模糊处理,接着使用cv2.Canny函数进行边缘检测,最后将输出的图片传入ShapeDetection函数进行识别与标记。

三.代码实现

  1. import cv2
  2. import numpy as np
  3. import imutils
  4. #定义形状检测函数
  5. def ShapeDetection(img):
  6. contours,hierarchy = cv2.findContours(img,cv2.RETR_EXTERNAL,cv2.CHAIN_APPROX_NONE) #寻找轮廓点
  7. for obj in contours:
  8. area = cv2.contourArea(obj) #计算轮廓内区域的面积
  9. perimeter = cv2.arcLength(obj,True) #计算轮廓周长
  10. approx = cv2.approxPolyDP(obj,0.02*perimeter,True) #获取轮廓角点坐标
  11. # print(approx) 测试,打印角点坐标
  12. CornerNum = len(approx) #轮廓角点的数量
  13. x, y, w, h = cv2.boundingRect(approx) #获取坐标值和宽度、高度
  14. #print(x,y,w,h) 测试,打印坐标值 宽度 高度
  15. #轮廓对象分类 按识别出的轮廓角点坐标数量来分类
  16. if CornerNum ==3:
  17. objType ="triangle"
  18. cv2.drawContours(imgContour, approx, -1, (255, 255, 0), 8)
  19. elif CornerNum ==2:
  20. objType ="line"
  21. cv2.drawContours(imgContour, approx, -1, (255, 255, 0), 8)
  22. elif CornerNum == 4:
  23. if w==h:
  24. objType= "Square"
  25. cv2.drawContours(imgContour, approx, -1, (255, 255, 0), 8)
  26. else:
  27. objType="Rectangle"
  28. cv2.drawContours(imgContour, approx, -1, (255, 255, 0), 8)
  29. else:objType="N"
  30. #绘制边界框
  31. cv2.rectangle(imgContour,(x-10,y-10),(x+w+12,y+h+12),(0,0,255))
  32. #绘制文字
  33. cv2.putText(imgContour,objType,(x+(w//2),y+(h//2)),cv2.FONT_HERSHEY_COMPLEX,0.6,(0,0,0),1)
  34. path = 'jihe/tupian/line.jpg'
  35. img = cv2.imread(path)
  36. imgContour = img.copy()
  37. imgGray = cv2.cvtColor(img,cv2.COLOR_RGB2GRAY) #转灰度图
  38. imgBlur = cv2.GaussianBlur(imgGray,(5,5),1) #高斯模糊
  39. imgCanny = cv2.Canny(imgBlur,60,60) #Canny算子边缘检测
  40. ShapeDetection(imgCanny) #形状检测
  41. cv2.imshow("Original img", img)
  42. cv2.imshow("imgGray", imgGray)
  43. cv2.imshow("imgBlur", imgBlur)
  44. cv2.imshow("imgCanny", imgCanny)
  45. cv2.imshow("shape Detection", imgContour)
  46. cv2.waitKey(0)

四.运行及结果

1.直线

绘制图形如下:

识别标记结果如下:

 2.三角形

绘制图形如下:

识别标记结果如下:

3.矩形 

绘制图形如下:

识别标记结果如下:

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/weixin_40725706/article/detail/264025
推荐阅读
相关标签
  

闽ICP备14008679号