视频/图像中的条形码/二维码识别

视频/图像中的条形码/二维码识别

图像识别

在这里插入图片描述

视频识别

在这里插入图片描述
在这里插入图片描述

# 二维码识别
import cv2
import numpy as np
from pyzbar.pyzbar import decode
 
# 读取文件
def Read():
    global Data_Array
    Data_Array = open('Existing.txt').read().splitlines() #按行分隔,已授权数据存放处
    print('已授权的数据:',Data_Array,'\n')
 
 
# 判断二维码是否授权
def Judge(data):
    global color
    if data in Data_Array:      #已授权
        color = (0, 255, 0)     #绿色标记
        print('Authorized\n')
    else:                       #未授权
        color = (0, 0, 255)     #红色标记
        print('Unauthorized\n')
 
 
# 检测图像中的码(解码)
def Read_Decode_Pic(image):
    # 遍历解码
    for code in decode(image):
        # print("条形码/二维码:", code)
        data = code.data.decode('utf-8')
        print("条形码/二维码数据:", data)    #解码数据
 
        # 判断二维码是否授权
        Judge(data)
 
        # 多边形获取(矩形的框)
        pts_poly= np.array(code.polygon, np.int32)          #获取多边形坐标
        cv2.polylines(image, [pts_poly], True, color, 5)    #画多边形框
 
        # 显示数据(获取矩形框的左上角作为Text的坐标(左边坐标),显示数据)
        pts_rect = code.rect
        # print(pts_rect)
        cv2.putText(image, data, (pts_rect[0],pts_rect[1]), cv2.FONT_HERSHEY_SIMPLEX, 0.7, color, 2)
        #                  显示数据  矩形坐标                   字体类型                 字体大小 颜色     粗细
 
    cv2.imshow('image', image)      #等画出所有矩形后显示
 
 
# 检测视频中的码(解码)
def Read_Decode_Cam():
    cap = cv2.VideoCapture(0)           #打开视频
    cap.set(3, 1000)                    #帧的宽度
    cap.set(4, 800)                     #帧的高度
 
    while True:
        success, image = cap.read()     #获取每一帧图片
        cv2.imshow('image', image)
 
        image = Read_Decode_Pic(image)  #对每一帧图片检测
 
        cv2.waitKey(1)                  #延时1ms
 
 
if __name__ == '__main__':
    Read()                          #读取文件
    img = cv2.imread('0.jpg')
    Read_Decode_Pic(img)           # 检测图像中的码(解码)
    Read_Decode_Cam()              # 检测视频中的码(解码)
 
    cv2.waitKey(0)



  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
OpenCV+zbar开源库实现摄像头识别二维码,测试验证识别率非常高,已实现简单的应用。 打包源码在VS2013下可以完全编译成功,附加包含OpenCV库及zbar-0.10-setup.exe,zbar-0.10.tar.bz2 下载Demo后需要安装 zbar-0.10-setup.exe 以下代码可以可以完成整个流程的开发,也可以贡献积分下载资源包。 1、 环境准备 (1) OpenCV库2.49 (2) ZBar开源库 (3) VS2013 2、 VS2013环境配置 (1) 配置附加包含目录 C/C++ -- 附加包含目录 include\opencv\include\ include\opencv\include\opencv include\opencv\include\opencv2 include (2) 配置链接器 链接器 -- 附加库目录 lib32\opencv\lib lib32 (3) 配置链接器 链接器--输入--附加依赖项 opencv_core249d.lib opencv_highgui249d.lib opencv_imgproc249d.lib libzbar-0.lib 3、 代码开发 (1)包含头文件 include include include include include include using namespace std; using namespace zbar; using namespace cv; (2)实现函数 void MatToCImage(cv::Mat &mat, CImage &cImage) { //create new CImage int width = mat.cols; int height = mat.rows; int channels = mat.channels(); cImage.Destroy(); //clear cImage.Create(width, height, 8 * channels); //默认图像像素单通道占用1个字节 //copy values uchar* ps; uchar* pimg = (uchar*)cImage.GetBits(); //A pointer to the bitmap buffer int step = cImage.GetPitch(); for (int i = 0; i (i)); for (int j = 0; j GetDlgItem(IDC_STATIC_IMG)->GetClientRect(▭); cv::VideoCapture capture(0);//从摄像头读入图像 while (!m_bCloseCamera) { cv::Mat frame; capture >> frame; cv::Mat newframe; cv::Size ResImgSiz = cv::Size(rect.Width(), rect.Height()); cv::resize(frame, newframe, ResImgSiz, CV_INTER_CUBIC); MatToCImage(newframe, imgDst); imgDst.Draw(pThis->GetDlgItem(IDC_STATIC_IMG)->GetDC()->GetSafeHdc(), rect); ImageScanner scanner; scanner.set_config(ZBAR_NONE, ZBAR_CFG_ENABLE, 1); Mat imageGray; cvtColor(frame, imageGray, CV_RGB2GRAY); int width = imageGray.cols; int height = imageGray.rows; uchar *raw = (uchar *)imageGray.data; Image imageZbar(width, height, "Y800", raw, width * height); scanner.scan(imageZbar); //扫描条码 Image::SymbolIterator symbol = imageZbar.symbol_begin(); if (imageZbar.symbol_begin() == imageZbar.symbol_end()) { } else { iIndex++; if (iIndex > 999999) { iIndex = 0; } for (; symbol != imageZbar.symbol_end(); ++symbol) { char szInfo[1024]; memset(szInfo, 0, sizeof(szInfo)); sprintf(szInfo, "[d]类型:%s\r\n条码:%s\r\n", iIndex , symbol->get_type_name().c_str(), symbol->get_data().c_str()); pThis->GetDlgItem(IDC_EDIT1)->SetWindowText(szInfo); } } imageZbar.set_data(NULL, 0); } imgDst.Destroy(); capture.release(); return 0; }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值