VS2012下配置opencv 及相关问题

2024-05-14 09:18

本文主要是介绍VS2012下配置opencv 及相关问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

这段时间因有一个比赛,奉命做一个视频字幕检索系统,可偏偏电脑不给力,只能在一台新的电脑上安装VS同时配置opencv。以为原来搞过会很简单,又是遇到一堆问题。将遇到的问题整理了一下。


以下面代码为例,进行编译问题讲解:

#include <cv.h>
#include <highgui.h>using namespace std;int main()
{IplImage * test;test = cvLoadImage("D:\\Sample_8.bmp");//图片路径cvNamedWindow("test_demo", 1);cvShowImage("test_demo", test);cvWaitKey(0);cvDestroyWindow("test_demo");cvReleaseImage(&test);return 0;
}


1、在win32编译环境下,进行编译时,头文件cv.h  ,  highgui.h  均加载成功,可是却提示

error LNK2019: 无法解析的外部符号_cvReleaseImage,该符号在函数_main 中被引用

在网上搜得出现这个问题的原因有两个:附加依赖项少添加了库函数;还有一个可能是:配置设置错误了,比如该是64位,却设置成win32了。改过来就好了。

(1)对于少添加库函数的说法我是不同意的,因为我认真对照了我添加的opencv中lib库里的库,正好19个不少。添加库:

opencv_calib3d248d.lib
opencv_contrib248d.lib
opencv_core248d.lib
opencv_features2d248d.lib
opencv_flann248d.lib
opencv_gpu248d.lib
opencv_highgui248d.lib
opencv_imgproc248d.lib
opencv_legacy248d.lib
opencv_ml248d.lib
opencv_objdetect248d.lib
opencv_ts248d.lib
opencv_video248d.lib


(2)既然我添加的库不少,那就应该是配置环境出了问题。在配置环境问题时可能会有人像我一样偷懒。在配置环境变量时为了方式我们会同时出现编译32和64的情况,所以讲两个文件全部加入环境变量中。本人这次进行“项目->属性->配置属性->链接器->常规 ->附加库目录”时也为了省事将x86和x64放在了一起,而且x64位于x86的前面,这就导致了问题的出现。将x64删除掉问题就可以解决。



2、按照相同方法配置x64后,编译时提示fatal error C1083: 无法打开包括文件:“cv.h”: No such file or directory

#include <cv.h>
#include <highgui.h>

一般出现这种问题极有可能是文件路径出现了问题,为什么这两句在win32 时直接编译通过,而在x64中失败呢?


这是由于opencv从2.2版本以后<opencv root>include下有两个文件夹 opencv 和opencv2 。从官方的意思来看,它逐渐喜欢用opencv2里面的那种包含头文件的方式。
但是cv.h highgui.h是opencv目录下的头文件。


将上面两句改为:

#include <opencv/cv.h>
#include <opencv/highgui.h>


小编试过了,改为这两句同样不影响在win32中的编译。

相关博客链接:http://blog.csdn.net/emperorjade/article/details/49718985



最后,小编在这里给出在VS2012中配置opencv 的方法:


