基於 Xcode 搭建 OpenCV 開發環境

来源:https://www.cnblogs.com/CharminZh/archive/2022/04/28/16203023.html
-Advertisement-
Play Games

如何基於Xcode搭建OpenCV開發環境 我的開發平臺是MacBook Pro (13-inch, M1, 2020),版本11.4,碩士課題是關於電腦視覺的,平時主要用Clion/PyCharm基於opencv-python/C++進行開發。近期閑來沒事體驗一下蘋果官方的開發工具,由於遇到了一 ...


如何基於Xcode搭建OpenCV開發環境

我的開發平臺是MacBook Pro (13-inch, M1, 2020),版本11.4,碩士課題是關於電腦視覺的,平時主要用Clion/PyCharm基於opencv-python/C++進行開發。近期閑來沒事體驗一下蘋果官方的開發工具,由於遇到了一些坑,網上的資料也不是很多,因此決定記錄一下配置過程。

相應工具的安裝

Xcode-13

有兩種安裝方法:

  1. (推薦)在App Store中安裝Xcode,直接安裝就行,省心省事;
  2. 登錄Apple Id開發者賬號,在官方網站進行下載,註意系統版本要對應支持的版本;

Homebrew

HomebrewMac上的包管理工具,可以複製以下代碼,直接在終端中安裝。

/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"

OpenCV

完成了Homebrew的安裝,只需要通過brew命令即可安裝openCV,由於自己編譯OpenCV可能會出現很多問題,因此推薦通過用這種方法來安裝。

brew install opencv

安裝完成後,要記錄一下你的OpenCV安裝路徑,如下圖所示,我的OpenCV的安裝路徑是:

/opt/homebrew/Cellar/opencv/4.5.3_2
image-20220428144209309

pkg-config

pkg-config是在編譯應用程式和庫時使用的輔助工具,可以幫助我們找到找到正確的OpenCV 鏈接器符號 (Linker Flags) ,在後續的步驟中會用到。 安裝pkg-config,也只需要在終端輸入以下命令

brew install pkg-config

配置Xcode

6.創建Xcode項目

在配置OpenCV環境之前,我們首先要新建一個C++項目,如圖所示,選擇macOS -> Command Line Tool

image-20220428144440033

併在下一步中的編程語言中選擇:C++

image-20220428144456538

使用pkg-config查看OpenCV的編譯依賴

查看您的opencv.pc文件所在位置,一般opencv.pc文件所在位置為

/opt/homebrew/Cellar/opencv/<版本號>/lib/pkgconfig/

如筆者的版本為4.5.3_2opencv.pc現已改為opencv4.pc(不同電腦可能有所不同,讀者可以cd到相應文件目錄查看具體信息)

/opt/homebrew/Cellar/opencv/4.5.3_2/lib/pkgconfig/opencv4.pc

使用下麵的命令查看OpenCV的鏈接器符號 (Linker Flags) ,筆者的代碼為

pkg-config --cflags --libs /opt/homebrew/Cellar/opencv/4.5.3_2/lib/pkgconfig/opencv4.pc

你會得到類似於如下的輸出結果,我們需要參照輸出結果在 Xcode 中進行配置

-I/opt/homebrew/opt/opencv/include/opencv4 -L/opt/homebrew/opt/opencv/lib -lopencv_gapi -lopencv_stitching -lopencv_alphamat -lopencv_aruco -lopencv_barcode -lopencv_bgsegm -lopencv_bioinspired -lopencv_ccalib -
...(後續省略)

設置Header Search Paths

在 Xcode 中設置 Header Search Paths,先單擊 Xcode 項目,然後點擊 Build Settings,然後搜索Header Search Paths。將 Header Search Paths 路徑設置為剛纔得到的輸出結果“-I”之後的路徑,如我需要對如下路徑進行添加。

/opt/homebrew/opt/opencv/include/opencv4
image-20220428150736979

設置 Library Search Paths

類似地,在 Build Settings 中搜索Library Search Paths,將 Library Search Paths路徑設置為剛纔得到的輸出結果“-L”之後的路徑,如我需要對如下路徑進行添加。註意,請將Lib目錄手動拖動到最上頭

/opt/homebrew/opt/opencv/lib
image-20220428150750424

