我使用以下行获取我的 DataMatrix 代码:
BitMatrix bitMatrix = new DataMatrixWriter().encode(dmie.preEncodeBarcode(dataToEncode), BarcodeFormat.DATA_MATRIX, 50, 50, null);
我得到的输入字符串包含“FNC1”(就像字符串中的纯字符一样)来标记动态字段的结尾,并且该字符串总共有 4 个不同的 GS1 DataMatrix 应用程序标识符及其各自的值。
preEncodeBarcode() 所做的是将 "FNC1" 替换为<GS>
,如下所示:
input = input.replaceAll("FNC1", new String(new byte[] {0x1d}));
因为否则我只需在 DataMatrix 中编码“FNC1910005FNC1230202 [...]”,而我想要的当然<GS>
是文本“FNC1”。
但是,当将 FNC1 替换为<GS>
(我也尝试过使用 '\u001c')时,我得到了这个非常奇怪的双 DM 代码,而不是普通代码:
只有当我跳过替换“FNC1”时,<GS>
我才能得到一个合适的。
知道如何根据包含我<GS>
的字符串获得正确的 DataMatrix 代码吗?<GS>
还是我只是直接在字符串中做错了什么?在这种情况下,我应该怎么做才能让 zxing 给我一个正确的 DataMatrix?我一直在阅读,但我真的无法理解这一点。
更新:我不确定,但我可能会遇到一些奇怪的错误。这就是我在预处理输入字符串后发送给 DataMatrixWriter 的内容(空格是 ):
[d29100001 21000000049347037 24000163718 390300000002990
我发现相当模糊的是,如果我(在撰写本文时)发送input.substring(2, input.length());
或者input.substring(0, input.length()-3);
它工作得很好,而如果我从开头只删除一个(或更少)字符或从结尾删除 2 个或更少,那么我得到这个奇怪的数据矩阵。更奇怪的是,这种行为甚至不一致——如果我在最后添加 6 个随机数,那么它工作正常,但如果我然后删除其中三个数字,我又会遇到问题。最糟糕的是,一个小时前我无法发送input.substring(0, input.length()-3)
,但现在我可以了。
换句话说,我完全感到困惑。
(PS。我正在使用此处找到的代码将 DataMatrix 缩放到我想要的大小,但是 zxing 从一开始就给出了错误的输出。)