Data Matrix 二维条码原名Datacode,由美国国际资料公司(International Data Matrix, 简称ID Matrix)于1989年发明。Data-Matrix二维条码是一种矩阵式二维条码。

Data Matrix符号由规则排列的深浅色正方形模块构成,每一个正方形模块就是一个基本单元。每一个基本单元又被编码为一比特的数据。

数据区的四周是探測图形。用于条码符号定位和确定条码结构信息。探測图形的四周是空白区,用以将条码符号与背景分离。

探測图形是一个模块的宽度。是数据区的边界,当中所有由深色模块组成的两条邻边构成了一个“L”形实线边缘,“L”对面由交替的深浅模块组成的两条邻边又构成了虚线边缘。探測图形主要用于限定符号的单元结构,也可用于确定符号的物理尺寸。以及解决符号定位和失真等问题。

数据区是由多个正方形深浅模块所组成的正方形区域,信息储存方式是深浅模块的不同排列组合.以二进制码方式来编码数据。因此计算机可直接读取。深色模块代表“1”。浅色模块代表“0”,再利用成串的特定排列的深浅模块来描写叙述码字信息,再排列成一个矩阵式符号,终于形成Data Matrix条码。

因此。随意Data Matrix符号能够由四个部分构成:探測图形中“L”形的两条实线边缘、探測图形中“L”形对面的两条虚线边缘、被探測图形包围的数据区、条码符号四周的一个模块宽度的空白区。

Data Matrix条码编码是将物品信息转化成为数据码字流,用二维条码符号来表示实现。

同意输入数据信息多样。能够是数字和字母,能够是常规的文字、字符信息,还能够是多媒体信息,如声音、图片、指纹等。

Data Matrix分为ECC 000-140和ECC 200两个大类,ECC 000-140具有四个等级的卷积纠错功能,ECC 200则通过Reed—Solomon纠错算法计算纠错码,依据符号的不同尺寸得到不同的纠错码。两类符号的外形差别在于,ECC 000-140符号的右上角为深色模块(仅为奇数)。尺寸从9*9至49*49。ECC 200符号的右上角为浅色模块(仅为偶数)。尺寸从10*10至144*144,若为长方形则从8*18至16*48。ECC 200应用较多。

Data Matrix编码包括三个部分:一是将数据信息流通过最优的编码规则转换成数据码字。二是依据Reed-Solomon算法以及响应的纠错要求,在数据码字的基础上生成纠错码字,数据码字加上纠错码字及可能须要的若干填充字符,构成编码后的码字流;三是将依照标准模板将单元模块放置到矩阵中,并增加探測图形,生成Data Matrix二维矩阵码符号。

Data Matrix二维条码图像的识别主要包括图像预处理、条码定位、採样解码。

Data Matrix条码图像预处理:首先对採集到的彩色图像灰度化;然后对灰度图像进行滤波去噪;选取适当的阈值进行图像二值化;最后进行边缘提取。

条码定位:区域初定位、边缘检測、旋转校正、精确提取、条码切割(网格)。

Data Matrix条码解码识别:依据採样网格,将深浅模块转换为“1”、“0”矩阵。去除探測图形,提取出数据区,并得到条码尺寸和版本号信息;调用模块放置矩阵恢复正确顺序的码字流。再确定数据码字和纠错码字,并进行条码数据的检错纠错。终于恢复原始数据,正确解码输出。

Data Matrix核心库它的license是BSD,具体介绍见主页http://www.libdmtx.org/  。

以下具体介绍Data Matrix在VS2010中编译过程:

1.  从http://sourceforge.net/projects/libdmtx/下载其稳定版本号libdmtx-0.7.4;

2.  新建一个libdmtx静态库project,将/libdmtx-0.7.4文件夹下对应的.h、.c文件增加到此project中;

3.  对源码进行调整:(1)、将dmtx.h和dmtxstatic.h两个头文件分别包括到每一个.c文件里;(2)、对于错误C2129,处理办法是将声明和实现中的“static”keyword都去掉;(3)、将float.h、stdio.h、limits.h、assert.h、math.h文件增加到dmtx.h中;(4)、将CHKERR、CHKSCHEME、CHKSIZE、CALLBACK_MATRIX等的定义从dmtxencodescheme.c中复制到dmtx.h中;(5)、凝视掉dmtx.c文件里包括的.c文件;(6)、将文件里的snprintf函数用sprintf_s函数替代;

