目标
这个教程包含以下内容:
- 在安装了Xcode的macOS系统上,透过homebrew安装OpenCV库;
- 在Xcode上调用OpenCV库;
- 尝试用C语言而非C++写第一个OpenCV 2.7程序。
工具
完成该教程应当事先准备:
- 安装了Xcode 10以上版本的Mac;
- 安装homebrew,请参看:
Mac安装homebrew详细教程;及
将Homebrew软件源调至在中国能迅速访问的源; - 可使用的Internet连接。
注明
本教程:
- 使用OpenCV 2.x版本,不使用3.x、4.x版本;
- 使用C语言调用OpenCV库,而一概不用C++、Python等其他语言。
步骤
1. 从homebrew上下载OpenCV
- 安装wget。键入如下命令:
brew install opencv
- 安装cmake。键入如下命令:
brew install cmake
- 最后,安装opencv。键入如下命令:
brew install opencv@2
请注意:opencv后面的@2,代表安装的是2.x版本的。如果没有加这个@2,brew将会去安装最新版本。这个版本对C语言支持较好,与本教程的目标相符合。
brew将自动检测安装OpenCV所需的依赖,在安装OpenCV之前,会自动将依赖一并安装完毕。
2. 明确安装到的目录
一般情况下,OpenCV安装的位置为 :/usr/local/Cellar/opencv@2。在安装目录下存在如下文件和资料夹:
3. 配置Xcode以调用库
-
在Xcode中新建一个C的命令行项目,如下图所示。
-
为项目添加头文件和库搜索目录。打开Build Settings,找到Header Search Paths及Library Search Paths。
在Header Search Paths中加入如下一行(注意勾选recursive):
并将
(1) /usr/local/lib;及
(2) /usr/local/Cellar/opencv@2/2.4.13.7_7/lib
按照上面一样加入库搜索目录(Library Search Paths)。 -
回到工程,新建一个group(命名随意),用来放依赖的动态库文件。
-
然后将/usr/local/Cellar/opencv@2/2.4.13.7_7/lib中,不是替身的文件(左下角没有箭头的文件)全部拉进这个group中去。不用复制。
4. 测试配置情况
若完成上述步骤且并无报错,OpenCV应当已经配置完成。
在main.c中键入如下代码:
#include <stdio.h>
#include <cv.h>
#include <highgui.h>
int main(int argc, char* argv[]) {
IplImage* pImg; // OpenCV图像对象
if( argc == 2 && (pImg = cvLoadImage( argv[1], 1)) != 0 ) {
// 用cvLoadImage(xxx, 1);输入一个图像
cvNamedWindow( "Image", 1 ); // 新建一个名为Image的视窗
cvShowImage( "Image", pImg ); // 展示pImg图像
cvWaitKey(0); // 等待按任意键以继续
cvDestroyWindow( "Image" ); // 关闭视窗
cvReleaseImage( &pImg ); // 很重要!删除读入的图像,以释放内存
return 0;
}
return -1; // 若开启失败(pImg = NULL)
}
可编译成功。运行时可以传递参数打开一个.png图像文件。
[完]