設置Linker Flags

將上述pkg-config --cflags --libs .../opencv4.pc導出的一長串信息全部複製下來,添加到如下所示的框框里。

image-20220428150519963

測試

配置到這一步 Xcode 相關內容已經結束。可以嘗試運行簡單的OpenCV程式判斷是否能夠正常運行,以下給出簡單的示常式序,功能僅為打開圖片與退出。

#include <opencv2/core.hpp>
#include <opencv2/highgui.hpp>
#include <iostream>
#include <unistd.h>

using namespace cv;
using namespace std;

int main( int argc, char** argv ) {
    printf("Hello, world!");	// 手工斷點/doge
  
    char buf[200];
    getcwd(buf,sizeof(buf));
    printf("current working directory: %s\n", buf);	// 測試當前工作目錄
  
    Mat image;
    image = imread("test.png", IMREAD_COLOR);	// 註意圖片的路徑
    
    if(! image.data ) {	// 養成良好工作習慣
        cout <<  "Could not open or find the image" << std::endl;
        return -1;
    }
  
    imshow( "Display window", image);
    waitKey(0);
    return 0;
}

運行結果展示:

image-20220428151225907

其它設置

使用相對路徑

image-20220428151455058

Xcode使用圖像或資源的絕對路徑。為了設置相對路徑需要設置Working Directory。依次點擊

(菜單欄) Product > Scheme > Edit Scheme 
			|->	Run -> option -> ✅ Use Custom Working Directory

然後自定義項目目錄。

image-20220428151550616

常見錯誤

Not a Doxygen trailing comment

image-20220428151644355

Build Settings 中搜索 “Documentation Comments”,將 Documentation Comments 設置為 No即可解決該問題。Doxygen 只是一種格式可以選擇跳過檢查。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 上次說為了不想在web端登錄博客園,我想著還是繼續使用MarkWord編寫博客,不過在使用的過程中,如果markdown文件的目錄中有中文的話,Markdown預覽就不能夠顯示粘貼的圖片了,原因是之前.NET Framework的WeBrowser庫太老了,應該升級一下。 替換WebBrowser的 ...
  • 一、C#代碼實現 本案例使用的是c# winform .NET Framework 4.7.2 首先我們聲明一個尋找窗體的函數 [DllImport("User32.dll", EntryPoint = "FindWindow")] public static extern IntPtr FindW ...
  • 理解路由事件 事件路由允許源自某個元素的事件由另一個元素引發。 定義、註冊和包裝路由事件 public class MyWindow : Window { /// <summary> /// 定義和註冊路由事件 /// </summary> public static readonly Routed ...
  • 由於經常需要進行報表導出的操作,但有時候數據量比較大,趁手的工具不是收費就是學習使用也比較花費時間成本,所以找了些庫進行簡單的整合,能夠滿足需求,百萬條數據幾分鐘即可導出,效率也能滿足要求,所以將就著用 數據讀取處理 public class DBConnectFactory { public co ...
  • 在使用.Net 6開發程式時,發現多了很多新的警告類型。這裡總結一下處理方法。 CS8618 在退出構造函數時,不可為 null 的 屬性“Name”必須包含非 null 值 經常遇到的有CS8618警告:如果定義屬性可能為空時,在編譯時會報這個警告,比如下麵的代碼: public class Pl ...
  • 前言 本文主要介紹ArcGis的ArcEngine開發,學習時,我們需要放下心裡障礙,那就是Gis開發只是普通的軟體開發,並不需要專業的GIS知識,就是非常普通的,調用相關的C++開發的COM組件。 開發環境:VS2017。 ArcEngine版本:10.1。 基礎學習 正式使用ArcGis之前,需 ...
  • 本文詳細的講解了FFT的實現,簡直是手把手了。我也是慢慢學過來的,知道網上的教程對於初學者不是很友好,所以決定自己寫一份博客來記錄下來我的經驗 ...
  • 本文例子參考《STM32單片機開發實例——基於Proteus虛擬模擬與HAL/LL庫》 源代碼:https://github.com/LanLinnet/STM33F103R6 項目要求 實現流水燈效果。 硬體設計 在第一節的基礎上,在Proteus中添加電路如下圖所示,其中我們添加了一個排阻RX8 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...