windows下 C++ openCV配置及x86编译

本傻瓜教程需要的环境如下: IDE: vs2015或vs2017 ,  windows 10 或 11

vs2017下载地址如下:

  ①百度网盘

链接:https://pan.baidu.com/s/1r628e9M5lv_F9IWO-h05jA 
提取码:23a7

 ②官网地址

https://my.visualstudio.com/Downloads/Featured?mkt=zh-cnicon-default.png?t=M276https://my.visualstudio.com/Downloads/Featured?mkt=zh-cn关于vs的版本,个人觉得不管是社区版个人版还是企业版,对于我们工作学习的个人来说都一样,就我的经验,我从vs2005开始,使用了包括2005/2008/2010/2013/2015/2017/2019/2022,在做项目时(个人版,社区办,企业版)几乎没有差距,随意找一个下载就行

关于vs的安装这里就不提了,可以自行百度

这里强制IDE为2015/2017是因为opencv最新的几个版本都是只支持vs2015/vs2017编译的,虽然可以在更高的vs版本使用opencv的库,但是却不能编译opencv的源码,为什么要编译opencv的源码呢,这只能怪opencv自己了,他本身只提供了x64编译版本库,未提供x86编译版本,相信在中国做软件项目,你的客户肯定有xp/win732位的客户,为了增强兼容性,我们发布的程序肯定是32位的,尤其是C++项目.

好了,基本的工作环境已经有了,下面开始进入主题

   一:下载opencv

     openCV官网下载地址如下:

     Releases - OpenCVicon-default.png?t=M276https://opencv.org/releases/

登录官网后根据需求下载对应版本(当然了,如果还看我的博客,说明基本都是啥也不懂的,就直接照着我的示例来吧)

 在我写博客的这个时间,opencv的最新版本为4.5.5,下载如图划红线的windows版本

点击后会进入如下页面

 这个倒计时结束会进入自动下载

 下载完成后的文件拷贝到你熟悉的文件夹内,以便后面使用

我这边是直接在桌面新建了一个叫opencv的文件夹用来存放本次配置opencv所需要使用的所有文件

二:安装opencv

双击

进行安装,这个安装过程也是全程傻瓜式,只需要注意一点,opencv的安装目录不要出现中文路径,

如图,我的安装目录如下,因为本次安装的是4.5.5版本,直接重命名目录为opencv455,便于理解 

 三:配置opencv环境变量,测试opencv x64库

此电脑->右击 属性->高级系统设置->环境变量

根据如下步骤配置环境变量

我已经配置好了变量名为OpenCV455_x64_vs2017的变量

下面将该变量添加到 环境变量  双击Path,将OpenCV455_x64_vs2017添加到Path环境变量

 四:配置vs项目环境,调用opencv库

下面我使用vs2019调用opencv x64库

可以看到在安装的opencv文件夹中有这么一个目录:

该目录下有vc14跟vc15两个目录,这两个目录分别存放的是经过vs2015编译的库跟经过vs2017编译的库,我们这里测试vc15(vs2017)的库

使用vs2019创建一个win32控制台空项目程序,添加cpp文件,在文件中添加如下代码:


    
    
  1. #include <iostream>
  2. #include <opencv2/core/core.hpp>
  3. #include <opencv2/highgui/highgui.hpp>
  4. using namespace cv;
  5. int main()
  6. {
  7. // 读入一张图片(poyanghu缩小图)
  8. Mat img = imread( "C:\\Users\\ljl\\Desktop\\桌面杂物箱\\ascii码表.jpg");
  9. // 创建一个名为 "图片"窗口
  10. namedWindow( "图片");
  11. // 在窗口中显示图片
  12. imshow( "图片", img);
  13. // 等待6000 ms后窗口自动关闭
  14. waitKey( 60000);
  15. return 0;
  16. }

此时项目结构如下:

 

 因为我们测试的x64的库,这里一定要选择x64  

ps: 虽然我们都知道64位的系统可以兼容32位的程序,但是切记,这是对于系统而言,我们使用的IDE需要明确区分32位跟64位,这涉及到编译过程.在我的工作经验中,x64的程序无法调用32位的动态库

在项目属性中配置opencv库,配置如下

 在包含目录中添加:

D:\openCV\opencv455\build\include\opencv2
D:\openCV\opencv455\build\include

在库目录中添加:

D:\openCV\opencv455\build\x64\vc15\lib

 在链接器->输入->附加依赖项中添加 opencv_world455d.lib

其实从上面的配置就可以看出,本次使用的是隐式调用动态库,关于动态库的调用方式,可了解如下

c++动态函数库的创建与调用(.def)_痕忆丶的博客-CSDN博客_.def动态库的创建有两种方法,之前说过了不使用.def的方法,现在说一下使用.def的方法环境VS2005写个简单的动态库,里面有两个函数,能实现加法减法首先创建一个空项目dll,创建头文件,再创建源文件,再创建模块定义文件即.def文件这样创建一个动态库所需的条件就满足了.在头文件中写入如下代码在源文件中写入如下代码在源文件的模块定义文件中写入如下代码F7生成动态库在.def中第一行是数据库的名字,第...https://blog.csdn.net/qq_37059136/article/details/80167388

配置好环境后编译程序  将opencv_world455d.dll拷贝到该程序生成目录 

运行如下

 如此表示opencv调用正常,以后使用opencv也只需要进行如此配置

