我正在尝试使用Web Assembly为Web制作PDF417条形码阅读器(有一些,但唯一可靠的是许可的)。这个想法很简单,只需用 C 代码构建一个可以通过 JavaScript 调用的二进制文件。
我按照这个指南,让我几乎到达那里!我不得不添加--enable-codes=pdf417
作为参数来configure
启用PDF417符号并禁用所有其他我不感兴趣的符号。
该代码实际上对于任何其他类型的符号都非常有效(请参阅演示),但是如果我编译ZBar以接受PDF417,它会检测到它,但会发出警告:
WARNING: zbar/decoder/pdf417.c:73: pdf417_decode8: Assertion "clst >= 0 && clst < 9" failed.
dir=0 sig=5a44 k=9 buf[0000]=
WARNING: zbar/decoder/pdf417.c:89: pdf417_decode8: Assertion "g[0] >= 0 && g[1] >= 0 && g[2] >= 0" failed.
dir=1 sig=ca03 k=6 g0=ffffffff g1=e71 g2=585 buf[0000]=
这些断言在ZBar的第71行和第86行。
您可以在我之前提到的指南中看到我正在使用的所有代码(唯一的区别是我在编译之前启用了 PDF417) ¿有什么想法吗?
zbar 的默认行为是尝试解码所有符号类型。
if(sym == ZBAR_NONE) {
static const zbar_symbol_type_t all[] = {
ZBAR_EAN13, ZBAR_EAN2, ZBAR_EAN5, ZBAR_EAN8,
ZBAR_UPCA, ZBAR_UPCE, ZBAR_ISBN10, ZBAR_ISBN13,
ZBAR_I25, ZBAR_DATABAR, ZBAR_DATABAR_EXP, ZBAR_CODABAR,
ZBAR_CODE39, ZBAR_CODE93, ZBAR_CODE128, ZBAR_QRCODE,
ZBAR_PDF417, 0
};
const zbar_symbol_type_t *symp;
for(symp = all; *symp; symp++)
zbar_decoder_set_config(dcode, *symp, cfg, val);
return(0);
}
您的图像是否包含 PDF417 条形码?如果没有,您可以指示 zbar 仅解码您感兴趣的符号类型,因此 PF417 解码器将不会运行。您可以使用符号参数执行此操作,例如,如果您的图像仅包含QR码,
// disable all
scanner.set_config(ZBAR_NONE, ZBAR_CFG_ENABLE, 0);
// enable qr
scanner.set_config(ZBAR_QRCODE, ZBAR_CFG_ENABLE, 1);
(皮兹巴尔)
from pyzbar.pyzbar import ZBarSymbol
decode(Image.open('pyzbar/tests/qrcode.png'), symbols=[ZBarSymbol.QRCODE])
对于任何试图使用ZBar读取PDF417的人来说,PDF417解码是不完整的。这是行不通的。你最好的开源选择是ZXing。