OpenCV简介及安装

13 篇文章 0 订阅
7 篇文章 0 订阅

前言

因为最近想做图像处理、人脸检测/识别之类的相关开发,所以就开始补OpenCV的相关知识,便开个专栏用于记录学习历程和在学习过程中遇到的一些值得注意的重点和坑。

学习过程基本上也是面向官方文档和Google。

简介

OpenCV(开源的计算机视觉库)是基于BSD协议,因此它可免费用于学术和商业用途。

其提供C++,C,Python和Java接口,支持Windows,Linux,Mac OS,iOS和Android。

OpenCV致力于高效运算和即时应用开发。因其是用优化的C/C++编写的,故其可以充分利用多核处理优势。

并且还启用了OpenSL,它可以利用底层异构计算平台的硬件加速。

广泛运用在世界各地,OpenCV拥有超过4.7万人的用户社区和超过1400万的下载次数。

从互动艺术、矿山检查、网络地图到先进的机器人技术都有OpenCV的身影。

它包含了数百个计算机视觉算法。它有一个模块化的结构,囊括了几个共享的或静态的库,其中包括:

  • Core functionality(核心功能):一个简洁基本且模块化的数据结构,包含了多维数组(矩阵)和用于其他模块的基本功能。

  • Image processing(图像处理):包括线性和非线性的图像滤波、几何图像转换(缩放、仿射和透视调整)、颜色模式转换、直方图等等。

  • Video(视频):一个视频分析模块,其包含了运动估计、背景消除和目标跟踪算法。

  • Calib3d:提供基本的多视图几何算法、平面和立体影像校正、物体定位、立体通信算法和三维重建。

  • Features2d:显著特征探测器、描述符和描述符匹配器。

  • Objectect:检测对象和预定义的类的实例(例如:脸部、眼睛、杯子、人、车等等)。

  • Highgui(图形界面):提供一个简单易用的UI。

  • Video I/O:提供一个简单易用的视频捕获和编码解码界面。

  • GPU:来自于不同的OpenCV模块的GPU加速算法。

  • ......一些其他的辅助模块,例如FLANN(神经网络)和Google测试封装、Python绑定等等。

下面来讲一下OpenCV的下载和安装(C++和Python3 API)。

C++

先从官网上下载好文件包:Releases - OpenCV library

https://link.zhihu.com/?target=https%3A//opencv.org/releases.html

建议选择最新的3.3.1 Win Pack。

图片

下载好后,双击运行exe程序解压,选择一个解压后的目录。

(其会自动生成一个opencv目录,不需要单独再创一个opencv目录。另,不建议将其解压到C盘根目录下的Program Files或Program File (x86)目录下,可能会因系统权限导致各种问题)

图片

解压完毕后,将其写入系统的环境变量中,向Path中添加一条:"解压后opencv所在的文件夹目录\opencv\build\x64\vc14\bin",

例如我将其解压在C:\Leon下,则添加:C:\Leon\opencv\build\x64\vc14\bin。

图片

这样OpenCV3.3.1就算安装好了,接下来就在自己IDE中配置一下就行。

例如我C++开发环境是Visual Studio 2017,相应的项目创建配置流程如下:

1. 打开Visual Studio,新建一个项目(快捷键Ctrl+Shift+N),项目名自取,选择好创建目录。

图片

第一步图

2. 新建一个C++文件(快捷键Ctrl+Shift+A)。

图片

第二步图

3. 将菜单栏下的Debug后的x86改为x64。

图片

第三步图

4. 单击右侧窗口的Property Manager(属性管理),或者点击菜单栏中的View(视图)->Other Windows(其他窗口)->Property Manager(属性管理)。

图片

第四步图

5. 右键属性管理窗口中的Debug | x64,选择Property(属性),编辑包含目录。

图片

第五步图

6. 添加三个目录路径并确定。(注意路径是你opencv安装的路径)

图片

第六步图

7. 同理,添加库目录,如图所示。

图片

第七步图1

图片

第七步图2

8. 添加附加依赖项。

链接器->输入->附加依赖项。

将opencv_world331d.lib键盘敲入(注意opencv版本,3.3.1是331,其他版本自行脑补)。

图片

第八步图1

图片

第八步图2

9. 确定,应用。库的导入已经完成了。接下来就可以开始OpenCV相关开发了。

10. 先将以下代码(功能是显示一张图片)写入项目中的Source.cpp文件,编译链接运行(快捷键Ctrl+F5),看是否能跑起来,跑起来了说明配置成功!
 

#include <opencv2/opencv.hpp>
using namespace cv;

int main() {
  Mat img = imread("C:\\Users\\11537\\Desktop\\新垣结衣.jpg");    //引号内选一张自己计算机内的图片的路径
  imshow("新垣结衣", img);    //打开一个窗口,显示图片
  waitKey(0);    //在键盘敲入字符前程序处于等待状态
  destroyAllWindows();    //关闭所有窗口
  return 0;
}

测试效果图如下:

图片



Python 3.x ​​​​​​​