(http://blog.csdn.net/chenxi_wind/article/details/41843653?utm_source=tuicool&utm_medium=referral)


总结一下在配置opencv的步骤(VS2012+opencv2.4.8)

1。 配置环境变量,配置好环境变量之后有可能要重启计算机才会有效,我就属于这种情况。

我们首先要在 计算机-属性-高级系统设置-环境变量 里添加你的opencv 路径, 我的opencv直接安装在C盘,有些文章里讲在 系统变量里添加路径,我这里用户变量和系统变量都添加了,如下:我的计算机是win7 64 位,所以我x86 和x64都添加进去了,因为可能在VS里面debug时切换64位和32位进行调试。



2、在VS里添加opencv包含目录和库目录。

(1)包含目录

在opencv2.4.8 解压之后的文件夹当中你会看到build 和source 两个文件夹,build->include->opencv和opencv2 所以我们还需要把这两个子文件夹的路径都包含进去。 

如下图:初次配置时新建路径即可。项目->属性->配置属性->VC++目录->包含目录



(2)库目录

项目->属性->配置属性->VC++目录->库目录,由于我的计算机系统是64 位的,所以我添加了32位和64位的两个库目录。

初次配置时只需新建路径即可,下图的右上角的键。



3.链接时,会需要一些附加依赖项。下面我们说(附加 .lib)的配置

这里分两步,第一步是项目->属性->配置属性->链接器->常规 ->附加库目录

第二步是项目->属性->配置属性->链接器->输入 ->附加依赖项,其中第一步是告诉链接器附加依赖库的位置。如果少了任何一步,在链接时都可能会出现无法解析的外部符号等错误。

如下图所示:

第一步



第二步:初次配置时把附加依赖项都粘贴在空白位置就好了。



这里我们给出几个opencv 版本的附加依赖项:

对于【OpenCV2.4.8】,添加如下248版本的lib(这样的lib顺序是:19个带d的debug版的lib写在前面,19个不带d的release版的lib写在后面):
opencv_ml248d.lib
opencv_calib3d248d.lib
opencv_contrib248d.lib
opencv_core248d.lib
opencv_features2d248d.lib
opencv_flann248d.lib
opencv_gpu248d.lib
opencv_highgui248d.lib
opencv_imgproc248d.lib
opencv_legacy248d.lib
opencv_objdetect248d.lib
opencv_ts248d.lib
opencv_video248d.lib
opencv_nonfree248d.lib
opencv_ocl248d.lib
opencv_photo248d.lib
opencv_stitching248d.lib
opencv_superres248d.lib
opencv_videostab248d.lib
opencv_objdetect248.lib
opencv_ts248.lib
opencv_video248.lib
opencv_nonfree248.lib
opencv_ocl248.lib
opencv_photo248.lib
opencv_stitching248.lib
opencv_superres248.lib
opencv_videostab248.lib
opencv_calib3d248.lib
opencv_contrib248.lib
opencv_core248.lib
opencv_features2d248.lib
opencv_flann248.lib
opencv_gpu248.lib
opencv_highgui248.lib
opencv_imgproc248.lib
opencv_legacy248.lib
opencv_ml248.lib
对于【OpenCV2.4.9】,添加如下249版本的lib(这样的lib顺序是:19个带d的debug版的lib写在前面,19个不带d的release版的lib写在后面):
opencv_ml249d.lib
opencv_calib3d249d.lib
opencv_contrib249d.lib
opencv_core249d.lib
opencv_features2d249d.lib
opencv_flann249d.lib
opencv_gpu249d.lib
opencv_highgui249d.lib
opencv_imgproc249d.lib
opencv_legacy249d.lib
opencv_objdetect249d.lib
opencv_ts249d.lib
opencv_video249d.lib
opencv_nonfree249d.lib
opencv_ocl249d.lib
opencv_photo249d.lib
opencv_stitching249d.lib
opencv_superres249d.lib
opencv_videostab249d.lib
opencv_objdetect249.lib
opencv_ts249.lib
opencv_video249.lib
opencv_nonfree249.lib
opencv_ocl249.lib
opencv_photo249.lib
opencv_stitching249.lib
opencv_superres249.lib
opencv_videostab249.lib
opencv_calib3d249.lib
opencv_contrib249.lib
opencv_core249.lib
opencv_features2d249.lib
opencv_flann249.lib
opencv_gpu249.lib
opencv_highgui249.lib
opencv_imgproc249.lib
opencv_legacy249.lib
opencv_ml249.lib

以上四步算是完成了opencv 在vs 里面的配置。

也许你觉得每次建立一个项目都要这样配置很麻烦,也有一劳永逸的方法,任意新建一个项目,打开视图->属性管理器,在debug|win32 里点击Microsoft.Cpp,win32.user 右键属性,在这里再按照以上的方法设置包含目录和库目录以及附加依赖项即可。

如下图:



4 下面我们给出一个运行实例:

代码是:


//缩放图像文件  
//By MoreWindows (http://blog.csdn.net/MoreWindows)  
#include <opencv2/opencv.hpp>  
using namespace std;  
//隐藏控制台窗口  
#pragma comment(linker, "/subsystem:\"windows\" /entry:\"mainCRTStartup\"")  
int main()  
{  const char *pstrImageName = "1.jpg";  const char *pstrSaveImageName = "1.jpg";  const char *pstrWindowsSrcTitle = "原图 (http://blog.csdn.net/MoreWindows)";  const char *pstrWindowsDstTitle = "缩放图 (http://blog.csdn.net/MoreWindows)";  double fScale = 0.314;	  //缩放倍数  CvSize czSize;			  //目标图像尺寸  //从文件中读取图像	IplImage *pSrcImage = cvLoadImage(pstrImageName, CV_LOAD_IMAGE_UNCHANGED);  IplImage *pDstImage = NULL;   //计算目标图像大小  czSize.width = pSrcImage->width * fScale;  czSize.height = pSrcImage->height * fScale;  //创建图像并缩放  pDstImage = cvCreateImage(czSize, pSrcImage->depth, pSrcImage->nChannels);  cvResize(pSrcImage, pDstImage, CV_INTER_AREA);  //创建窗口  cvNamedWindow(pstrWindowsSrcTitle, CV_WINDOW_AUTOSIZE);  cvNamedWindow(pstrWindowsDstTitle, CV_WINDOW_AUTOSIZE);  //在指定窗口中显示图像  cvShowImage(pstrWindowsSrcTitle, pSrcImage);  cvShowImage(pstrWindowsDstTitle, pDstImage);  //等待按键事件  cvWaitKey();  //保存图片  cvSaveImage(pstrSaveImageName, pDstImage);  cvDestroyWindow(pstrWindowsSrcTitle);  cvDestroyWindow(pstrWindowsDstTitle);  cvReleaseImage(&pSrcImage);  cvReleaseImage(&pDstImage);  return 0;  
}  


运行结果是:



5 到这里终于结束了,又多试了几次,都没有出问题,哎呀,配置opencv 真是很麻烦呀。







这篇关于VS2012下配置opencv 及相关问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/988369

相关文章

linux生产者,消费者问题

pthread_cond_wait() :用于阻塞当前线程,等待别的线程使用pthread_cond_signal()或pthread_cond_broadcast来唤醒它。 pthread_cond_wait() 必须与pthread_mutex 配套使用。pthread_cond_wait()函数一进入wait状态就会自动release mutex。当其他线程通过pthread

问题:第一次世界大战的起止时间是 #其他#学习方法#微信

问题:第一次世界大战的起止时间是 A.1913 ~1918 年 B.1913 ~1918 年 C.1914 ~1918 年 D.1914 ~1919 年 参考答案如图所示

Linux 安装、配置Tomcat 的HTTPS

Linux 安装 、配置Tomcat的HTTPS 安装Tomcat 这里选择的是 tomcat 10.X ,需要Java 11及更高版本 Binary Distributions ->Core->选择 tar.gz包 下载、上传到内网服务器 /opt 目录tar -xzf 解压将解压的根目录改名为 tomat-10 并移动到 /opt 下, 形成个人习惯的路径 /opt/tomcat-10

RecastNavigation之Poly相关类

Poly分成正常的Poly 和 OffMeshPoly。 正常的Poly 又分成 原始的Poly 和 Detail化的Poly,本文介绍这两种。 Poly的边分成三种类型: 1. 正常边:有tile内部的poly与之相邻 2.border边:没有poly与之相邻 3.Portal边:与之相邻的是外部tile的poly   由firstLink索引 得到第一个连接的Poly  通

uniapp接入微信小程序原生代码配置方案(优化版)

uniapp项目需要把微信小程序原生语法的功能代码嵌套过来,无需把原生代码转换为uniapp,可以配置拷贝的方式集成过来 1、拷贝代码包到src目录 2、vue.config.js中配置原生代码包直接拷贝到编译目录中 3、pages.json中配置分包目录,原生入口组件的路径 4、manifest.json中配置分包,使用原生组件 5、需要把原生代码包里的页面修改成组件的方

2024.6.24 IDEA中文乱码问题(服务器 控制台 TOMcat)实测已解决

1.问题产生原因: 1.文件编码不一致:如果文件的编码方式与IDEA设置的编码方式不一致,就会产生乱码。确保文件和IDEA使用相同的编码,通常是UTF-8。2.IDEA设置问题:检查IDEA的全局编码设置和项目编码设置是否正确。3.终端或控制台编码问题:如果你在终端或控制台看到乱码,可能是终端的编码设置问题。确保终端使用的是支持你的文件的编码方式。 2.解决方案: 1.File -> S

vcpkg安装opencv中的特殊问题记录(无法找到opencv_corexd.dll)

我是按照网上的vcpkg安装opencv方法进行的(比如这篇:从0开始在visual studio上安装opencv(超详细,针对小白)),但是中间出现了一些别人没有遇到的问题,虽然原因没有找到,但是本人给出一些暂时的解决办法: 问题1: 我在安装库命令行使用的是 .\vcpkg.exe install opencv 我的电脑是x64,vcpkg在这条命令后默认下载的也是opencv2:x6

问题-windows-VPN不正确关闭导致网页打不开

为什么会发生这类事情呢? 主要原因是关机之前vpn没有关掉导致的。 至于为什么没关掉vpn会导致网页打不开,我猜测是因为vpn建立的链接没被更改。 正确关掉vpn的时候,会把ip链接断掉,如果你不正确关掉,ip链接没有断掉,此时你vpn又是没启动的,没有域名解析,所以就打不开网站。 你可以在打不开网页的时候,把vpn打开,你会发现网络又可以登录了。 方法一 注意:方法一虽然方便,但是可能会有

IDEA配置Tomcat远程调试

因为不想把本地的Tomcat配置改乱或者多人开发项目想测试,本文主要是记录一下,IDEA使用Tomcat远程调试的配置过程,免得一段时间不去配置到时候忘记(毕竟这次是因为忘了,所以才打算记录的…) 首先在catalina.sh添加以下内容 JAVA_OPTS="-Dcom.sun.management.jmxremote=-Dcom.sun.management.jmxremote.port

vue同页面多路由懒加载-及可能存在问题的解决方式

先上图,再解释 图一是多路由页面,图二是路由文件。从图一可以看出每个router-view对应的name都不一样。从图二可以看出层路由对应的组件加载方式要跟图一中的name相对应,并且图二的路由层在跟图一对应的页面中要加上components层,多一个s结尾,里面的的方法名就是图一路由的name值,里面还可以照样用懒加载的方式。 页面上其他的路由在路由文件中也跟图二是一样的写法。 附送可能存在