二维码的检测识别

文章目录


代码:

#导入标准库os
import os
#导入numpy
import numpy as np
#导入matplotlib
from matplotlib import pyplot as plt
#导入OpenCV
import cv2 as cv


src = cv.imread('/home/jovyan/work/tt.png')
#绘制热图
plt.imshow(src)
#图片显示
plt.show()
gray = cv.cvtColor(src, cv.COLOR_BGR2GRAY)
qrcoder = cv.QRCodeDetector()
codeinfo, points, straight_qrcode = qrcoder.detectAndDecode(gray)
print(points)
print(points[0][0])
result = np.copy(src)
cv.putText(result,'%s'%codeinfo,tuple(points[2][0]),cv.FONT_HERSHEY_SIMPLEX, 0.8,(0, 0, 255))
cv.drawContours(result, [np.int32(points)], 0, (0, 0, 255), 2)
print("qrcode : %s"% codeinfo)
#绘制热图
plt.imshow(result)
#图片显示
plt.show()
code_roi = np.uint8(straight_qrcode)
#绘制热图
plt.imshow(code_roi)
#图片显示
plt.show()
cv.waitKey(0)
cv.destroyAllWindows()

在这里插入图片描述

[[[ 43.       43.     ]]

 [[406.       43.     ]]

 [[407.99347 407.99347]]

 [[ 43.      406.     ]]]
[43. 43.]
qrcode : https://github.com/JimmyHHua/opencv_tutorials/tree/master/python/code_114

在这里插入图片描述

在这里插入图片描述

解释

OpenCV3.4.4以上版本与OpenCV4.0版本支持该功能!

OpenCV在对象检测模块中QRCodeDetector有两个相关API分别实现二维码检测与二维码解析

二维码检测


retval, points  =   cv.QRCodeDetector.detect(   img[, points]   )

  • img输入图像,灰度或者彩色图像

  • points 得到的二维码四个点的坐标信息

解析二维码


retval, straight_qrcode =   cv.QRCodeDetector.decode(   img, points[, straight_qrcode]  )

  • img输入图像,灰度或者彩色图像

  • points 二维码ROI最小外接矩形顶点坐标

  • qrcode 输出的是二维码区域ROI图像信息,返回的二维码utf-8字符串

上述两个API功能,可以通过一个API调用实现,该API如下:


retval, points, straight_qrcode = cv.QRCodeDetector.detectAndDecode(img[, points[, straight_qrcode]])

总结

二维码检测识别是计算机视觉中的一个重要任务,目的是在图像或视频中检测、定位和解析出二维码信息。在实际应用中,可以使用诸如OpenCV、ZBar等开源工具库,通过图像处理、特征提取、分类器训练等方式来实现检测和识别。同时,还需要注意二维码的大小、颜色、歪斜度等问题,以提高识别的准确性和鲁棒性。最后,为了更好地应用二维码检测识别技术,还需要深入理解二维码的原理和应用场景,并结合实际业务需求进行优化和改进。

猜你喜欢

转载自blog.csdn.net/weixin_53573350/article/details/131072665