相对于C++,Python的Opencv库导入就相对简单很多了。

一提及Python安装第三方库,大家第一时间会想到pip,的确pip是Python第三方库安装的利器。

首先我们得先安装另一个第三方库numpy,这是opencv的依赖库,没有它无法进行python-opencv开发。

很简单,保持有网状态命令行下输入pip install numpy,自动下载安装完后搞定。

比较遗憾的是默认的pip源中没有opencv这个库,不能直接pip install opencv,不过这时候我们可以下载其whl文件,下载地址:Python Extension Packages for Windows

https://link.zhihu.com/?target=https%3A//www.lfd.uci.edu/~gohlke/pythonlibs/

在页面中找到OpenCV栏,根据自己计算机中Python解释器版本选择下载文件。

图片

下载好后,通过命令行到whl文件目录下,pip install [下载的whl完整文件名]。例如pip install opencv_python-3.3.1-cp36-cp36m-win_amd64.whl

tip: 可以通过这个方法下载其他whl文件,用法一样,可以在无网状态下直接pip install whl文件导入第三方库

对于PyCharm用了Virtualenv虚拟环境的用户,可以在IDE中打开命令行界面到该项目venv/Scripts目录下./pip install numpy以及whl文件导入虚拟目录site-packages文件夹中。

同样上个测试代码(功能是显示一张图片):
 

import numpy as np
import cv2

def cv2_imread(file_path, flag=1):
"""解决包含中文的路径cv2.imread无法打开的问题的函数"""
    return cv2.imdecode(np.fromfile(file_path, dtype=np.uint8), flag)

if __name__ == "__main__":

    img = cv2_imread("C:\\Users\\11537\\Desktop\\长泽雅美.jpg")    #第一个参数选一张自己计算机内的图片的路径
    cv2.imshow("Nagasawa Masami", img)    #python的cv2.imshow第一个参数(即窗口名)为中文会乱码,至今未找到有效解决方案
    cv2.waitKey(0)    #在键盘敲入字符前程序处于等待状态
    cv2.destroyAllWindows()    #关闭所有窗口

测试效果图如下:

图片

小结

一次OpenCV初体验,个人觉得可能是历史遗留问题(以前的OpenCV是完全由C实现的),OpenCV的OOP特性并不强,跟Python的另一个图像库pillow相比用起来感觉有点怪。

不过不得不说,OpenCV还是挺强大的。至于C++和Python关于OpenCV接口问题,其实实现都大同小异,也没必要纠结于到底用C++好还是Python好,移植重构很容易。

后续打算记录一下OpenCV关于图像和基于矩阵处理的相关笔记。

​​​​​​​

参考文献

OpenCV: Introduction:

https://link.zhihu.com/?target=https%3A//docs.opencv.org/master/d1/dfb/intro.html

OpenCV学习笔记(一) OpenCV简介及安装 (qq.com)

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
OpenCV是一款开源的计算机视觉库,它提供了一系列不同的图像处理功能,包括图像识别、图像分割、目标跟踪等等。如果想要在电脑上使用OpenCV,需要进行安装及配置。下面将详细介绍OpenCV安装及配置步骤。 1.安装CMake OpenCV是一个开源项目,需要在编译前生成Makefile文件,通过Makefile文件自动生成OpenCV库文件。所以需要安装CMake工具。可以上CMake的官网进行下载。 2.安装Visual Studio的C++编译器和编译工具 OpenCV需要使用C++编译器进行编译,Visual Studio是一款比较常用的编译器,因此在安装OpenCV之前,需要先安装Visual Studio。 3.下载OpenCV源码 从OpenCV官网下载OpenCV源码。解压缩后会看到一个名为“opencv”的文件夹,其中包含OpenCV的源码。 4.在CMake中配置OpenCV 打开CMake软件,点击“Browse Source”按钮,选择OpenCV的源码路径。点击“Browse Build”按钮,选择OpenCV生成文件的路径。点击“Configure”按钮进行初始化,然后点击“Generate”按钮生成OpenCV文件。 5.编译OpenCV 在Visual Studio中打开OpenCV生成的sln文件,进行编译。这个过程可能会需要等待一段时间,在编译完成后,会在OpenCV生成文件夹中生成库文件。 6.配置Visual Studio属性 在Visual Studio中打开你的C++工程,选择“项目属性”,然后选择“VC++目录”,将OpenCV的头文件目录和库文件目录添加到C++工程的头文件和库文件路径中。 7.链接OpenCV库文件 在Visual Studio中打开你的C++工程,选择“项目属性”,然后选择“链接器”,将OpenCV的库文件名添加到链接器的附加依赖项列表中。 从以上步骤可以看出,安装及配置OpenCV需要一定的计算机知识和操作技能。但是对于计算机视觉开发者来说,掌握OpenCV安装及配置方法是非常重要的。一个标准的OpenCV安装及配置能够让计算机视觉开发者更加高效地进行图像处理和计算机视觉算法的开发和实现。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Risehuxyc

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值