基本信息
源码名称:边缘检测多尺度opencv
源码大小:1.5KB
文件格式:.cpp
开发语言:C/C++
更新时间:2017-11-17
   友情提示:(无需注册或充值,赞助后即可获取资源下载链接)

     嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们QQ(微信同号):813200300

本次赞助数额为: 2 元 
   源码介绍
边缘检测多尺度opencv

#include <iostream>  
#include <sstream>  
#include "cv.h"  
#include "cxcore.h"  
#include "highgui.h"  
using namespace std;

#define SCALESIZE 20  
int main(int argc, char* argv[])
{
IplImage* src;
//src = cvLoadImage("C:\\Users\\Administrator\\Desktop\\测试\\12074.jpg", 0);
src = cvLoadImage("C:\\Users\\Administrator\\Desktop\\马.bmp", 0);
int winSize[SCALESIZE], i;
IplImage* scaleImage[SCALESIZE];
IplImage* edgeImage[SCALESIZE];
char filename[256];
char filename2[256];
winSize[0] = 3;
scaleImage[0] = cvCreateImage(cvGetSize(src), 8, 1);
edgeImage[0] = cvCreateImage(cvGetSize(src), 8, 1);
for (i = 1; i<SCALESIZE; i )
{
winSize[i] = winSize[i - 1] 2;
scaleImage[i] = cvCreateImage(cvGetSize(src), 8, 1);
edgeImage[i] = cvCreateImage(cvGetSize(src), 8, 1);
}
for (i = 0; i<SCALESIZE; i )
{
cvSmooth(src, scaleImage[i], CV_GAUSSIAN, winSize[i], winSize[i]);

cvCanny(scaleImage[i], edgeImage[i], 30, 90, 3);
}
//保存图像  
for (i = 0; i<SCALESIZE; i )
{
string s1 = "scale_";
string jpg = ".jpg";
stringstream ss;
ss << s1;
ss << i;
ss << jpg;
ss >> filename;
//sprintf(filename,"scale_%d.jpg",i);  
cvSaveImage(filename, scaleImage[i]);
ss.clear();
string s2 = "edge_";
ss << s2;
ss << i;
ss << jpg;
ss >> filename2;
cvSaveImage(filename2, edgeImage[i]);
}

for (i = 0; i<SCALESIZE; i )
{
cvReleaseImage(&scaleImage[i]);
cvReleaseImage(&edgeImage[i]);
}
cvReleaseImage(&src);
return 0;
}