環境安裝:html
1. zxing-cpp 源碼和源碼編譯後生成的lib,個人版本是V1.0.8,編譯方法見:http://www.javashuo.com/article/p-pdkpkmdt-kv.html。zxing-cpp項目路徑:https://github.com/nu-book/zxing-cppc++
2. Visual Studio 2017安裝https://visualstudio.microsoft.com/zh-hans/vs/older-downloads/,安裝完成後在 工具-獲取工具和支持 中添加「使用C++的桌面開發」支持。git
3.安裝windows opencv並添加環境變量,例如我安裝在 D:\opencv\opencv 文件夾中,添加環境變量 D:\opencv\opencv\build\x64\vc15\bin。觀察opencv文件夾咱們也能夠知道,opencv默認只支持x64,x86須要本身下載源碼編譯。我安裝的版本是 4.1.2 ,下載路徑:github
Demo地址:https://github.com/SourceCode-Farmer/ZxingDemowindows
過程記錄:ide
1、 添加依賴工具
1. 新建Visual C++ Windows控制檯應用程序 ZxingDemo,打開項目文件夾有以下文件:測試
2. 打開opencv 安裝目錄下的 build 文件夾,複製 include 文件夾到 ZxingDemo 項目文件夾中,重命名爲opencv_header.ui
3. 在 ZxingDemo 項目文件夾中新建 opencv_lib\lib64 文件夾,打開 opencv 安裝目錄下的 build\x64\vc15\lib 文件夾,將 opencv_world412.lib 和 opencv_world412d.lib 兩個文件複製到 ZxingDemo 項目文件夾中(若是 lib 文件名稱有變化,請將全部 lib 文件一股腦複製過來便可)。編碼
4. 在 ZxingDemo 項目文件夾中新建文件夾 zxing_lib ,複製 zxing-cpp 編譯後的 lib 到文件夾中(注意 Zxing-cpp 和 ZxingDemo 編譯時的解決方案配置、解決方案平臺必須一致)。
5. 打開 zxing-cpp 源碼中的 core 文件夾,複製 src 到 ZxingDemo 項目目錄中,重命名文件夾爲 zxing_header。
6. 打開 zxing_header 文件夾,刪除當前目錄及其子目錄中的全部cpp文件。
ps:若是隻作 Qr 碼識別,能夠刪除目錄 aztec、maxicode、oned、pdf417 和 textcodec,保留 zxing_header 下 h 文件和 datamatrix 、 qrcode文件下h文件。
ps:修改文件分組依據,能夠以快速刪除 cpp 文件
2、 配置依賴
1. vs 項目右鍵屬性,調整配置爲 Release,調整平臺爲 x64.
2. 屬性 - 配置屬性 - c/c++ - 常規 - 附加包含目錄 ,添加頭文件路徑(圖片路徑按實際作調整,依葫蘆畫瓢)。
3. 屬性 - 配置屬性 - 連接器 - 常規 - 附加庫目錄,添加 lib 庫目錄(圖片路徑按實際作調整,依葫蘆畫瓢)。
4.屬性 - 配置屬性 - 連接器 - 常規 - 附加依賴項,添加 ZxingDemo 項目中全部的 lib 文件名稱(根據 lib 文件實際名稱調整)。
3、編碼
1.在 ZxingDemo.cpp 文件中編寫代碼。
//按項目實際路徑調整 #pragma comment(lib,"zxing_lib/ZXingCore.lib") #include "stdafx.h" #include "zxing_header\HybridBinarizer.h" #include "zxing_header\LuminanceSource.h" #include "zxing_header\GenericLuminanceSource.h" #include "zxing_header\DecodeHints.h" #include "zxing_header\BinaryBitmap.h" #include "zxing_header\ReadBarcode.h" #include "zxing_header\TextUtfEncoding.h" #include "zxing_header\MultiFormatReader.h" #include <opencv2\opencv.hpp> #include <opencv2\core\types_c.h> static std::string WstringToString(const std::wstring &wstr) { std::string str; std::mbstate_t state = {}; const wchar_t *data = wstr.data(); size_t len = std::wcsrtombs(nullptr, &data, 0, &state); if (static_cast<size_t>(-1) != len) { std::unique_ptr<char[]> buff(new char[len + 1]); len = std::wcsrtombs(buff.get(), &data, len, &state); if (static_cast<size_t>(-1) != len) { str.assign(buff.get(), len); } } return str; } static void Scan() { cv::Mat mat, gray_mat; //打開圖片 mat = cv::imread("test.PNG"); if (mat.empty()) { std::cout << "not found image" << std::endl; return; } //轉爲灰度圖 cv::cvtColor(mat, gray_mat, cv::COLOR_RGBA2GRAY); //寬高 int height = gray_mat.rows; int width = gray_mat.cols; auto *pixels = new unsigned char[height * width]; int index = 0; for (int i = 0; i < height; i++) { for (int j = 0; j < width; j++) { pixels[index++] = gray_mat.at<unsigned char>(i, j); } } //識別 std::shared_ptr<ZXing::GenericLuminanceSource> luminance = std::make_shared<ZXing::GenericLuminanceSource>(0, 0, width, height, pixels, width * sizeof(unsigned char)); std::shared_ptr<ZXing::BinaryBitmap> bitmap = std::make_shared<ZXing::HybridBinarizer>(luminance); ZXing::DecodeHints hints; //根據須要添加format std::vector<ZXing::BarcodeFormat> formats = { ZXing::BarcodeFormat(ZXing::BarcodeFormat::QR_CODE) }; hints.setPossibleFormats(formats); auto reader = new ZXing::MultiFormatReader(hints); ZXing::Result result = reader->read(*bitmap); if (result.status() == ZXing::DecodeStatus::NoError) { //識別成功,打印結果 std::cout << WstringToString(result.text()) << std::endl; } else { std::cout << "Fail" << std::endl; } } int main() { Scan(); std::cin.get(); return 0; }
2. 搞一張二維碼圖片 test.PNG 放到編譯輸出目錄 x64\Release 中。
4、啓動
1. 調整配置爲 Release,調整平臺爲 x64,點擊」本地windows調試器」啓動測試。
2.成功輸出結果。
5、常見問題
1. 編譯異常:錯誤 C4996 'wcsrtombs': This function or variable may be unsafe. Consider using wcsrtombs_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS. See online help for details. ZxingDemo H:\cpp\ZxingDemo\ZxingDemo\ZxingDemo.cpp 23
解決方法:右鍵項目屬性 - 配置屬性 – c/c++ - 預處理器 - 預處理器定義,添加以下預處理定義。
_CRT_SECURE_NO_WARNINGS
_CRT_NONSTDC_NO_WARNINGS
_CRT_SECURE_NO_WARNINGS_GLOBALS
2. 執行異常,啓動測試後報錯:沒法啓動此程序,由於計算機中丟失 opencv_world412.dll。嘗試從新安裝該程序已解決此問題。
緣由:程序找不到opencv_world412.dll,通常狀況:1.沒安裝 opencv 或者沒有添加 opencv 環境變量 2.打開 vs2017 後才添加 opencv 環境變量,未生效。
解決:安裝 opencv ,添加 Path 環境變量 build\x64\vc15\bin(或者build\x64\vc14\bin)。關閉 Vs2017 從新打開項目。