二维码PDF417简介及其解码实现(zxing-cpp)

二维码PDF417是一种堆叠式二维条码。PDF417条码是由美国SYMBOL公司发明的,PDF(Portable Data File)意思是“便携数据文件”。组成条码的每一个条码字符由4个条和4个空共17个模块构成,故称为PDF417条码。 PDF417条码需要有417解码功能的条码阅读器才能识别。PDF417条码最大的优势在于其庞大的数据容量和极强的纠错能力。

PDF417条码是一种高密度、高信息含量的便携式数据文件,是实现证件及卡片等大容量、高可靠性信息自动存储、携带并可用机器自动识读的理想手段。

PDF417条码可表示数字、字母或二进制数据,也可表示汉字。一个PDF417条码最多可容纳1850 个字符或1108 个字节的二进制数据,如果只表示数字则可容纳2710 个数字。PDF417的纠错能力分为9级,级别越高,纠正能力越强。由于这种纠错功能,使得污损的PDF417条码也可以正确读出。我国已制定了PDF417码的国家标准。

二维码PDF417可应用在:证件管理、执照年检、报表管理、机电产品的生产和组配线、银行票据管理及行包、货物的运输和邮递。

以下是通过zxing-cpp开源库实现的对二维码PDF417进行解码的测试代码:

#include "funset.hpp"
#include <string>
#include <fstream>
#include <Windows.h>

#include <zxing/LuminanceSource.h>
#include <zxing/common/Counted.h>
#include <zxing/Reader.h>
#include <zxing/aztec/AztecReader.h>
#include <zxing/common/GlobalHistogramBinarizer.h>
#include <zxing/DecodeHints.h>
#include <zxing/datamatrix/DataMatrixReader.h>
#include <zxing/MultiFormatReader.h>
#include <zxing/pdf417/PDF417Reader.h>

#include <opencv2/opencv.hpp>

#include "zxing/MatSource.h"

int test_PDF417_decode()
{
	std::string image_name = "E:/GitCode/BarCode_Test/test_images/PDF417.png";
	cv::Mat matSrc = cv::imread(image_name, 1);
	if (!matSrc.data) {
		fprintf(stderr, "read image error: %s", image_name.c_str());
		return -1;
	}

	cv::Mat matGray;
	cv::cvtColor(matSrc, matGray, CV_BGR2GRAY);

	zxing::Ref<zxing::LuminanceSource> source = MatSource::create(matGray);
	int width = source->getWidth();
	int height = source->getHeight();
	fprintf(stderr, "image width: %d, height: %d\n", width, height);

	zxing::Ref<zxing::Reader> reader;
	reader.reset(new zxing::pdf417::PDF417Reader);

	zxing::Ref<zxing::Binarizer> binarizer(new zxing::GlobalHistogramBinarizer(source));
	zxing::Ref<zxing::BinaryBitmap> bitmap(new zxing::BinaryBitmap(binarizer));
	zxing::Ref<zxing::Result> result(reader->decode(bitmap, zxing::DecodeHints(zxing::DecodeHints::PDF_417_HINT)));

	std::string txt = "E:/GitCode/BarCode_Test/test_images/PDF417.txt";
	std::ifstream in(txt);
	if (!in.is_open()) {
		fprintf(stderr, "fail to open file: %s\n", txt.c_str());
		return -1;
	}

	std::string str1;
	std::getline(in, str1);
	fprintf(stderr, "actual        result: %s\n", str1.c_str());
	std::string str2 = result->getText()->getText();
	fprintf(stdout, "recognization result: %s\n", str2.c_str());

	if (str1.compare(str2) == 0) {
		fprintf(stderr, "=====  recognition is correct  =====\n");
	}
	else {
		fprintf(stderr, "=====  recognition is wrong =====\n");
		return -1;
	}

	in.close();

	return 0;
}
测试图像如下:

测试结果如下:

GitHubhttps://github.com/fengbingchun/Barcode_Test

1、本软件为演示软件,在性能和功能上有所限制; 2、参数说明: 条码列数 取值范围1-30,根据具体要生成条码的数据量决定; 例如20 byte左右数据量,取值范围可设3-5; 纠错等级 条码污损后的纠错能力,取值范围0-7,建议取1-3; 长宽比例 条码单位长度和宽度比例,取值范围1-5; 1----紧凑型条码,生成条码图片容量最小,适合配合数据库管理系统使用, 便于直接以最小的容量存储在数据库中,而且生成速度最快,适合大 批量生成条码。但需要通过报表控件做纵横向适当拉伸后,打印出来 才可识读,不能直接打印识读或软解码; 2--5 标准型条码,适合直接打印识读或软件解码,建议取3。 以上参数的设置将直接影响条码的可读性和条码图片的大小。 3、在文本框中输入要生成条码的信息,输入欲保存图片的名称,按“生成”即在当前目录下产生指定的bmp图片; 默认路径为执行文件同目录,默认文件名为bar.bmp; 4、若要打印,可用windows提供的“画图”工具打开bar.bmp,直接按打印就可以在打印机上输出; 建议采用激光打印机; 5、本控件能将文字信息、照片信息等生成二维条码; 6、本控件可以采用DLL方式或OCX方式提供。 7、本软件只演示将文本信息(注意要<1kByte)生成pdf417二维条码并解码; 8、解码控件可以支持黑白二色、256色、24位真彩二维条码图片。 若需要其他功能演示,如图片压缩生成二维条码,二维条码与数据库连接,扫描枪与串口连接读取二维条码, 软件进行二维条码图片解码等等;
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值