opencv(5)

//************************图像边缘检测(附带高斯平滑和缩放)*********************************


#include <cv.h>
#include <highgui.h>
//GAUSSIAN平滑
IplImage * simplechange(IplImage * image,int area,int channels)
{
 IplImage * imageout = cvCreateImage(cvGetSize(image),//cvsize结构通过cvgetsize获得该图的cvsize
  IPL_DEPTH_8U,//每个像素点的数据类型,多少位
  channels);//通道
 cvSmooth(image,//被平滑图像
  imageout,//平滑后的图像
  CV_GAUSSIAN,//平滑方式
  area, area);//每个像素周围area*area区域
 return(imageout);
}
//图像尺寸变为一半
IplImage * dopyrdown(IplImage * in, int filter = IPL_GAUSSIAN_5x5)//目前filter参数只支持ipl_gaussian_5x5
{
 assert(in->width % 2 == 0 && in->height % 2 == 0);//最好是分成两句断言
 IplImage * out = cvCreateImage(cvSize(in->width / 2, in->height / 2), in->depth, in->nChannels);//创建图像结构体
 cvPyrDown(in, out,filter);//缩小图像,只能用来缩小一半
 return(out);
}
//canny边缘检测,只接受单通道图,彩色图不行,边缘检测前最好进行高斯平滑
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);//sobel算子
 return (out);
}
int main()
{
 IplImage *img = cvLoadImage("D:\\op\\simple.jpg",0);//加载至内存
 //simplechange(img);//调用函数
 cvNamedWindow("test_demo5", CV_WINDOW_AUTOSIZE);
 cvNamedWindow("test_demo5_half", CV_WINDOW_AUTOSIZE);//放大缩小时cv_window_autosize可以适应图像的变化
 cvShowImage("test_demo5", img);
 IplImage *imgout = simplechange(img,3,1);
 imgout = dopyrdown(img, IPL_GAUSSIAN_5x5);
 imgout = dopyrdown(imgout, IPL_GAUSSIAN_5x5);//循环用imageout这一结构体,可有效减少内存释放所带来的问题。
 imgout = docanny(imgout,
  50, //第二阈值,避免边缘断续,若不大于最大值,在最大值附近大于第二阈值也算边缘。
  150,//最大阈值,至少大于最大阈值才会被检测为边缘。
  3);//sobel内核大小,计算颜色梯度方向的算子。虽然这是一个重要参数,但是若不是科学研究,只是日常应用,参数设为3即可。
 cvShowImage("test_demo5_half", imgout);
 cvWaitKey(0);
 cvReleaseImage(&img);
 cvReleaseImage(&imgout);
 cvDestroyWindow("test_demo5");
 cvDestroyWindow("test_demo5_half");
}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值