條碼識別是視覺模塊經常使用到的功能之一,經常用于識別超市的貨物信息。本文我們將演示如何基于瑞芯微RV1106的LockAI視覺識別進行條碼識別。
源代碼網址:https://gitee.com/LockzhinerAI/LockzhinerVisionModule/tree/master/Cpp_example/C07_test_bar_codeDetector
1. 基本知識講解
1.1 條碼簡介
條碼是一種通過寬度不同的平行線條和間隔來表示數據的機器可讀形式,能夠被掃描設備快速讀取并轉換為數字信號。被廣泛應用于零售、物流、醫療和制造等行業。條碼技術提高了數據輸入的速度和準確性,降低了成本,并且由于其高效性和兼容性強的特點,成為商品標識、庫存管理、貨物追蹤等操作中不可或缺的一部分。無論是簡單的產品編碼還是一些復雜的包含文字、網址的信息,條碼都能提供可靠的支持。
1.2 條碼識別步驟
條碼碼識別主要通過兩個步驟完成:圖像捕捉和解碼。
圖像捕捉:使用設備攝像頭拍攝包含條碼的圖像。
解碼:軟件處理圖像,定位并讀取條碼中的數據,轉換為原始信息。
常用工具如ZXing和ZBar提供了便捷的方法來集成條碼識別功能,使得開發者可以輕松實現從圖像捕捉到數據解碼的過程。用戶只需簡單操作即可快速獲取條碼中的信息,極大提高了效率和便利性。
2. C++ API文檔
2.1 Code128Detector類
2.1.1 頭文件
#include
作用:用于聲明Code128Detector類,使得Code128Detector類可以在當前源文件中使用。
2.1.2 構造類對象
lockzhiner_vision_module::Code128Detectormodel;
作用:用于實現條碼識別。
參數說明:
無
返回值:
無
2.1.3 Predict函數
autoresults=model.Predict(input_mat);
作用:Code128Detector類中的一個函數,用于實現條碼識別。
參數說明:
input_mat: 要識別的圖像。
返回值:
返回一個包含Code 128格式的條碼檢測結果的對象集合。每個Result對象包含條碼的位置信息和解碼后的文本內容。
2.2 Visualize函數
2.2.1 頭文件
#include
作用:用于聲明Visualize函數,使得Visualize函數可以在當前源文件中使用。
2.2.2 結果可視化
lockzhiner_vision_module::Visualize(input_image,output_image,
results);
參數說明:
input_image: 輸入參數,表示原始輸入圖像。
output_image: 輸出參數,用于存儲帶有可視化結果的輸出圖像。
results: 輸入參數,表示條碼碼檢測的結果集。每個Result對象包含條碼的位置信息和解碼后的文本內容。
返回值:
無
3. 綜合代碼介紹
3.1 流程圖
3.2 核心代碼解析
初始化
lockzhiner_vision_module::Code128Detectormodel;
lockzhiner_vision_module::Editedit;
調用攝像頭捕獲圖像
cv::VideoCapturecap;
// 設置攝像頭獲取幀的寬高
cap.set(cv::CAP_PROP_FRAME_WIDTH,640);
cap.set(cv::CAP_PROP_FRAME_HEIGHT,480);
cap.open(0);
// wihile循環中的以下代碼用于捕獲圖像幀
cap>>input_mat;
if(input_mat.empty())
{
continue;
}
條碼檢測
autoresults=model.Predict(input_mat);
3.3 完整代碼實現
#include
#include
#include
#include
#include
#include
#include
#include
usingnamespacestd::chrono;
lockzhiner_vision_module::Code128Detectormodel;
intmain()
{
// 初始化 edit 模塊
lockzhiner_vision_module::Editedit;
if(!edit.StartAndAcceptConnection())
{
std::cerr<<"Error: Failed to start and accept connection."<<std::endl;
returnEXIT_FAILURE;
}
std::cout<<"Device connected successfully."<<std::endl;
cv::VideoCapturecap;
// 設置攝像頭獲取幀寬高
cap.set(cv::CAP_PROP_FRAME_WIDTH,640);
cap.set(cv::CAP_PROP_FRAME_HEIGHT,480);
cap.open(0);
if(!cap.isOpened())
{
std::cerr<<"Error: Could not open camera."<<std::endl;
returnEXIT_FAILURE;
}
cv::Matinput_mat;
while(true)
{
intread_index=0;
inttime_ms=0;
for(inti=0;i<30;i++)
{
// 獲取當前時間點作為開始時間
high_resolution_clock::time_pointstart_time=high_resolution_clock::now();
cap>>input_mat;
if(input_mat.empty())
{
continue;
}
// 使用 model 對象的 Predict 方法對輸入圖像進行預測,獲取條碼檢測結果
autoresults=model.Predict(input_mat);
// 獲取當前時間點作為結束時間
high_resolution_clock::time_pointend_time=high_resolution_clock::now();
autotime_span=duration_cast<milliseconds>(end_time-start_time);
time_ms+=time_span.count();
read_index+=1;
cv::Matoutput_image;
// 調用 Visualize 函數對原始圖像和檢測結果進行可視化處理,并將結果存儲在 output_image 中
lockzhiner_vision_module::Visualize(input_mat,output_image,results);
edit.Print(output_image);
}
std::cout<<"Frames per second: "<<1000.0/time_ms*read_index<<std::endl;
}
cap.release();
return0;
}
4. 編譯調試
4.1 編譯環境搭建
請確保你已經按照開發環境搭建指南正確配置了開發環境。
同時以正確連接開發板。
4.2 Cmake介紹
# CMake最低版本要求
cmake_minimum_required(VERSION3.10)
project(test_bar_codeDetector)
set(CMAKE_CXX_STANDARD17)
set(CMAKE_CXX_STANDARD_REQUIRED ON)
# 定義項目根目錄路徑
set(PROJECT_ROOT_PATH"${CMAKE_CURRENT_SOURCE_DIR}/../..")
message("PROJECT_ROOT_PATH = "${PROJECT_ROOT_PATH})
include("${PROJECT_ROOT_PATH}/toolchains/arm-rockchip830-linux-uclibcgnueabihf.toolchain.cmake")
# 定義 OpenCV SDK 路徑
set(OpenCV_ROOT_PATH"${PROJECT_ROOT_PATH}/third_party/opencv-mobile-4.10.0-lockzhiner-vision-module")
set(OpenCV_DIR"${OpenCV_ROOT_PATH}/lib/cmake/opencv4")
find_package(OpenCV REQUIRED)
set(OPENCV_LIBRARIES"${OpenCV_LIBS}")
# 定義 LockzhinerVisionModule SDK 路徑
set(LockzhinerVisionModule_ROOT_PATH"${PROJECT_ROOT_PATH}/third_party/lockzhiner_vision_module_sdk")
set(LockzhinerVisionModule_DIR"${LockzhinerVisionModule_ROOT_PATH}/lib/cmake/lockzhiner_vision_module")
find_package(LockzhinerVisionModule REQUIRED)
# 定義 ZXing SDK 路徑
set(ZXing_ROOT_PATH"${PROJECT_ROOT_PATH}/third_party/zxing-cpp-v2.2.1-lockzhiner-vision-module")
set(ZXing_DIR"${ZXing_ROOT_PATH}/lib/cmake/ZXing")
set(ZXing_INCLUDE_DIRS"${ZXing_ROOT_PATH}/include")
find_package(ZXing REQUIRED)
set(ZXing_LIBRARIES"${ZXing_LIBS}")
# 基本圖像處理示例
add_executable(test-bar-codeDetector test_bar_codeDetector.cc)
target_include_directories(test-bar-codeDetector PRIVATE
${ZXing_INCLUDE_DIRS}
${LOCKZHINER_VISION_MODULE_INCLUDE_DIRS}
)
target_link_libraries(test-bar-codeDetector PRIVATE${OPENCV_LIBRARIES}${LOCKZHINER_VISION_MODULE_LIBRARIES}${ZXing_LIBRARIES})
install(
TARGETS test-bar-codeDetector
RUNTIME DESTINATION .
)
4.3 編譯項目
使用 Docker Destop 打開 LockzhinerVisionModule 容器并執行以下命令來編譯項目
# 進入Demo所在目錄
cd/LockzhinerVisionModuleWorkSpace/LockzhinerVisionModule/Cpp_example/C07_test_bar_codeDetector
# 創建編譯目錄
rm-rfbuild &&mkdirbuild &&cdbuild
# 配置交叉編譯工具鏈
exportTOOLCHAIN_ROOT_PATH="/LockzhinerVisionModuleWorkSpace/arm-rockchip830-linux-uclibcgnueabihf"
# 使用cmake配置項目
cmake ..
# 執行編譯項目
make-j8&&makeinstall
在執行完上述命令后,會在build目錄下生成可執行文件。
5. 例程運行示例
5.1 運行前準備
請確保你已經參考凌智視覺模塊攝像頭部署指南正確下載了凌智視覺模塊圖片傳輸助手。
5.2 運行過程
在凌智視覺模塊輸入以下命令:
chmod777test-bar-codeDetector
./test-bar-codeDetector
5.3 運行效果
6. 總結
通過上述內容,我們成功的實現了一個條碼識別系統,包括:
- 獲取并加載包含code 128格式的條碼圖像。
- 進行條碼的檢測和解碼,返回檢測和解碼后的結果。
- 可視化包含條碼圖像的識別結果。
-
視覺識別
+關注
關注
3文章
101瀏覽量
16969 -
Lock
+關注
關注
0文章
11瀏覽量
7872 -
條碼識別
+關注
關注
0文章
35瀏覽量
7298 -
AI視覺
+關注
關注
0文章
82瀏覽量
4703
發布評論請先 登錄
基于LockAI視覺識別模塊:C++圖像采集例程
基于LockAI視覺識別模塊:C++使用圖像的統計信息
基于LockAI視覺識別模塊:C++尋找色塊
基于LockAI視覺識別模塊:C++輪廓檢測
ATK QR二維碼和條碼識別庫的模塊資料和使用C語言代碼合集免費下載

掃碼頭、條碼識別模塊、二維條碼掃描模塊在物聯網領域中的應用

基于LockAI視覺識別模塊:C++使用圖像的統計信息

# 基于LockAI視覺識別模塊:C++尋找色塊

基于LockAI視覺識別模塊:C++同時識別輪廓和色塊

評論