chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

基于LockAI視覺識別模塊:C++條碼識別

福州市凌睿智捷電子有限公司 ? 2025-05-27 09:32 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

條碼識別是視覺模塊經(jīng)常使用到的功能之一,經(jīng)常用于識別超市的貨物信息。本文我們將演示如何基于瑞芯微RV1106的LockAI視覺識別進行條碼識別。

源代碼網(wǎng)址:https://gitee.com/LockzhinerAI/LockzhinerVisionModule/tree/master/Cpp_example/C07_test_bar_codeDetector

1. 基本知識講解

1.1 條碼簡介

條碼是一種通過寬度不同的平行線條和間隔來表示數(shù)據(jù)的機器可讀形式,能夠被掃描設(shè)備快速讀取并轉(zhuǎn)換為數(shù)字信號。被廣泛應(yīng)用于零售、物流、醫(yī)療和制造等行業(yè)。條碼技術(shù)提高了數(shù)據(jù)輸入的速度和準確性,降低了成本,并且由于其高效性和兼容性強的特點,成為商品標識、庫存管理、貨物追蹤等操作中不可或缺的一部分。無論是簡單的產(chǎn)品編碼還是一些復(fù)雜的包含文字、網(wǎng)址的信息,條碼都能提供可靠的支持。

1.2 條碼識別步驟

條碼碼識別主要通過兩個步驟完成:圖像捕捉和解碼。

圖像捕捉:使用設(shè)備攝像頭拍攝包含條碼的圖像。

解碼:軟件處理圖像,定位并讀取條碼中的數(shù)據(jù),轉(zhuǎn)換為原始信息。

常用工具如ZXing和ZBar提供了便捷的方法來集成條碼識別功能,使得開發(fā)者可以輕松實現(xiàn)從圖像捕捉到數(shù)據(jù)解碼的過程。用戶只需簡單操作即可快速獲取條碼中的信息,極大提高了效率和便利性。


2. C++ API文檔

2.1 Code128Detector類

2.1.1 頭文件

#include

作用:用于聲明Code128Detector類,使得Code128Detector類可以在當前源文件中使用。

2.1.2 構(gòu)造類對象

lockzhiner_vision_module::Code128Detectormodel;

作用:用于實現(xiàn)條碼識別。

參數(shù)說明:

返回值:

2.1.3 Predict函數(shù)

autoresults=model.Predict(input_mat);

作用:Code128Detector類中的一個函數(shù),用于實現(xiàn)條碼識別。

參數(shù)說明:

input_mat: 要識別的圖像。

返回值:

返回一個包含Code 128格式的條碼檢測結(jié)果的對象集合。每個Result對象包含條碼的位置信息和解碼后的文本內(nèi)容。

2.2 Visualize函數(shù)

2.2.1 頭文件

#include

作用:用于聲明Visualize函數(shù),使得Visualize函數(shù)可以在當前源文件中使用。

2.2.2 結(jié)果可視化

lockzhiner_vision_module::Visualize(input_image,output_image,
results);

參數(shù)說明:

input_image: 輸入?yún)?shù),表示原始輸入圖像。

output_image: 輸出參數(shù),用于存儲帶有可視化結(jié)果的輸出圖像。

results: 輸入?yún)?shù),表示條碼碼檢測的結(jié)果集。每個Result對象包含條碼的位置信息和解碼后的文本內(nèi)容。

返回值:


3. 綜合代碼介紹

3.1 流程圖

82eb8fd6-3a9a-11f0-986f-92fbcf53809c.png

3.2 核心代碼解析

初始化

lockzhiner_vision_module::Code128Detectormodel;
lockzhiner_vision_module::Editedit;

調(diào)用攝像頭捕獲圖像

cv::VideoCapturecap;
// 設(shè)置攝像頭獲取幀的寬高
cap.set(cv::CAP_PROP_FRAME_WIDTH,640);
cap.set(cv::CAP_PROP_FRAME_HEIGHT,480);
cap.open(0);

// wihile循環(huán)中的以下代碼用于捕獲圖像幀
cap>>input_mat;
if(input_mat.empty())
{
continue;
}

條碼檢測

autoresults=model.Predict(input_mat);

3.3 完整代碼實現(xiàn)

#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;
// 設(shè)置攝像頭獲取幀寬高
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 方法對輸入圖像進行預(yù)測,獲取條碼檢測結(jié)果
autoresults=model.Predict(input_mat);
// 獲取當前時間點作為結(jié)束時間
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;
// 調(diào)用 Visualize 函數(shù)對原始圖像和檢測結(jié)果進行可視化處理,并將結(jié)果存儲在 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. 編譯調(diào)試

