1. 方案簡介
本方案將演示如何利用EASY-EAI-Orin-Nano以及MIPI-CSI攝像頭制作一個【網絡攝像頭(IPCamera)】:四路MIPI-CSI攝像頭分別單獨輸出四路流。
1.1 接線示意圖
攝像頭與板卡連接:
板卡與局域網連接:
* 接線必須在斷電時進行操作。
* 采用反向線連接IMX415攝像頭與Cmaera1接口。(注意:用錯線會燒壞攝像頭或者核心板,因此在接線時務必要小心。)
* 接線端子卡扣與FPC線的藍色塑料標識必須位于同一側。如下圖所示。
EASY EAI Orin-Nano默認搭配IMX415單目攝像頭。同時配有一根0.5mm間距的40pin FPC反向線。
反向線:兩端的藍色標識不在同一側面。
同向線:兩端的藍色標識處于同一側面。
2.快速上手
如果您初次閱讀此文檔,請閱讀:《入門指南/源碼管理及編程介紹/源碼工程管理》,按需管理自己工程源碼(注:此文檔必看,并建議采用【遠程掛載管理】方式,否則有代碼丟失風險!!!)。
2.1 源碼工程下載
先在PC虛擬機定位到nfs服務目錄,再在目錄中創建存放源碼倉庫的管理目錄:
cd ~/nfsroot mkdir GitHub cd GitHub
再通過git工具,在管理目錄內克隆遠程倉庫(需要設備能對外網進行訪問)
git clone https://github.com/EASY-EAI/EASY-EAI-Toolkit-3576.git
注:
* 此處可能會因網絡原因造成卡頓,請耐心等待。
* 如果實在要在gitHub網頁上下載,也要把整個倉庫下載下來,不能單獨下載本實例對應的目錄。
2.2 開發環境搭建
通過adb shell進入板卡開發環境,如下圖所示。
通過以下命令,把nfs目錄掛載上nfs服務器。
mount -t nfs -o nolock : /home/orin-nano/Desktop/nfs/
2.3 例程編譯
然后定位到nfs的掛載目錄,再在目錄中創建存放源碼倉庫的管理目錄:
cd /home/orin-nano/Desktop/nfs/GitHub
進入到對應的開發實例目錄執行編譯操作,具體命令如下所示:
cd EASY-EAI-Toolkit-3576/Solutions/rtspIPCamera/ ./build.sh
2.4 例程運行及效果
執行下方命令,運行示例程序:
./Release/rtspIPCamera
執行效果如下所示。
2.5 非本地rtsp拉流
如果需要使用另一臺計算機設備作為rtspClinet去拉流,則需要把127.0.0.1(本機IP)替換成rtspServer設備所在局域網的IP地址,具體操作如下。
首先通過ifconfig命令查看板卡的局域網IP地址。
sudo ifconfig
然后在另外一臺計算機開啟rtspClinet應用(以VLC為例),填上URL進行拉流。
3. 設計說明
3.1 總體邏輯框圖
3.2 factory邏輯
3.3 代碼組成
本開發實例相關的所有代碼,均位于EASY-EAI-Toolkit-3576/Solutions/rtspIPCamera/中。其中:
總體邏輯位于:EASY-EAI-Toolkit-3576/Solutions/rtspIPCamera/src/main.cpp
factory邏輯位于:EASY-EAI-Toolkit-3576/Solutions/rtspIPCamera/src/appSource.cpp
攝像頭控制邏輯位于:EASY-EAI-Toolkit-3576/Solutions/rtspIPCamera/src/camera/
3.4 調用關系
4. 開發指南
4.1 Toolkit倉庫介紹
4.2 示例文件&目錄結構
4.2.1 開發實例介紹
每個開發實例就是一個獨立的項目,項目使用cmake構建自動編譯部署。一個最簡單的項目至少要包含以下元素:build.sh、CMakeLists.txt、main.c,如下所示。
具體介紹如下所示。
組成部分 | 描述 |
build.sh | 編譯腳本,用于管理生成可執行文件后的部署準備工作,用戶可自定義shell命令 |
CMakeLists.txt | 工程管理文件,用于組織整個工程結構,指導cmake生成Makefile |
include | 用于存放第三方應用庫、頭文件目錄等 |
src | 用于存放實現本方案需求的源代碼 |
4.2.2 可拓展的目錄
可拓展的目錄是指:開發過程中增加某些功能模塊,功能代碼。增加模式分為兩種:
增加已編譯的第三方庫,在include、libs目錄內添加頭文件和庫文件;
增加用戶自定義的功能模塊,推薦在src目錄內增加;
具體情況如下所示,第三方模塊相關的文件由include/3rd_model/xxx.h、libs/3rd_model/xxx.a。自定義的功能模塊為src/mySrcCode、src/mySrcCode2。
4.3 CMakeLists.txt文件解析
4.3.1 編譯環境配置部分:
第一部分為配置部分,配置部分如下所示。(獲取當前方案目錄、配置工具鏈、提取方案名稱):
配置信息如下所示。
配置項 | 描述 |
CMake要求版本 | cmake_minimum_required函數指定,要求的最低版本 |
CMAKE_SYSTEM_NAME | cmake的系統類型,交叉編譯必須 |
CMAKE_CROSSCOMPILING | cmake是否啟動交叉編譯 |
cross.camke | camke_host_system_information獲取平臺信息,發現不是armv7l或者aarch64就導入當前平臺的交叉編譯配置。 |
project項目名 | 由project函數指定 |
4.3.2 easyeai-api配置部分
第二部分是引入我司的功能組件庫(針對當前方案進行:配置EASY EAI API頭文件目錄${XXX_INCLUDE_DIRS}、源碼文件目錄${XXX_SOURCE_DIRS}以及所依賴的庫參數${XXX_LIBS}):
配置信息如下所示。
配置項 | 描述 |
api_inc | 最終通過target_include_directories關鍵字指定目標包含的頭文件路徑 |
api_srcs | 最終通過add_executable關鍵字指定所需easyeai-api的源碼 |
sysLib_list | 最終通過target_link_libraries關鍵字指定easyeai-api所需的庫參數 |
4.3.3 第三方庫配置部分
第三部分配置第三方的庫(針對當前方案進行:配置第三方頭文件目錄、庫文件目錄、配置第三方庫鏈接參數以及配置源碼目錄):
配置信息如下所示。
配置項 | 描述 |
custom_inc | 自定義變量custom_inc,最終通過target_include_directories函數指定目標包含的頭文件路徑,在源碼include目錄下 |
link_directories | 由link_directories函數指定第三方庫所在路徑 |
custom_libs | 自定義變量custom_libs,最終通過target_link_libraries函數指定目標引用的庫鏈接參數 |
aux_source_directory | 自定義變量dir_srcs,用于添加工程代碼以及自定義的個人代碼 |
例如添加個人庫的目錄組成方式如下所示。
aux_source_directory的修改方式為:
aux_source_directory(./src ./src/mySrcCode ./src/mySrcCode2 dir_srcs)
或
aux_source_directory(./src dir_srcs) aux_source_directory(./src/mySrcCode dir_srcs) aux_source_directory(./src/mySrcCode2 dir_srcs)
4.3.4 本方案配置部分
第四部分配置項目的編譯信息,內容如下所示:
配置項如下所示。
配置項 | 需求 |
add_executable |
編譯結果為${CURRENT_FOLDER}指定,即方案目錄名; 編譯的源文件為${dir_srcs}和${api_srcs}指定; |
target_include_directories | 指定頭文件的名字,由${custom_inc}與${api_inc}指定; |
target_link_libraries | 指定的庫編譯參數,由${custom_libs}與${sysLib_list}指定; |
4.4 build.sh編譯腳本:
4.4.1 路徑定位部分
第一部分用于提取目錄用于編譯操作,內容如下所示:(進入build.sh腳本所在目錄,并且提取當前目錄絕對路徑,提取當前目錄名稱)
4.4.2 清除編譯部分
第二部分清除操作,清除目錄為build、Release,內容如下所示:(執行build.sh腳本時,帶入了參數“clear”,則清空編譯輸出)
4.4.3 編譯操作
第三部分,編譯直接調用cmake,內容如下所示:(重新編譯,成部署目錄,并把資源自動部署進板卡)
審核編輯 黃宇
-
開發板
+關注
關注
25文章
5530瀏覽量
102349 -
rk3576
+關注
關注
1文章
145瀏覽量
563
發布評論請先 登錄
基于RK3576開發板的MIPI-DSI使用

評論