4. 新建barcodetest控制台project,对libdmtx库进行简单測试。相关文件代码例如以下(代码參考/libdmtx-0.7.4/test/simple-test/simple_test.c):

stdafx.h:

#pragma once

#include "targetver.h"

#include <stdio.h>

#include "../../src/datamatrix/libdmtx-0.7.4/dmtx.h"

stdafx.cpp:

#include "stdafx.h"

#ifdef _DEBUG
#pragma comment(lib, "../../../lib/dbg/x86_vc10/libdmtx[dbg_x86_vc10].lib")
#else
#pragma comment(lib, "../../../lib/rel/x86_vc10/libdmtx[rel_x86_vc10].lib")
#endif

barcodetest.cpp:

#include "stdafx.h"
#include <iostream>
#include <assert.h>
#include <string> using namespace std; int main(int argc, char* argv[])
{
size_t width, height, bytesPerPixel;
string str = "中国_abc_DEF_123_@#$!";
string dst;
unsigned char *pxl;
DmtxEncode *enc;
DmtxImage *img;
DmtxDecode *dec;
DmtxRegion *reg;
DmtxMessage *msg; //fprintf(stdout, "input: \"%s\"\n", str);
cout<<"str : "<<str<<endl; /* 1) ENCODE a new Data Matrix barcode image (in memory only) */
enc = dmtxEncodeCreate();
assert(enc != NULL);
//dmtxEncodeDataMatrix(enc, strlen(str), str);
dmtxEncodeDataMatrix(enc, strlen(str.c_str()), (unsigned char*)str.c_str()); /* 2) COPY the new image data before releasing encoding memory */
width = dmtxImageGetProp(enc->image, DmtxPropWidth);
height = dmtxImageGetProp(enc->image, DmtxPropHeight);
bytesPerPixel = dmtxImageGetProp(enc->image, DmtxPropBytesPerPixel); pxl = (unsigned char *)malloc(width * height * bytesPerPixel);
assert(pxl != NULL);
memcpy(pxl, enc->image->pxl, width * height * bytesPerPixel); dmtxEncodeDestroy(&enc); /* 3) DECODE the Data Matrix barcode from the copied image */
img = dmtxImageCreate(pxl, width, height, DmtxPack24bppRGB);
assert(img != NULL); dec = dmtxDecodeCreate(img, 1);
assert(dec != NULL); reg = dmtxRegionFindNext(dec, NULL);
if(reg != NULL) {
msg = dmtxDecodeMatrixRegion(dec, reg, DmtxUndefined);
if(msg != NULL) {
/*fputs("output: \"", stdout);
fwrite(msg->output, sizeof(unsigned char), msg->outputIdx, stdout);
fputs("\"\n", stdout);*/
dst = string(reinterpret_cast<const char*>(msg->output));
dmtxMessageDestroy(&msg);
}
dmtxRegionDestroy(&reg);
} cout<<"dst : "<<dst<<endl; dmtxDecodeDestroy(&dec);
dmtxImageDestroy(&img);
free(pxl); cout<<"ok!"<<endl;
return 0;
}

GitHubhttps://github.com/fengbingchun/BarCode_Test

