二维码生成原理.doc_第1页
二维码生成原理.doc_第2页
二维码生成原理.doc_第3页
二维码生成原理.doc_第4页
二维码生成原理.doc_第5页
免费预览已结束,剩余1页可下载查看

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

qr码生成原理(一)一、什么是qr码qr码属于矩阵式二维码中的一个种类,由denso(日本电装)公司开发,由jis和iso将其标准化。qr码的样子其实在很多场合已经能够被看到了,我这还是贴个图展示一下:这个图如果被正确解码,应该看到我的名字和邮箱。二、qr码的特点说到qr码的特点,一是高速读取(qr就是取自“quick response”的首字母),对读取速度的体验源自于我手机上的一个软件,象上面贴出的码图,通过摄像头从拍摄到解码到显示内容也就三秒左右,对摄像的角度也没有什么要求;二是高容量、高密度;理论上内容经过压缩处理后可以存7089个数字,4296 个字母和数字混合字符,2953个8位字节数据,1817个汉字;三是支持纠错处理;纠错处理相对复杂,目前我还没有深入了解,按照qr码的标准文档说明,qr码的纠错分为4个级别,分别是: level l : 最大 7% 的错误能够被纠正; level m : 最大 15% 的错误能够被纠正; level q : 最大 25% 的错误能够被纠正; level h : 最大 30% 的错误能够被纠正;四是结构化;看似无规则的图形,其实对区域有严格的定义,下图就是一个模式2、版本1的qr图结构(关于qr码的模式、版本将在后面进行介绍):在上图21*21的矩阵中,黑白的区域在qr码规范中被指定为固定的位置,称为寻像图形(finder pattern) 和 定位图形(timing pattern)。寻像图形和定位图形用来帮助解码程序确定图形中具体符号的坐标。黄色的区域用来保存被编码的数据内容以及纠错信息码。蓝色的区域,用来标识纠错的级别(也就是level l到level h)和所谓的mask pattern,这个区域被称为“格式化信息”(format information)。五是扩展能力。qr码的structure append特点,使一个qr码可以分解成多个qr码,反之,也可以将多个qr码的数据组合到一个qr码中来。 三、qr码的模式和版本前面提到过qr码的模式(model)和版本(version)。qr码分为model1和model2两种模式,model1是对qr的初始定义,model2是对model1的扩展,目前使用较为普遍的是model2,本文的所有说明也仅用于model2。qr图的大小(size)被定义为版本(version),版本号从1到40。版本1就是一个21*21的矩阵,每增加一个版本号,矩阵的大小就增 加4个模块(module),因此,版本40就是一个177*177的矩阵。(版本越高,意味着存储的内容越多,纠错能力也越强)。三、qr码支持的编码内容qr码支持编码的内容包括纯数字、数字和字符混合编码、8位字节码和包含汉字在内的多字节字符。其中:数字:每三个为一组压缩成10bit。字母数字混合:每两个为一组,压缩成11bit。 8bit字节数据:无压缩直接保存。多字节字符:每一个字符被压缩成13bit。qr码编码原理二(编码)编码就是把常见的数字、字符等转换成qr码的方法。说具体的编码之前,先说一下qr码的最大容量问题。一、最大容量qr码的最大容量取决于选择的版本、纠错级别和编码模式(mode:数字、字符、多字节字符等)。以版本1、纠错级别为level q的qr码为例,可以存储27个纯数字,或17个字母数字混合字符或11个8bit字节数据。如果要存储同样多的内容同时提高纠错级别,则需要采用更高的 版本。版本19 数据容量、纠错码容量对照如下表:(version)(error correcting level)(count of data code words)count of ec code words(numeric)(alphanumeric)8bit1l197412517m1610342014q1313271611h917171072l3410774732m2816633826q2222482920h16283420143l55151277753m44261016142q3436774732h26445835244l802018711478m64361499062q48521116746h36648250345l10826255154106m864820212284q62721448760h468810664446l13636322195134m10864255154106q769617510874h6011213984587l15640370224154m12472293178122q8810820712586h6613015493648l19448461279192m15488365221152q110132259157108h86156202122849l23260552335230m182110432262180q132160312189130h10019223514398如果要了解更详细的qr码容量信息,可以到电装的网站去看看/qrcode/vertable1-e.html。 下面,就举例说明将“abcde123”转换成为版本1、level h的qr码转换方法。二、模式标识符(mode indicator)qr码的模式(mode)就是前文提到的数字、字符、8bit 字节码、多字节码等。对于不同的模式,都有对应的模式标识符(mode indicator)来帮助解码程序进行匹配,模式标识符是4bit的二进制数:1、数字模式(numeric mode ): 00012、混合字符模式(alphanumeric mode) : 00103、8bit byte mode: 01004、日本汉字(kanji mode) : 10005、中国汉字(gb2312):1101由于示例文本串是混合字符,因此将选择alphanumeric mode,其标识码为:0010三、文本串计数标识符(character count indicator)文本串计数标识符用来存储源内容字符串的长度,在版本1-9的qr码中,文本串长度标识符自身的长度被定义为:数字 : 10bit 混合字符 : 9bit8bit 字节码 : 8bit多字节码 : 8bit在本例中,源文本串的长度为8个字符,混合字符的长度为9bit,因此将字符个数8编码为9位二进制表示:000001000加上混合字符模式标识码,总的编码为0010 000001000四、数据内容编码 1、数字模式下的编码在数字模式下,数据被限制为3个数字一段,分成若干段。如:123456 将分成123 和 456,分别被编码成10bit的二进制数。“123”的10bit二进制表示法为:0001111011,实际上就是二进制的123。当数据的长度不足3个数字时,如果只有1个数字则用4bit,如果有2个数字就用7个bit来表示。如:9876被分成987和6两段,因此被表示为1111011011 0110。2、混合字符模式下的编码混合字符模式编码,其字符对照表如下:0 0 a 10 k 20 u 30 + 40 11 b11 l21 v31 -4122 c12 m22 w32 .4233 d13 n23 x33 /4344 e14 o24 y34 :4455 f15 p25 z3566 g16 q26 sp3677 h17 r27 $3788 i18 s28 %3899 j19 t29 *3 编码方式为:源码被分成两个字符一段,如下所示,每段的第一个字符乘上45,再用第二个数字相加。因此每段变成了11bit的2进制码,如果字符个数只有1个,则用6bit表示。 示例: abcde123 45*10+1145*12+1345*14+145*2+3 461553631930010000001000001110011010100010100101001110111000010111013、8bit字节数据不经编码转换直接保存。五、编码终止符(terminator)如果编码后的字符长度不足当前版本和纠错级别所存储的容量,则在后续补0000,如果容量已满则无需添加终止符。此时得到的编码串为:0010 000001000 00111001101 01000101001 01001110111 00001011101 0000六、编成8bit码字(code words)将以上的编码再按8bit一组,形成码字(code words): 00100000 01000001 11001101 01000101 00101001 11011100 00101110 10000如果尾部数据不足8bit,则在尾部充0:00100000 01000001 11001101 01000101 00101001 11011100 00101110 10000000如果编码后的数据不足版本及纠错级别的最大容量,则在尾部补充 11101100 和 00010001,直到全部填满。最后,版本1、level h下的abcde123 的qr码是:00100000 01000001 11001101 01000101 00101001 11011100 00101110 10000000 11101100十进制表示法为:32 65 205 69 41 220 46 128 236qr码编码原理三(日本汉字和中文编码)一、日本汉字(kanji)是两个字节表示的字符码,编码的方式是将其转换为13字节的二进制码制。转换步骤为:1、对于jis值为8140(hex) 到9ffc(hex)之间字符:a)将待转换的jis值减去8140(hex);b)将高位字节乘以c0(hex);c)将b)步骤生成的数据加上低位字节;d)将结果转换为13位二进制串。2、对于jis值为e040(hex)到ebbf(hex)之间的字符:a)将待转换的jis值减去c140(hex);b)将高位字节乘以c0(hex);c)将b)步骤生成的数据加上低位字节;d)将结果转换为13位二进制串。 二、中文汉字的与日文汉字转换步骤相似:1、对于第

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论