4.1 編譯環(huán)境搭建

請確保你已經(jīng)按照開發(fā)環(huán)境搭建指南正確配置了開發(fā)環(huán)境。

同時以正確連接開發(fā)板。

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 容器并執(zhí)行以下命令來編譯項目

# 進入Demo所在目錄
cd/LockzhinerVisionModuleWorkSpace/LockzhinerVisionModule/Cpp_example/C07_test_bar_codeDetector
# 創(chuàng)建編譯目錄
rm-rfbuild &&mkdirbuild &&cdbuild
# 配置交叉編譯工具鏈
exportTOOLCHAIN_ROOT_PATH="/LockzhinerVisionModuleWorkSpace/arm-rockchip830-linux-uclibcgnueabihf"
# 使用cmake配置項目
cmake ..
# 執(zhí)行編譯項目
make-j8&&makeinstall

在執(zhí)行完上述命令后,會在build目錄下生成可執(zhí)行文件。


5. 例程運行示例

5.1 運行前準備

請確保你已經(jīng)參考凌智視覺模塊攝像頭部署指南正確下載了凌智視覺模塊圖片傳輸助手。

5.2 運行過程

在凌智視覺模塊輸入以下命令:

chmod777test-bar-codeDetector
./test-bar-codeDetector

5.3 運行效果

8310614e-3a9a-11f0-986f-92fbcf53809c.png

6. 總結(jié)

通過上述內(nèi)容,我們成功的實現(xiàn)了一個條碼識別系統(tǒng),包括:

- 獲取并加載包含code 128格式的條碼圖像。

- 進行條碼的檢測和解碼,返回檢測和解碼后的結(jié)果。

- 可視化包含條碼圖像的識別結(jié)果。


聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 視覺識別
    +關(guān)注

    關(guān)注

    3

    文章

    110

    瀏覽量

    17246
  • Lock
    +關(guān)注

    關(guān)注

    0

    文章

    11

    瀏覽量

    7987
  • 條碼識別
    +關(guān)注

    關(guān)注

    0

    文章

    38

    瀏覽量

    7416
  • AI視覺
    +關(guān)注

    關(guān)注

    0

    文章

    98

    瀏覽量

    4904
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    基于LockAI視覺識別模塊C++圖像采集例程

    本文主要演示如何使用LockAI視覺識別模塊進行視頻流的讀取,同時使用Edit模塊進行圖像傳輸。 例程源代碼地址:https://gitee
    發(fā)表于 04-30 10:52

    基于LockAI視覺識別模塊C++二維碼識別

    二維碼識別視覺模塊經(jīng)常使用到的功能之一。我們將演示如何使用基于瑞芯微RV1106的LockAI視覺識別
    發(fā)表于 05-26 09:57

    基于LockAI視覺識別模塊C++條碼識別

    條碼識別視覺模塊經(jīng)常使用到的功能之一,經(jīng)常用于識別超市的貨物信息。本文我們將演示如何基于瑞芯微RV1106的
    發(fā)表于 05-27 10:26

    基于LockAI視覺識別模塊C++目標檢測

    本文檔基于瑞芯微RV1106的LockAI凌智視覺識別模塊,通過C++語言做的目標檢測實驗。 本文檔展示了如何使用 lockzhiner_v
    發(fā)表于 06-06 14:43

    基于LockAI視覺識別模塊:手寫數(shù)字識別

    手寫數(shù)字識別是一種經(jīng)典的模式識別和圖像處理問題,旨在通過計算機自動識別用戶手寫的數(shù)字。 本文將教會你如何使用基于RV1106的 LockAI視覺
    發(fā)表于 06-30 16:45

    基于LockAI視覺識別模塊C++人臉識別

    本文基于RV1106做成的LockAI視覺識別模塊,采用 LZ-Picodet 模型訓(xùn)練的人臉檢測模型 LZ-Face,以及ArcFace人臉識別
    發(fā)表于 07-01 12:01

    GM65-S條碼識別模塊用戶手冊

    GM65-S條碼識別模塊
    發(fā)表于 01-22 14:23 ?0次下載

    基于LockAI視覺識別模塊C++圖像采集例程

    本文主要演示如何使用LockAI視覺識別模塊進行視頻流的讀取,同時使用Edit模塊進行圖像傳輸。基礎(chǔ)知識講解1.1OpenCV簡介OpenC
    的頭像 發(fā)表于 04-30 18:23 ?438次閱讀
    基于<b class='flag-5'>LockAI</b><b class='flag-5'>視覺</b><b class='flag-5'>識別</b><b class='flag-5'>模塊</b>:<b class='flag-5'>C++</b>圖像采集例程

    基于LockAI視覺識別模塊C++圖像的基本運算

    在圖像處理中,理解圖像的基本操作是掌握計算機視覺技術(shù)的關(guān)鍵。本文章將介紹基于LockAI視覺識別模塊下OpenCV中圖像的基本運算方法,包括
    的頭像 發(fā)表于 05-06 16:20 ?419次閱讀
    基于<b class='flag-5'>LockAI</b><b class='flag-5'>視覺</b><b class='flag-5'>識別</b><b class='flag-5'>模塊</b>:<b class='flag-5'>C++</b>圖像的基本運算

    基于LockAI視覺識別模塊C++使用圖像的統(tǒng)計信息

    在圖像處理中,統(tǒng)計信息可以幫助我們了解圖像的特性,例如區(qū)域內(nèi)的像素分布、顏色轉(zhuǎn)換以及特定區(qū)域的分析。本文將介紹基于LockAI視覺識別模塊如何提取興趣區(qū)域(ROI)、轉(zhuǎn)換顏色通道、計算
    的頭像 發(fā)表于 05-08 10:09 ?444次閱讀
    基于<b class='flag-5'>LockAI</b><b class='flag-5'>視覺</b><b class='flag-5'>識別</b><b class='flag-5'>模塊</b>:<b class='flag-5'>C++</b>使用圖像的統(tǒng)計信息

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

    在傳統(tǒng)計算機視覺場景中,顏色識別是目標檢測和分割的重要手段之一。通過識別特定顏色的色塊,可以在相對純凈的背景下快速定位目標區(qū)域。本實驗提供了一個簡單的色塊識別案例,并將其封裝為一個自定
    的頭像 發(fā)表于 05-12 14:27 ?393次閱讀
    # 基于<b class='flag-5'>LockAI</b><b class='flag-5'>視覺</b><b class='flag-5'>識別</b><b class='flag-5'>模塊</b>:<b class='flag-5'>C++</b>尋找色塊

    基于LockAI視覺識別模塊C++二維碼識別

    二維碼識別視覺模塊經(jīng)常使用到的功能之一。我們將演示如何使用基于瑞芯微RV1106的LockAI視覺識別
    的頭像 發(fā)表于 05-26 09:42 ?544次閱讀
    基于<b class='flag-5'>LockAI</b><b class='flag-5'>視覺</b><b class='flag-5'>識別</b><b class='flag-5'>模塊</b>:<b class='flag-5'>C++</b>二維碼<b class='flag-5'>識別</b>

    基于LockAI視覺識別模塊C++目標檢測

    本文檔基于瑞芯微RV1106的LockAI凌智視覺識別模塊,通過C++語言做的目標檢測實驗。本文檔展示了如何使用lockzhiner_vis
    的頭像 發(fā)表于 06-06 13:56 ?437次閱讀
    基于<b class='flag-5'>LockAI</b><b class='flag-5'>視覺</b><b class='flag-5'>識別</b><b class='flag-5'>模塊</b>:<b class='flag-5'>C++</b>目標檢測

    基于LockAI視覺識別模塊:手寫數(shù)字識別

    手寫數(shù)字識別是一種經(jīng)典的模式識別和圖像處理問題,旨在通過計算機自動識別用戶手寫的數(shù)字。本文將教會你如何使用基于RV1106的LockAI視覺
    的頭像 發(fā)表于 06-30 15:44 ?698次閱讀
    基于<b class='flag-5'>LockAI</b><b class='flag-5'>視覺</b><b class='flag-5'>識別</b><b class='flag-5'>模塊</b>:手寫數(shù)字<b class='flag-5'>識別</b>

    基于LockAI視覺識別模塊C++人臉識別

    本文基于RV1106做成的LockAI視覺識別模塊,采用LZ-Picodet模型訓(xùn)練的人臉檢測模型LZ-Face,以及ArcFace人臉識別
    的頭像 發(fā)表于 07-01 10:09 ?364次閱讀
    基于<b class='flag-5'>LockAI</b><b class='flag-5'>視覺</b><b class='flag-5'>識別</b><b class='flag-5'>模塊</b>:<b class='flag-5'>C++</b>人臉<b class='flag-5'>識別</b>