在计算机视觉和图像处理领域,OpenCV 是一个不可或缺的工具。其为开发者提供了一系列广泛的算法和实用工具,支持多种编程语言,并且可以在多个平台上运行。对于希望在其项目中集成先进视觉功能的开发者来说,掌握如何配置和使用OpenCV是非常重要的。

本文旨在帮助Windows平台上的C++开发者快速上手,在CLion集成开发环境中配置并使用OpenCV库。通过遵循本文档中的步骤,读者将学习到如何编译、配置适用于MinGW的OpenCV版本,并最终在CLion中创建一个简单的OpenCV项目。

一、下载OpenCV

OpenCV官方下载Windows版本的OpenCV安装包: https://opencv.org/releases/

二、解压OpenCV

双击opencv-4.10.0-windows.exe解压到一个自定义的目录,这里我解压到了D盘目录下。

解压中效果如下图所示。

解压完成后,可以看到包含两个文件夹,一个是build,一个是sources。

build文件夹是编译好的OpenCV MSVC版(对应开发工具为VS2022)sources文件夹是opencv的源码

所以,如果我们要使用CLion开发OpenCV,需要使用MinGW工具,自行进行编译。

这里关于MSVC版 和MinGW版编译包,进行一个简单的介绍说明:

MSVC版: OpenCV 文件夹会有 build(已编译好的库)和sources(源码) 使用 MSVC 的话,直接在将D:\Program\opencv\build\x64\vc16配置到路径即可使用;MinGW版:OpenCV 没有为我们编译好 MinGW 版,所以只能用户自行编译。

三、编译OpenCV

编译OpenCV需要用到Mingw编译器和Cmake工具,关于这两个工具的下载与安装,这里不进行详细介绍,请大家自行搜索并安装。

下边我们介绍,用Cmake工具与Mingw编译器,如何编译opencv:

在opencv文件夹下,创建一个新的mingw-build文件夹用于存放编译后的内容。

2. 找到本地电脑的cmake安装目录,找到其CMake\bin目录下的cmake-gui.exe

上方选择source为opencv下的source文件夹 ;下方选择刚刚建立的mingw bulid文件夹;点击下方的Configure按钮,并选择类型为MinGW Makefiles,后点击Finish 。

第一次编译后,会出现很多红色的这里不用担心。

再次点击Configure之后红色就会消失。

最后,点击Generate。

到这里Cmake就可以关掉了。

下边,我们打开CMD命令行,cd到opencv\mingw-build文件夹, 输入mingw32-make -j16命令。

这里的j16是指使用16核加速编译,如果电脑核心多的话可以增加或减少。

最后执行mingw32-make install命令,将刚刚编译的文件整合到一起。 install:告诉make工具执行Makefile中名为install的规则。通常情况下,install规则会负责将编译好的二进制文件、库文件、头文件以及其他资源复制到系统的合适位置,以便其他程序能够找到并使用它们。例如,可执行文件可能会被复制到/bin,而头文件可能会被复制到/include。

最后,将D:\Program\opencv\mingw-build\bin路径添加到环境变量中。

四、创建

打开Clion工具,新建C++项目,编写以下代码:

CMakeCache.txt

# 指定CMake最低版本要求,确保使用了至少3.23版本的CMake。

cmake_minimum_required(VERSION 3.23)

# 定义项目名称为CLion_OpenCV_Demo,并设置使用的默认语言(如果需要)。

project(CLion_OpenCV_Demo)

# 设置C++编译标准为C++14。

set(CMAKE_CXX_STANDARD 14)

#OpenCV

# 设置OpenCV_DIR变量,指向OpenCV构建目录下的bin文件夹路径,

set(OpenCV_DIR "D:/Program/opencv/mingw-build/bin")

# 尝试查找系统中安装的OpenCV库。REQUIRED选项表示如果找不到OpenCV,则停止配置过程并抛出错误。

find_package(OpenCV REQUIRED)

# 将OpenCV的头文件目录添加到当前项目的编译指令中,使得源代码可以包含OpenCV的头文件。

include_directories(${OpenCV_INCLUDE_DIRS})

# 添加链接器搜索路径,即OpenCV库文件所在的目录。

link_directories(${OpenCV_LIBRARY_DIRS})

# 定义可执行文件名和它的源文件列表。这里只有一份源文件main.cpp。

add_executable(CLion_OpenCV_Demo main.cpp)

# 链接目标可执行文件与OpenCV库,使得在链接阶段会将指定的OpenCV库链接到最终的可执行文件中。

target_link_libraries(CLion_OpenCV_Demo ${OpenCV_LIBS})

main.cpp

#include

#include

using namespace std;

using namespace cv;

int main() {

// 使用imread函数从文件路径加载图像到Mat对象中

Mat img = imread("../android.png");

// 检查是否成功加载了图像。如果img为空,则表示加载失败。

if (img.empty()) {

cout << "Error" << endl;

return -1;

}

// 使用imshow函数创建一个窗口,并在其中显示名为"Lena"的图像。

imshow("Lena", img);

// 等待用户按键事件。没有参数时会无限期等待直到任意键被按下。

// 这个调用也防止了显示窗口立即关闭。

waitKey();

return 0;

}

运行程序,输出如下UI界面,代表CLion运行OpenCV成功。

五、参考

Clion使用OpenCV环境配置 https://www.jianshu.com/p/4f5d372e3927

WIN10+CLion+Opencv配置教程 https://blog.csdn.net/DeepLearningJay/article/details/120214602