Opencv中调用FileStorage出现错误“Stack around the variable '*' was corrupted.”

我遇到的问题是这样的,在vs2012里面新建一个工程,配置好opencv等各种include和lib,然后下了如下的代码,调用filestorge来读一个yml文件,结果就提示了堆栈出错。

#include <cv.h> 
int main()
{
	//Load file
	cv::Mat project;
	cv::FileStorage fs( "project.yml", cv::FileStorage::READ);
	fs["project"] >> project;
	fs.release();
	return 1;
}

这个问题让我纠结了很久,甚至看了opencv的源代码。问题就是出在FileStorage这个函数和vs2012这个编译器之间。可是到底是什么导致了这样的结果?


这里先给出解决办法,让后再给出我的分析,大家一起探讨一下。
在vs2012里面,右键项目->属性->常规里面,讲平台工具集由Visual Studio 2012 改为 Visual Studio 2010就ok了!


我的分析是这样的,我用的opencv是官方给出的编译好的版本2.4,官方是用vs2010编译的,那么在2012下也许就会出现一些不可预期的错误,我猜测如果你将自己的opencv用vs2012编译一遍,也许就不会出现这个问题了,很可惜,用vs2012编译opencv老是不成功,如果有哪位同学编译通过了,可以测试一下,评论给出答案。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
在AE调用OpenCV.js需要使用JavaScript脚本来实现。以下是一些步骤: 1. 下载OpenCV.js库:你可以从GitHub仓库下载OpenCV.js库。 2. 将OpenCV.js库添加到AE项目:在AE创建一个新的脚本文件,并将OpenCV.js库添加到该文件。你可以使用以下代码将库添加到脚本: ``` #include "/path/to/opencv.js" ``` 3. 加载OpenCV.js库:在脚本使用以下代码加载OpenCV.js库: ``` cv = cv || {}; cv.load = function() { return new Promise((resolve, reject) => { if (typeof cv !== 'undefined') { resolve(); } else { const script = document.createElement('script'); script.src = '/path/to/opencv.js'; script.async = true; script.onload = () => resolve(); script.onerror = () => reject(new Error(`Failed to load ${script.src}`)); document.head.appendChild(script); } }); }; cv.load().then(() => { console.log('OpenCV.js is ready!'); }); ``` 4. 使用OpenCV.js库:一旦OpenCV.js库已加载,你就可以使用OpenCV.js库提供的函数和方法了。以下是一个简单的使用OpenCV.js库的示例: ``` cv.imread('/path/to/image.jpg', (img) => { cv.imshow('canvas', img); }); ``` 这将使用OpenCV.js库从指定的图像文件读取图像,并将其显示在指定的画布上。 请注意,OpenCV.js库是用JavaScript编写的,因此使用它可能会对性能产生一定影响。此外,OpenCV.js库可能不支持所有的OpenCV函数和方法。因此,在使用它之前,请确保仔细阅读文档并了解其功能和限制。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值