OpenCV 3.2.0 + opencv_contrib+VS2017

简介: OpenCV 3.2.0 + opencv_contrib+VS2017

OpenCV 3.2.0 + opencv_contrib+VS2017


首先本文假定你的电脑已经配置好了OpenCV3.2.0,并且想要在此基础上,添加opencv_contrib。在学习图像识别中的特征点检测和匹配时,需要用到一些常用的算法如FREAK、Surf和Sift算法等,但从OpenCV3以后,这些常用的算法OpenCV的Release版本中并不存在,因为他们是存放在opencv_contrib目录下面的未稳定功能模块,所以如果我们想要使用这些功能,需要自己下载代码并且自行编译。

首先需要有OpenCV的源码,可以通过在官网下载exe文件自动解压得到。本文章,OpenCV源码解压到E:/OpenCV/opencv/目录中。

1 下载OpenCV_contrib

前往https://github.com/opencv/opencv_contrib根据自己的OpenCV版本,下载对应的contrib。本文针对的是OpenCV3.2.0,因此,选择下载3.2.0版本即可。

image.png本文将openCV_contrib放入到目录:E:\OpenCV\opencv_extra中。

2 下载CMake(GUI),并完成配置

前往https://cmake.org/download/下载最新版本的CMake,当前最新版本为cmake-3.9.0-win64-x64.msi。安装结束后,打开,在where is the source code中选择openCV的源代码目录:E:/OpenCV/opencv/sources。在where to build the binaries中选择编译为Visual Studio项目的目录,可以随意选择一个空目录,这里我选择了D:/VSProject。如下图所示:

image.png

点击Configure按钮后,弹出对话框,选择编译器,根据本地计算机的CPU架构,选择32位或64位编译。本文选择Win64.如下图:

image.png

接下来完成配置后,会出现红色区域,里面是键值对配置文件。找到OPENCV_EXTRA_MODULES_PATH项,填入opencv_contrib目录下的modules文件夹路径,即:E:\OpenCV\opencv_extra\modules,如下图所示。其他地方不要轻易改动,除非你理解具体含义,否则可能会带来很多意想不到的问题。

image.png

接下来,点击Generate按钮,生成VS项目。注意,生成的这个VS项目主要是用来编译生成我们需要的库。完成后如下图所示:

image.png

此时,在D:/VSProject目录中,生成了很多文件,我们打开OpenCV.sln文件即可。

注意,在配置和生成项目过程中,可能会因为网络原因,无法下载到protobuf-cpp-3.1.0.tar.gz文件,从而报错。可以自己前往https://github.com/google/protobuf/releases中找到对应版本下载后,放入到E:\OpenCV\opencv_extra\modules\dnn\3rdparty\protobuf目录中。或者放入E:\OpenCV\opencv_extra\modules\dnn\.download\bd5e3eed635a8d32e2b99658633815ef\v3.1.0目录中,其中一串很长的MD5码目录根据每个人的机器可能会不同。

3. 编译VS,生成库

打开VS项目后,在Debug模式下。在INSTALL上 点击右键->生成。如下图所示。

image.png

完成编译后,Release模式下同理。此时,有了D:\VSProject\install目录。该目录包含了我们需要的头文件、库文件。

将D:\VSProject\install\x64\vc15\bin下的所有dll文件copy到C:/Windows/system32目录下。下面就可以开始使用了….

4. 使用

使用很简单,在VC++目录下的包含目录中,将D:\VSProject\install\include、D:\VSProject\install\include\opencv、D:\VSProject\install\include\opencv2加入。同时,在库目录中,将D:\VSProject\install\x64\vc15\lib加入。另外,如果需要,步骤1中的<opencv_home>/build/x64/vc14/lib也可以加入。

连接器》输入》附加依赖项中,根据需要,加入对应的库。但是opencv_world320d.lib是必须的。例如,为了使用FREAK算法,我还需要加入opencv_xfeatures2d320d.lib。

相关文章
|
6月前
|
算法 测试技术 计算机视觉
Opencv(C++)系列学习---opencv_contrib安装
Opencv(C++)系列学习---opencv_contrib安装
207 0
|
6月前
|
算法 计算机视觉 C++
[OpenCV3.0] 编译opencv_contrib模块
[OpenCV3.0] 编译opencv_contrib模块
75 0
|
数据安全/隐私保护
win10+vs2013+opencv3.2+opencv_contrib+cmake树莓派通用亲测安装包
win10+vs2013+opencv3.2+opencv_contrib+cmake树莓派通用亲测安装包
|
27天前
|
计算机视觉
Opencv学习笔记(三):图像二值化函数cv2.threshold函数详解
这篇文章详细介绍了OpenCV库中的图像二值化函数`cv2.threshold`,包括二值化的概念、常见的阈值类型、函数的参数说明以及通过代码实例展示了如何应用该函数进行图像二值化处理,并展示了运行结果。
246 0
Opencv学习笔记(三):图像二值化函数cv2.threshold函数详解
|
2月前
|
算法 计算机视觉
opencv图像形态学
图像形态学是一种基于数学形态学的图像处理技术,它主要用于分析和修改图像的形状和结构。
45 4
|
2月前
|
存储 计算机视觉
Opencv的基本操作(一)图像的读取显示存储及几何图形的绘制
本文介绍了使用OpenCV进行图像读取、显示和存储的基本操作,以及如何绘制直线、圆形、矩形和文本等几何图形的方法。
Opencv的基本操作(一)图像的读取显示存储及几何图形的绘制
|
3月前
|
算法 计算机视觉 Python
python利用opencv进行相机标定获取参数,并根据畸变参数修正图像附有全部代码(流畅无痛版)
该文章详细介绍了使用Python和OpenCV进行相机标定以获取畸变参数,并提供了修正图像畸变的全部代码,包括生成棋盘图、拍摄标定图像、标定过程和畸变矫正等步骤。
python利用opencv进行相机标定获取参数,并根据畸变参数修正图像附有全部代码(流畅无痛版)
WK
|
3月前
|
编解码 计算机视觉 Python
如何在OpenCV中进行图像转换
在OpenCV中,图像转换涉及颜色空间变换、大小调整及类型转换等操作。常用函数如`cvtColor`可实现BGR到RGB、灰度图或HSV的转换;`resize`则用于调整图像分辨率。此外,通过`astype`或`convertScaleAbs`可改变图像数据类型。对于复杂的几何变换,如仿射或透视变换,则可利用`warpAffine`和`warpPerspective`函数实现。这些技术为图像处理提供了强大的工具。
WK
102 1
|
5月前
|
算法 计算机视觉
【Qt&OpenCV 图像的感兴趣区域ROI】
【Qt&OpenCV 图像的感兴趣区域ROI】
151 1