为什么这里可以使用vs2019进行调用而文章一开始要求IDE必须是vs2015/2017呢,因为调用别人的库只要环境配置好了就可以在任意IDE调用,编译好的库是不依赖vs版本的,但是接下来我们要编译x86的库,就必须使用vs2015/2017了,也许你注意到了,我们下载的opencv的可执行程序名字很奇怪

 

 该文件名字表明此版本的opencv只兼容vc14 跟vc15,那么这俩代表什么意思呢


    
    
  1. vc 7 : Visual Studio2003
  2. vc 8 : Visual Studio2005
  3. vc 9 : Visual Studio2007
  4. vc 10: Visual Studio2009
  5. vc 11: Visual Studio2011
  6. vc 12: Visual Studio2013
  7. vc 14: Visual Studio2015
  8. vc 15: Visual Studio2017

也就是说想要编译这个版本的opencv源码,必须使用vc14或vc15工作环境

我们都知道在C++项目开发中第一步需要统一的就是开发工具,不同的开发工具使用的编译环境不同,虽然可以手动改变编译环境,但是需要耗费较大精力,opencv共300+个编译项目,在我们不清楚项目配置的情况下,还是乖乖使用opencv官网推荐的版本进行编译吧,我尝试过使用vs2019进行编译,以失败告终,千万别用你的小聪明挑战IDE的差异

五:编译opencv x86版本

准备条件: 下载cmake

Download | CMakeicon-default.png?t=M276https://cmake.org/download/

 下载如箭头所示的cmake版本,进行安装

 这里安装在D盘根目录

安装完后打开如下程序

打开后如下所示界面

 

 

如上是cmake使用的几个注意点,相较于命令行,cmake的ui界面显得就很好理解了.

好了,现在开始进行opencv的x86编译

 

 opencv的源码位置在安装opencv时已经被安装到本地,找到步骤一中你安装opencv的目录,如下

 

 

 

 

点击finish后开始编译

可通过stop停止,这里我们等待一段时间等他执行结束

 

 这里表示执行结束

勾选如下两个配置

 其余的使用默认配置即可

然后点两次 Generate(先编译一次完成后再点击一次进行编译) 。编译完成即可。(注意:在此过程中可能会报错,不需要例会即可)。

 

 如此表示项目构建结束

 下面使用vs2017进行编译生成动态库

 

项目打开后如图所示,我们需要的是32位版本,这里选x86或者是win32, 具体他们的区别如下

编译release 32位版本 

 

 经过漫长的等待,终于编译结束,很完美,没有报错

 编译成功后,在解决方案资源管理器—>CMake Targets—>INSTALL—>右键INSTALL—>仅用于项目—>仅生成INSTALL

 然后打开cmake生成文件的存放路径文件夹,找到install文件夹,里面的x86就是我们需要

 好了,既然编译了release版本,那顺手再编译debug版本吧

 CMake Targets—>INSTALL—>右键INSTALL—>仅用于项目—>仅生成INSTALL

进入cmake生成文件的存放路径文件夹,找到install文件夹,里面的x86文件夹查看

 这两个动态库就是我们需要的,其中 opencv_world455.dll是release版本,opencv_world455d.dll是debug版本.

下面还是使用上面的在四:配置vs项目环境,调用opencv库的方法去测试下这两个库能不能使用吧

这次使用vs2017测试

首先将生成的文件拷贝出来,便于我们配置环境变量

 将install目录下的x86复制到build目录下

 这样我们自己编译的x86跟opencv官网编译的x64就在同级目录,是不是就方便多了

配置环境变量的步骤参照第四部分

 打开vs2017,新建win32控制台空项目(流程跟第四部完全一致)

开始vs项目配置,使用opencv库(debug x86配置)

附加文件目录 

D:\openCV\opencv455\build\include

D:\openCV\opencv455\build\include\opencv2

附加库目录 D:\openCV\opencv455\build\x86\vc15\lib

附加依赖项 opencv_world455d.lib (名字带d的表示是debug库)

编译成功生成x86版本的debug程序,将opencv_world455d.dll拷贝到该程序目录

 

如上表示我们编译的opencv x86的库成功

聪明的你应该会类推测试release版本了吧

以上

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Ubuntu中使用VScode配置C++OpenCV环境的步骤如下: 1. 首先,安装OpenCV。可以参考引用中提供的链接,按照最新最详细的教程进行安装。 2. 安装VScode。在Ubuntu软件中心或者通过终端使用以下命令安装: ``` sudo snap install --classic code ``` 3. 打开VScode,并安装C++插件。点击左侧菜单栏的扩展图标,搜索并安装"C++"插件。 4. 配置编译器路径和标准。创建一个名为`.vscode`的文件夹,并在其中创建一个名为`c_cpp_properties.json`的文件。将以下内容复制到文件中,并保存: ``` { "configurations": [ { "name": "Linux", "includePath": [ "${workspaceFolder}/**", "/usr/include/x86_64-linux-gnu/sys", "/usr/local/include/opencv4" ], "defines": [], "compilerPath": "/usr/bin/gcc", "cStandard": "gnu17", "cppStandard": "gnu17", "intelliSenseMode": "linux-gcc-x64" } ], "version": 4 } ``` 5. 配置构建任务。创建一个名为`tasks.json`的文件,并将以下内容复制到文件中,并保存: ``` { "tasks": [ { "type": "cppbuild", "label": "C/C++: g++ build active file", "command": "/usr/bin/g++", "args": [ "-fdiagnostics-color=always", "-g", "${file}", "-o", "${fileDirname}/${fileBasenameNoExtension}.out", "`pkg-config","--libs","--cflags","opencv4`" ], "options": { "cwd": "${fileDirname}" }, "problemMatcher": [ "$gcc" ], "group": { "kind": "build", "isDefault": true } } ], "version": "2.0.0" } ``` 6. 现在,你可以在VScode中编写和运行C++代码,并使用OpenCV库。按下`Ctrl + Shift + B`编译并运行代码。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值