一维码Code 128简介及其解码实现(zxing-cpp)
一維碼Code 128:1981年推出,是一種長度可變、連續(xù)性的字母數(shù)字條碼。與其他一維條碼比較起來,相對較為復雜,支持的字元也相對較多,又有不同的編碼方式可供交互運用,因此其應用彈性也較大。
Code 128特性:
1、具有A、B、C三種不同的編碼類型,可提供標準ASCII中128個字元的編碼使用;
2、允許雙向掃描;
3、可自行決定是否加上檢驗位;
4、條碼長度可調(diào),但包括開始位和結(jié)束位在內(nèi),不可超過232個字元;
5、同一個128碼,可以由A、B、C三種不同編碼規(guī)則互換,既可擴大字元選擇的范圍,也可縮短編碼的長度。
Code 128各編碼方式的編碼范圍:
1、Code 128 A:標準數(shù)字和字母,控制符,特殊字符;
2、Code 128 B:標準數(shù)字和字母,小寫字母,特殊字符;
3、Code 128 C/EAN 128:[00]-[99]的數(shù)字對集合,共100個,即只能表示偶數(shù)位長度的數(shù)字。
Code 128編碼規(guī)則:開始位+[FNC1(為EAN 128碼時加)] + 數(shù)據(jù)位 + 檢驗位 + 結(jié)束位。
Code128檢驗位計算:(開始位對應的ID值 + 每位數(shù)據(jù)在整個數(shù)據(jù)中的位置 * 每位數(shù)據(jù)對應的ID值) % 103。
以下是通過zxing-cpp開源庫實現(xiàn)的對一維碼Code 128進行解碼的測試代碼:
#include "funset.hpp"
#include <string>
#include <fstream>
#include <Windows.h>#include <zxing/LuminanceSource.h>
#include <zxing/common/Counted.h>
#include <zxing/Reader.h>
#include <zxing/aztec/AztecReader.h>
#include <zxing/common/GlobalHistogramBinarizer.h>
#include <zxing/DecodeHints.h>
#include <zxing/datamatrix/DataMatrixReader.h>
#include <zxing/MultiFormatReader.h>
#include <zxing/pdf417/PDF417Reader.h>
#include <zxing/qrcode/QRCodeReader.h>
#include <zxing/oned/CodaBarReader.h>
#include <zxing/oned/Code39Reader.h>
#include <zxing/oned/Code93Reader.h>
#include <zxing/oned/Code128Reader.h>#include <opencv2/opencv.hpp>#include "zxing/MatSource.h"int test_Code128_decode()
{std::string image_name = "E:/GitCode/BarCode_Test/test_images/Code128.png";cv::Mat matSrc = cv::imread(image_name, 1);if (!matSrc.data) {fprintf(stderr, "read image error: %s", image_name.c_str());return -1;}cv::Mat matGray;cv::cvtColor(matSrc, matGray, CV_BGR2GRAY);zxing::Ref<zxing::LuminanceSource> source = MatSource::create(matGray);int width = source->getWidth();int height = source->getHeight();fprintf(stderr, "image width: %d, height: %d\n", width, height);zxing::Ref<zxing::Reader> reader;reader.reset(new zxing::oned::Code128Reader);zxing::Ref<zxing::Binarizer> binarizer(new zxing::GlobalHistogramBinarizer(source));zxing::Ref<zxing::BinaryBitmap> bitmap(new zxing::BinaryBitmap(binarizer));zxing::Ref<zxing::Result> result(reader->decode(bitmap, zxing::DecodeHints(zxing::DecodeHints::CODE_128_HINT)));std::string txt = "E:/GitCode/BarCode_Test/test_images/Code128.txt";std::ifstream in(txt);if (!in.is_open()) {fprintf(stderr, "fail to open file: %s\n", txt.c_str());return -1;}std::string str1;std::getline(in, str1);fprintf(stderr, "actual result: %s\n", str1.c_str());std::string str2 = result->getText()->getText();fprintf(stdout, "recognization result: %s\n", str2.c_str());if (str1.compare(str2) == 0) {fprintf(stderr, "===== recognition is correct =====\n");}else {fprintf(stderr, "===== recognition is wrong =====\n");return -1;}in.close();return 0;
}
測試圖像如下:
測試結(jié)果如下:
GitHub:https://github.com/fengbingchun/Barcode_Test
總結(jié)
以上是生活随笔為你收集整理的一维码Code 128简介及其解码实现(zxing-cpp)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 一维码Code 93简介及其解码实现(z
- 下一篇: 一维码EAN 8简介及其解码实现(zxi