利用opencv实现二维码检测(简单易上手)

前言 

二维码检测是一个简单易上手的小项目,掌握opencv基础的语句就可以实现。解析二维码的过程有专门的库来实现,所以只需调相应的库就好了。在实现这个代码前,先要配置opencv环境。

Python与Opencv配置安装_哔哩哔哩_bilibili 这里用anaconda配置很方便

相关代码

图像的简单处理

import cv2 #导入opencv
img=cv2.imread('path') #读取图片路径,path指图片相关路径
cv2.imshow('name', img) #显示图像(窗口命名,传入图像变量名)
cv2.waitKey(0) #窗口等待时间,以毫秒为单位。当传入参数为0时,图像将一直显示,直至关闭。
cv2.waitKey(1) == 27 #也可以通过按键绑定来执行窗口的退出,此处为esc键退出
cv2.destroyAllWindows() #把图像从内存中删除

视频的简单处理

cap = cv2.VideoCapture(0) #读取视频文件,0是打开默认摄像头(即笔记本自带的),1是第二个摄像头
While true: #读取视频的每一帧
    success, img = cap.read() #success表示有无成功读取的bool值,img是每一帧图像
    cv2.show(img) #在窗口显示这一帧

简单的绘图


start_point = (100, 100) #定义矩形的左上角和右下角坐标
end_point = (400, 400)
color = (0, 255, 0)  #定义矩形的颜色和线宽(B,G,R)
thickness = 2 #线宽
cv2.rectangle(img, start_point, end_point, color, thickness) #绘制矩形


center_coordinates = (256, 256) #定义圆心坐标和半径
radius = 100
color = (0, 255, 0) # 定义圆的颜色和线宽
thickness = 2
cv2.circle(img, center_coordinates, radius, color, thickness) #绘制圆

实现思路

摄像头帧画面的提取:调用while循环持续展示摄像头捕捉到的画面(如果不关闭显示窗口的话会一直执行while语句里的代码)

二维码位置提取和框定:利用point提取二维码位置,point 是一个包含四个元素的元组,表示矩形的左上角坐标和宽高。再利用cv2.rectangle 函数绘制矩形,其中 (point[0], point[1]) 是左上角坐标,(point[0]+point[2], point[1]+point[3]) 是右下角坐标

二维码解析和网页跳转(库实现):(在python的设置里下载pyzbar的软件包)调用pyzbar库的decode函数获取二维码信息,调用webbrowser跳转网页(这个库是py自带的,直接调)

二维码信息展示创建data列表存入解析出来的网址

要注意的问题和解决方法

正常来说摄像头在捕捉到二维码并进行解析后,会展示解析出来的地址并跳转到相应的网页。

而此时如果不关闭显示窗口的话,二维码就会持续被摄像头捕捉,代码就会一直去执行刚刚的操作,也就是会不断新增同一个网页和重复显示已经出现的地址。

简单来说就是要对代码进行优化,让他不要进行重复的操作,即有几个二维码就生成几个信息。

所以我们要设置一个计数器,用来计算data列表中存入了几个信息。还要设置一个状态值flag,我们可以理解为bool值,用来判定该二维码是否已经被解析过。1表示未被解析过,要执行解析操作,0表示已被解析,跳过该过程。

当时用了近一个小时才解决掉了这个问题。。。。。。

结尾

这只是opencv很基础的一部分。还有更多的知识和理论等着我们去学习。我也是计算机视觉领域的初学者(大一新牲),纯纯小白一个。也是第一次写技术文档,浅浅分享我的心得,希望对大家有所帮助。

最终代码展示

import cv2
import webbrowser #用于网页跳转
from pyzbar.pyzbar import decode #导入pyzbar库,该库是一个用于解析条形码和二维码的Python库
cap = cv2.VideoCapture(0) #调用摄像头
data = ['Code'] #存放在二维码识别到的地址
a = 0 #记录data列表中解析二维码的地址个数
flag = 1 #flag为bool值,为1的时候表示data列表中没有该二维码地址,则执行添加操作。

while True: #让摄像头画面一帧一帧显示
    success , img = cap.read()  #img是一帧的信息,success是一个bool值,表示是否成功读取到这一帧
    codes = decode(img) #使用pyzbar解码图像中的条形码或二维码

    for code in codes: #遍历解码结果
        code_data = code.data.decode('utf-8') #提取解码的数据
        for i in range(a+1): #遍历data列表查看识别到的二维码地址是否已存在
            if (code_data == data[i]): #如果存在则flag=0,不执行插入操作
                flag = 0

        if flag == 1: #将新的地址插入到data列表
            data.append(code_data)
            webbrowser.open(code_data)
            print(data)
            a += 1 #计数
        flag = 1   #刷新flag的值
        point = code.rect  # 提取条形码或二维码的位置信息
        cv2.rectangle(img,(point[0],point[1]),(point[0]+point[2],point[1]+point[3]),(0,255,0),5)  #框定二维码区域
    cv2.namedWindow('Code', cv2.WINDOW_NORMAL)    #创建窗口
    cv2.imshow("Code",img)      #展示窗口
    if cv2.waitKey(1) == 27:    #esc退出
        break


猜你喜欢

转载自blog.csdn.net/Radein/article/details/134492081