opencv 将灰度图进行边缘检测 20
#include"stdafx.h"#include"cv.h"#include"highgui.h"#include<iostream>usingnamespacest...
#include "stdafx.h"
#include"cv.h"
#include"highgui.h"
#include <iostream>
using namespace std;
IplImage* doCanny(IplImage* in,
double lowThresh,
double highThresh,
double aperture)
{
if(in->nChannels != 1)
return 0;
IplImage* out=cvCreateImage( cvGetSize( in ),IPL_DEPTH_8U,1);
cvCanny(in,out,lowThresh,highThresh,aperture);
return out;
};
int main()
{
IplImage* img=cvLoadImage("D:\\demo2.jpg");
double i=50,j=150,k=3;
IplImage* img2=doCanny(img,i,j,k);
cvNamedWindow("Image1",1);
cvNamedWindow("Image2",1);
cvShowImage( "Image1", img );//显示图像
cvShowImage( "Image2", img2 );//显示图像
cvWaitKey(0);
cvDestroyWindow("Image1");
cvDestroyWindow("Image2");
cvReleaseImage(&img);
cvReleaseImage(&img2);
return 0;
}
图像Img2什么都没有,怎么回事啊 展开
#include"cv.h"
#include"highgui.h"
#include <iostream>
using namespace std;
IplImage* doCanny(IplImage* in,
double lowThresh,
double highThresh,
double aperture)
{
if(in->nChannels != 1)
return 0;
IplImage* out=cvCreateImage( cvGetSize( in ),IPL_DEPTH_8U,1);
cvCanny(in,out,lowThresh,highThresh,aperture);
return out;
};
int main()
{
IplImage* img=cvLoadImage("D:\\demo2.jpg");
double i=50,j=150,k=3;
IplImage* img2=doCanny(img,i,j,k);
cvNamedWindow("Image1",1);
cvNamedWindow("Image2",1);
cvShowImage( "Image1", img );//显示图像
cvShowImage( "Image2", img2 );//显示图像
cvWaitKey(0);
cvDestroyWindow("Image1");
cvDestroyWindow("Image2");
cvReleaseImage(&img);
cvReleaseImage(&img2);
return 0;
}
图像Img2什么都没有,怎么回事啊 展开
展开全部
这里IplImage* img=cvLoadImage("D:\\demo2.jpg");如果不加参数,默认读取图像的原通道数。
假如你载入的图像不是单通道的,if(in->nChannels != 1) return 0;这句就直接被执行然后return了,Img2自然什么都么有。
改正:把IplImage* img=cvLoadImage("D:\\demo2.jpg");
改成IplImage* img=cvLoadImage("D:\\demo2.jpg",0);//强制转化读取的图像为灰度图
附:cvLoadImage函数使用方法
cvLoadImage( filename, -1 ); //默认读取图像的原通道数
cvLoadImage( filename, 0 ); //强制转化读取图像为灰度图
cvLoadImage( filename, 1 ); //读取彩色图
假如你载入的图像不是单通道的,if(in->nChannels != 1) return 0;这句就直接被执行然后return了,Img2自然什么都么有。
改正:把IplImage* img=cvLoadImage("D:\\demo2.jpg");
改成IplImage* img=cvLoadImage("D:\\demo2.jpg",0);//强制转化读取的图像为灰度图
附:cvLoadImage函数使用方法
cvLoadImage( filename, -1 ); //默认读取图像的原通道数
cvLoadImage( filename, 0 ); //强制转化读取图像为灰度图
cvLoadImage( filename, 1 ); //读取彩色图
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询