canny函数用法示例



//--------------------------------------【程序说明】-------------------------------------------
// 程序描述:canny函数用法示例
// 开发测试所用操作系统: Windows 7 64bit
// 开发测试所用IDE版本:Visual Studio 2010

//------------------------------------------------------------------------------------------------


//QQ:1746430162

//http://bbs.21ic.com/icview-759778-1-1.html (项目展示链接)

//  本工作室是专业电子类设计开发团队,团队成员全为从事51\DSP\ ARM\fpga类嵌入式开发和图像处理、机器学习等相关算法研究多年的软、硬件开发工程师,已与全国几十家客户成功合作。 可以长期提供技术支持,承接各类相关项目开发与咨询服务


//---------------------------------【头文件、命名空间包含部分】----------------------------
// 描述:包含程序所使用的头文件和命名空间
//------------------------------------------------------------------------------------------------
#include <opencv2/opencv.hpp>
#include<opencv2/highgui/highgui.hpp>
#include<opencv2/imgproc/imgproc.hpp>
using namespace cv;




//-----------------------------------【main( )函数】-------------------------------------------
//            描述:控制台应用程序的入口函数,我们的程序从这里开始
//-----------------------------------------------------------------------------------------------
int main( )
{
//载入原始图  
Mat srcImage = imread("1.jpg");  //工程目录下应该有一张名为1.jpg的素材图
Mat srcImage1=srcImage.clone();


//显示原始图 
imshow("【原始图】Canny边缘检测", srcImage); 


//----------------------------------------------------------------------------------
// 一、最简单的canny用法,拿到原图后直接用。
// 注意:此方法在OpenCV2中可用,在OpenCV3中已失效
//----------------------------------------------------------------------------------
  //Canny( srcImage, srcImage, 150, 100,3 );
//imshow("【效果图】Canny边缘检测", srcImage); 




//----------------------------------------------------------------------------------
// 二、高阶的canny用法,转成灰度图,降噪,用canny,最后将得到的边缘作为掩码,拷贝原图到效果图上,得到彩色的边缘图
//----------------------------------------------------------------------------------
Mat dstImage,edge,grayImage;


// 【1】创建与src同类型和大小的矩阵(dst)
dstImage.create( srcImage1.size(), srcImage1.type() );


// 【2】将原图像转换为灰度图像
cvtColor( srcImage1, grayImage, COLOR_BGR2GRAY );


// 【3】先用使用 3x3内核来降噪
blur( grayImage, edge, Size(3,3) );


// 【4】运行Canny算子
Canny( edge, edge, 3, 9,3 );


//【5】将g_dstImage内的所有元素设置为0 
dstImage = Scalar::all(0);


//【6】使用Canny算子输出的边缘图g_cannyDetectedEdges作为掩码,来将原图g_srcImage拷到目标图g_dstImage中
srcImage1.copyTo( dstImage, edge);


//【7】显示效果图 
imshow("【效果图】Canny边缘检测2", dstImage); 




waitKey(0); 


return 0; 
}
  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值