二维码Data Matrix简单介绍及在VS2010中的编译的更多相关文章

  1. 二维码Data Matrix编码、解码使用举例

    二维码Data Matrix的介绍见: http://blog.csdn.net/fengbingchun/article/details/44279967  ,这里简单写了个生成二维码和对二维码进行 ...

  2. 二维码Data Matrix的解码实现(zxing-cpp)

    二维码Data Matrix的介绍可以参考http://blog.csdn.net/fengbingchun/article/details/44279967 ,以下是通过zxing-cpp开源库实现 ...

  3. (zxing.net)二维码Data Matrix的简介、实现与解码

    一.简介 Data Matrix 二维条码原名Datacode,由美国国际资料公司(International Data Matrix, 简称ID Matrix)于1989年发明.Data-Matri ...

  4. c#高效准确的条形码、线性条码、QR二维码读写类库-SharpBarcode介绍

    SharpBarcode是一款支持.NET(C#,VB)的高效易用的条形码.QR二维码的读取和生成类库. 主要功能: 1.支持几乎所有常见类型的线性条形码和QR二维码的读取,高效读取,准确率高. 2. ...

  5. Android ZXing 二维码、条形码扫描介绍

    本帖最后由 Shims 于 2013-11-9 12:39 编辑 最近公司的Android项目需要用到摄像头做条码或二维码的扫描,Google一下,发现一个开源的 ZXing项目.它提供二维码和条形码 ...

  6. java学习-zxing生成二维码矩阵的简单例子

    这个例子需要使用google的开源项目zxing的核心jar包 core-3.2.0.jar 可以百度搜索下载jar文件,也可使用maven添加依赖 <dependency> <gr ...

  7. 二维码相关---java生成二维码名片,并且自动保存到手机通讯录中...

    http://blog.csdn.net/lidew521/article/details/24441825

  8. Java生成艺术二维码也可以很简单

    原文点击: Quick-Media Java生成艺术二维码也可以很简单 现在二维码可以说非常常见了,当然我们见得多的一般是白底黑块,有的再中间加一个 logo,或者将二维码嵌在一张特定的背景中(比如微 ...

  9. 免费开源的DotNet二维码操作组件ThoughtWorks.QRCode(.NET组件介绍之四)

    在生活中有一种东西几乎已经快要成为我们的另一个电子”身份证“,那就是二维码.无论是在软件开发的过程中,还是在普通用户的日常中,几乎都离不开二维码.二维码 (dimensional barcode) , ...

随机推荐

  1. 使用Git Submodule管理子模块

    转自:https://segmentfault.com/a/1190000003076028 使用场景 基于公司的项目会越来越多,常常需要提取一个公共的类库提供给多个项目使用,但是这个library怎 ...

  2. iOS图标抖动效果

    开始抖动 -(void)BeginWobble { srand([[NSDate date] timeIntervalSince1970]); float rand=(float)random(); ...

  3. iOS开发-UITextField手机号和邮箱验证

    不管是网页是手机,用户注册登录的时候绝大数时候都需要手机号码和邮箱地址,而且有些App会限制只能使用手机号注册,iOS方面邮箱正则比较简单,不过手机号码验证找了一下网上的,发现三大运营商的号码段有所变 ...

  4. 弹出层框架layer快速使用

    layer官方及演示文档:layer官方及演示文档 1.将layer整个放入工程内. 2.文件内引入layer.js, <script type="text/javascript&qu ...

  5. listview加载数据

    首先我们需要理清思路:使用ListView显示数据是很方便的,ListVIew的数据之间通过适配器adapter去作为桥梁连接起来.当我们需要使用listview显示大量数据的时候,我们需要使用到分页 ...

  6. 大数据开发实战:MapReduce内部原理实践

    下面结合具体的例子详述MapReduce的工作原理和过程. 以统计一个大文件中各个单词的出现次数为例来讲述,假设本文用到输入文件有以下两个: 文件1: big data offline data on ...

  7. AAAI 2018 论文 | 蚂蚁金服公开最新基于笔画的中文词向量算法

    AAAI 2018 论文 | 蚂蚁金服公开最新基于笔画的中文词向量算法 2018-01-18 16:13蚂蚁金服/雾霾/人工智能 导读:词向量算法是自然语言处理领域的基础算法,在序列标注.问答系统和机 ...

  8. webstorm和intellij idea下如何自动编译sass和scss文件

    webstorm和intellij idea下如何自动编译sass和scss文件 https://segmentfault.com/a/1190000008996504 https://www.jia ...

  9. Mongo = get size of single document

      Object.bsonsize(db.test.findOne({type:"auto"}))

  10. Springboot单元测试(MockBean||SpyBean)

    转载:https://blog.csdn.net/maiyikai/article/details/78483423 本来要写springboot集成netty实现的,但是想起来单元测试没总结,那就趁 ...