1

我使用以下行获取我的 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 从一开始就给出了错误的输出。)

4

1 回答 1

0

感谢zxing Google 小组的 Lachezar Dobrev,我能够按预期工作。事实证明,您可以将 EncodeHintType 交给 DataMatrixWriter,这会强制它应用方形。

这对我有用:

        HashMap hintMap = new HashMap();
        hintMap.put(EncodeHintType.DATA_MATRIX_SHAPE, SymbolShapeHint.FORCE_SQUARE);
        BitMatrix bitMatrix = new DataMatrixWriter().encode(input, BarcodeFormat.DATA_MATRIX, 50, 50, hintMap);

一周后更新:事实证明,zxing 不兼容 GS1,无论你给它什么输入,所以整个 FNC1/ 问题都不重要。相反,我会推荐使用Okapi Barcode,它可以完美运行。

我还没有找到任何指南或教程,但是根据 Okapi Java GUI 如何生成其条形码,我从项目的Make Barcode类中对此感到困惑。

DataMatrix dataMatrix = new DataMatrix();
dataMatrix.setDataType(Symbol.DataType.GS1);
dataMatrix.setReaderInit();
dataMatrix.setPreferredSize(24); //144x144
dataMatrix.forceSquare(true);
dataMatrix.setContent(dataToEncode);
BufferedImage image = new BufferedImage((dataMatrix.getWidth() * magnification) + (2 * borderSize),
                    (dataMatrix.getHeight() * magnification) + (2 * borderSize), BufferedImage.TYPE_INT_RGB);
Graphics2D g2d = image.createGraphics();
g2d.setRenderingHint(RenderingHints.KEY_ANTIALIASING, RenderingHints.VALUE_ANTIALIAS_ON);
g2d.setColor(Color.WHITE);
g2d.fillRect(0, 0, (dataMatrix.getWidth() * magnification) + (2 * borderSize),
                    (dataMatrix.getHeight() * magnification) + (2 * borderSize));
Java2DRenderer renderer = new Java2DRenderer(g2d, magnification, borderSize, Color.WHITE, Color.BLACK);
renderer.render(dataMatrix);
try {
    ByteArrayOutputStream baos = new ByteArrayOutputStream();
    ImageIO.write(image, "png", baos);
    //Before Base64-encoding the image and return as a String        
    Base64.Encoder encoder = Base64.getEncoder(); 
    return encoder.encodeToString(baos.toByteArray());
} catch (IOException e) {
//Do some logging
return "Something went wrong";//Return super-informative error message
}
于 2015-11-05T07:58:18.180 回答