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

一.实现目标

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

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

二.实现流程

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

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

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

三.代码实现

import cv2
import numpy as np
import imutils
#定义形状检测函数
def ShapeDetection(img):
    contours,hierarchy = cv2.findContours(img,cv2.RETR_EXTERNAL,cv2.CHAIN_APPROX_NONE)  #寻找轮廓点
    for obj in contours:
        area = cv2.contourArea(obj)  #计算轮廓内区域的面积
        perimeter = cv2.arcLength(obj,True)  #计算轮廓周长
        approx = cv2.approxPolyDP(obj,0.02*perimeter,True)  #获取轮廓角点坐标
        # print(approx) 测试,打印角点坐标
        CornerNum = len(approx)   #轮廓角点的数量
        x, y, w, h = cv2.boundingRect(approx)  #获取坐标值和宽度、高度
        #print(x,y,w,h) 测试,打印坐标值 宽度 高度

        #轮廓对象分类 按识别出的轮廓角点坐标数量来分类
        if CornerNum ==3: 
            objType ="triangle"
            cv2.drawContours(imgContour, approx, -1, (255, 255, 0), 8)
        elif CornerNum ==2: 
             objType ="line"
             cv2.drawContours(imgContour, approx, -1, (255, 255, 0), 8)
        elif CornerNum == 4:
            if w==h: 
                objType= "Square"
                cv2.drawContours(imgContour, approx, -1, (255, 255, 0), 8)
            else:
                objType="Rectangle"
                cv2.drawContours(imgContour, approx, -1, (255, 255, 0), 8)
        else:objType="N"
        #绘制边界框
        cv2.rectangle(imgContour,(x-10,y-10),(x+w+12,y+h+12),(0,0,255))  
        #绘制文字
      cv2.putText(imgContour,objType,(x+(w//2),y+(h//2)),cv2.FONT_HERSHEY_COMPLEX,0.6,(0,0,0),1)  
        
        
path = 'jihe/tupian/line.jpg'
img = cv2.imread(path)
imgContour = img.copy()

imgGray = cv2.cvtColor(img,cv2.COLOR_RGB2GRAY)  #转灰度图
imgBlur = cv2.GaussianBlur(imgGray,(5,5),1)  #高斯模糊
imgCanny = cv2.Canny(imgBlur,60,60)  #Canny算子边缘检测
ShapeDetection(imgCanny)  #形状检测

cv2.imshow("Original img", img)
cv2.imshow("imgGray", imgGray)
cv2.imshow("imgBlur", imgBlur)
cv2.imshow("imgCanny", imgCanny)
cv2.imshow("shape Detection", imgContour)

cv2.waitKey(0)

四.运行及结果

1.直线

绘制图形如下:

识别标记结果如下:

 2.三角形

绘制图形如下:

识别标记结果如下:

3.矩形 

绘制图形如下:

识别标记结果如下:

  • 0
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
### 回答1: OpenCV是一个广泛使用的计算机视觉库,其中包括了许多图像处理和图像识别的常用算法。而指纹识别也是计算机视觉领域中的一项重要技术。 OpenCV中的指纹识别主要借助于一些预处理和特征提取算法。首先,需要将输入的指纹图像进行预处理,即去噪、二值化、细化等。这些操作可以去除基准点周围的噪声,并将指纹的纹理特征提取出来。 接着,利用OpenCV中的基于特征的匹配算法,可以对提取出的指纹纹理特征进行匹配。其中,最常用的方法是SIFT、SURF或ORB等算法。这些算法可以识别出指纹纹路的关键点,并将其转换成特征向量,进而用于指纹的比对和匹配。 实现OpenCV指纹识别代码的具体步骤如下: 1. 读入指纹图像; 2. 对指纹图像进行预处理,去噪、二值化、细化等; 3. 提取指纹纹理特征,使用SIFT、SURF或ORB算法进行关键点检测和特征向量提取; 4. 对输入的指纹图像进行同样的预处理和特征提取; 5. 利用特征匹配算法对两幅指纹图像进行匹配,找到特征向量之间的最佳匹配点; 6. 根据匹配结果,判定两幅指纹图像是否相似,即是否为同一个指纹。 总之,OpenCV指纹识别代码是通过利用预处理和基于特征的匹配算法,对输入的指纹图像进行特征提取和匹配,来实现指纹识别的过程。通过优化算法和特征提取步骤,可以提高指纹识别的准确度和可靠性。 ### 回答2: OpenCV指纹识别代码可以实现对人类指纹的图像处理、特征提取和匹配识别等功能,其核心部分基于图像处理算法和数学模型实现,具有较高的准确性和效率。常见的OpenCV指纹识别代码主要包括以下几个步骤: 1. 图像输入和预处理:读入指纹图像数据,并对其进行灰度化、降噪、图像增强等预处理操作,以便提高图像的质量和对比度,增强指纹特征。 2. 特征提取:利用特征提取算法,对指纹图像进行处理,提取图像中的关键特征,如指纹图案、点阵型纹、弧线型纹、三角形纹等等,同时对提取的特征进行量化和归一化处理,以便进行后续的匹配操作。 3. 特征匹配:基于特征模板匹配算法,对已提取的特征进行匹配,计算相似度并进行判断,以确定是否为同一人的指纹图像。匹配算法根据相似度阈值进行判定,若相似度超过阈值则认为匹配成功,否则匹配失败。 4. 最终输出和结果显示:对匹配结果进行处理和输出,以便后续判断和使用。同时,在界面上显示匹配结果,方便用户进行操作。 总的来说,OpenCV指纹识别代码是一种实现指纹识别功能的高效技术,可以广泛应用于安全检测、门禁系统、考勤管理、个人身份识别等一系列领域,具有重要的实际意义和应用价值。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值