关于OpenCv中cvPreCornerDetect 运行出错解决方法

http://m.blog.csdn.net/blog/wode0239

由于书本上示例的不全,相信大家在做的时候,肯定是无从下手。

而且就算做了,会遇到各种错误。

我也是初学,也遇到各种Exception。

相信大家遇到的问题就是如何将load的image转换为32FC1

我花了一个晚上,终于功夫不负有心人,终于解决这个问题了。

我们知道由于cvPreCornerDetect 接收的参数,只能是浮点型的单通道图像

而我们load进来的图像,默认是char 类型的3通道的图像,那么到底如何转换呢

转换图像有两个方法,一个是cvConvert或者cvConvertScale ,另一个是cvCvtColor.

根据我的测试,得到如下结果

//单纯的使用cvConvertScale(image,temp);,只能转换相同通道不同值深度的图像

//然后在使用cvCvtColor(temp,out,CV_RGB2GRAY); 这个函数也只能转换相同深度,不同通道的图像

所以我们要结合使用才能将我们传入的8UC3转为32FC1

下面直接看代码吧

这是我经过测试的函数,可以运行,并出图像

//计算用于角点检测的特征图,大家只需要在main里,调用,并将图像指针传入。运行,即可得到结果

void doPreCornerDetect(IplImage* image)

{

IplImage* temp = cvCreateImage(cvGetSize(image),IPL_DEPTH_32F,3);

//由于cvPreCornerDetect只接收 32FC1图像,所以应该讲传入的image转换

//单纯的使用cvConvertScale(image,temp);,只能转换相同通道不同值深度的图像

//然后在使用cvCvtColor(temp,out,CV_RGB2GRAY); 这个函数也只能转换相同深度,不同通道的图像

cvConvertScale(image,temp);

IplImage* out = cvCreateImage(cvGetSize(temp),IPL_DEPTH_32F,1);

cvCvtColor(temp,out,CV_RGB2GRAY);

IplImage* corners = cvCloneImage(out);

/*IplImage* dilated_corners = cvCloneImage(temp);

IplImage* corner_mask = cvCreateImage( cvGetSize(temp), 8, 1 );*/

cvPreCornerDetect( out, corners, 3 );

// 扩张

/*cvDilate( corners, dilated_corners, 0, 1 );

cvSub( corners, dilated_corners, corners );

cvCmpS( corners, 0, corner_mask, CV_CMP_GE );*/

cvNamedWindow("PreCornerDetect");

cvShowImage("PreCornerDetect",corners);

cvWaitKey(0);

cvReleaseImage( &out );

cvReleaseImage( &corners );

//cvReleaseImage( &dilated_corners );

cvReleaseImage(&temp);

}

opencv cvPreCornerDetect的更多相关文章

  1. [OpenCV] IplImage and Functions

    In this chapter, APIs will make U crazy. Good luck! Next, Review Linear Algebra.  Ref: http://blog.c ...

  2. OpenCv结构和内容

    OpenCv的结构和内容 OpenCv源码组成结构其中包括cv, cvauex, cxcore, highgui, ml这5个模块 CV:图像处理和视觉算法 MLL:统计分类器 HighGui:GUI ...

  3. [OpenCV] IplImage and Operation

    IplImage 一.资源 In this chapter, APIs will make U crazy. Good luck! Next, Review Linear Algebra. Ref:  ...

  4. 常用的OpenCV函数速查

    常用的OpenCV函数速查 1.cvLoadImage:将图像文件加载至内存: 2.cvNamedWindow:在屏幕上创建一个窗口: 3.cvShowImage:在一个已创建好的窗口中显示图像: 4 ...

  5. OpenCV学习笔记四:ImgProc模块

    一,简介 这个模块包含一系列的常用图像处理算法. 二,分析 此模块包含的文件如下图: 其导出算法包括如下: /*********************** Background statistics ...

  6. 常用的OpenCV 2.0函数速查

    OpenCV 2.0函数释义列表 1.cvLoadImage:将图像文件加载至内存: 2.cvNamedWindow:在屏幕上创建一个窗口: 3.cvShowImage:在一个已创建好的窗口中显示图像 ...

  7. opencv在图像显示中文

    在图像定位和模式识别时,经常需要把结果标注到图片上,标注内容可以是数字字母.矩形框等(opencv支持的)或者是中文汉字(借助freetype). 1.显示数字/矩形框 #include <op ...

  8. opencv中Mat与IplImage,CVMat类型之间转换

    opencv中对图像的处理是最基本的操作,一般的图像类型为IplImage类型,但是当我们对图像进行处理的时候,多数都是对像素矩阵进行处理,所以这三个类型之间的转换会对我们的工作带来便利. Mat类型 ...

  9. opencv源码:cascadedetect

    级联分类器检测类CascadeClassifier,提供了两个重要的方法: CascadeClassifier cascade_classifier; cascade_classifier.load( ...

随机推荐

  1. thinkserer TD350 系统损坏后,数据恢复及系统重做过程

    电脑配置: 联想服务器 TD350   E5-2609V4 2*8G 2*4T+R1 塔式 单电 1.系统恢复: 试过很多种方法,均无效 2.数据恢复:  重新安装系统后,直接在D盘查找 , 原C盘的 ...

  2. mysql 5.7 双主+主从配置

    mysql5.7安装及赋权 wget http://repo.mysql.com/mysql57-community-release-el7-8.noarch.rpm rpm -ivh mysql57 ...

  3. java中TCP传输协议

    class TcpClient { public static void main(String[] args) throws Exception { //创建client的socket服务,指定目的 ...

  4. TCP/IP协议族-----20、远程登录:TELNET与SSH

  5. (诡异Floyd&amp;自环)MZ Training 2014 #15 E题(POJ 2240)

    你们见过这么诡异的FLOYD吗? 先上题. [Description] 货币的汇率存在差异.比如,如果1美元购买0.5英镑,1英镑买10法郎.而1法国法郎买0.21美元.然后,通过转换货币,一个聪明的 ...

  6. hdu5372 Segment Game

    Problem Description Lillian is a clever girl so that she has lots of fans and often receives gifts f ...

  7. opencv-图像金字塔

    图像金字塔 目标 原理摘自:http://www.opencv.org.cn/opencvdoc/2.3.2/html/doc/tutorials/imgproc/pyramids/pyramids. ...

  8. Thinkphp的 is null 查询条件是什么,以及exp表达式如何使用

    Thinkphp的 is null 查询条件是什么,以及exp表达式如何使用 一.总结 一句话总结:$map['name'] = array('exp','is null'); 1.is null判断 ...

  9. 值得学习的html知识

    这里零度为大家推荐几个值得学习的html知识,很有用的哦! 一.打开窗口即最大化 <script language="javaScript"> <!-- Begi ...

  10. Linux下使用网上银行

    Linux下使用网上银行 650) this.width=650;" onclick="window.open("http://blog.51cto.com/viewpi ...