双字节编码。同样,也可以用于中文编码。日文和汉字的编码会减去一个值。如:在0X8140to0X9FFC中的字符会减去8140,在0XE040到0XEBBF中的字符要减去0XC140,然后把前两位拿出来乘以0XC0,然后再加上后两位,最后转成13bit的编码。如下图示例:
Exte
dedCha
elI
terpretatio
ECImode主要用于特殊的字符集。并不是所有的扫描器都支持这种编码。StructuredAppe
dmode用于混合编码,也就是说,这个二维码中包含了多种编码格式。FNC1mode这种编码方式主要是给一些特殊的工业或行业用的。比如GS1条形码之类的。简单起见,后面三种不会在本文中讨论。
附件
qr_codepdf
下面两张表中,Table2是各个编码格式的“编号”,这个东西要写在FormatI
formatio
中。注:中文是1101Table3表示了,不同版本(尺寸)的二维码,对于,数字,字符,字节和Ka
ji模式下,对于单个编码的2进制的位数。(在二维码的规格说明书中,有各种各样的编码规范
f表,后面还会提到)
下面我们看几个示例,示例一:数字编码在Versio
1的尺寸下,纠错级别为H的情况下,编码:012345671把上述数字分成三组012345672把他们转成二进制012转成0000001100;345转成010;67转成1000011。3把这三个二进制串起来000000110001010000114把数字的个数转成二进制versio
1H是10bits8个数字的二进制是00000010005把数字编码的标志0001和第4步的编码加到前面0001000000100000000011000101000011示例二:字符编码在Versio
1的尺寸下,纠错级别为H的情况下,编码AC42
f1从字符索引表中找到AC42这五个字条的索引101241422两两分组101241423把每一组转成11bits的二进制1012104512等于462转成0011100111041441454等于1849转成111001110012等于2转成0000104把这些二进制连接起来:00111001110111001110010000105把字符的个数转成二进制Versio
1H为9bits5个字符,5转成0000001016在头上加上编码标识0010和第5步的个数编码00100000001010011100111011100111001000010结束符和补齐符假如我们有个HELLOWORLD的字符串要编码,根据上面的示例二,我们可以得到下面的编码,
注:二维码的纠错码主要是通过ReedSolomo
errorcorrectio
(里德所罗门纠错算法)来实现的。对于这个算法,对于我来说是相当的复杂,里面有很多的数学计算,比如:多项式除法,把1255的数映射成2的
次方(0
255)的伽罗瓦域GaloisField之类的神一样的东西,以及基于这些基础的纠错数学公式,因为我的数据基
f础差,对于我来说太过复杂,所以我一时半会儿还r