opencv学习之路(17)、边缘检测

 一、概述

二、canny边缘检测

 1 #include "opencv2/opencv.hpp"
 2 using namespace cv;
 3 
 4 void main()
 5 {
 6     //Canny边缘检测
 7     Mat srcImg = imread("E://1.png",0); //0表示以灰度图读入,彩色图和灰度图进行边缘检测时略有不同,建议使用灰度图
 8     //medianBlur(srcImg, srcImg,5);//中值滤波
 9     imshow("src", srcImg);
10 
11     Mat dstImg;
12     Canny(srcImg, dstImg, 30, 80);
13     imshow("Canny", dstImg);
14     waitKey(0);
15 }

Canny边缘检测小应用——检测工件是否平整,检测布料是否平滑

 1 #include "opencv2/opencv.hpp"
 2 using namespace cv;
 3 
 4 Mat src,dst;
 5 int min_thres=30,max_thres=100;//不能直接命名为min,max,标准库std里有min和max方法
 6 
 7 void onCanny(int,void*){
 8     Canny(src, dst,min_thres,max_thres);
 9     imshow("src",src);    
10     imshow("Canny", dst);
11 }
12 
13 void main()
14 {
15     src=imread("E://9.jpg",0);
16     namedWindow("Canny",CV_WINDOW_AUTOSIZE);
17     createTrackbar("min_thres","Canny",&min_thres,255,onCanny,0);
18     createTrackbar("max_thres","Canny",&max_thres,255,onCanny,0);
19 
20     onCanny(min_thres,0);//回调函数初始化
21     onCanny(max_thres,0);
22 
23     waitKey(0);
24     destroyAllWindows();
25 }

注意:canny边缘检测后,图像为灰度图!

三、Sobel算子(带方向,分x,y方向)

 1 #include "opencv2/opencv.hpp"
 2 using namespace cv;
 3 
 4 void main()
 5 {
 6     Mat grad_x, grad_y;
 7     Mat abs_grad_x, abs_grad_y, dst;
 8 
 9     Mat src = imread("E://5.jpg", 0);
10     imshow("src", src);
11 
12     Sobel(src, grad_x, CV_16S, 1, 0, 3);//16位有符号(求导时有正负),x方向参数设置为1,0
13     convertScaleAbs(grad_x, abs_grad_x);//转为无符号
14     imshow("X方向", abs_grad_x);
15 
16     Sobel(src, grad_y, CV_16S, 0, 1, 3);//y方向参数设置为0,1
17     convertScaleAbs(grad_y, abs_grad_y);
18     imshow("Y方向", abs_grad_y);
19 
20     addWeighted(abs_grad_x, 0.5, abs_grad_y, 0.5, 0, dst);
21     imshow("合并效果", dst);
22 
23     waitKey(0);
24     destroyAllWindows();
25 }

四、Laplacian算子(二阶,带方向)

 

 1 #include "opencv2/opencv.hpp"
 2 using namespace cv;
 3 
 4 void main()
 5 {
 6     Mat src,dst,abs_dst;
 7     src = imread("E://lena.jpg", 0);
 8     imshow("src", src);
 9 
10     Laplacian(src, dst, CV_16S, 3);
11     convertScaleAbs(dst, abs_dst);
12     imshow("Laplacian", abs_dst);
13 
14     waitKey(0);
15     destroyAllWindows();
16 }

 五、其他

Z1  Z2  Z3
 Z4  Z5  Z6
 Z7  Z8  Z9

 

 

 

 

Robets交叉梯度算子:▽f≈|Z9-Z5|+|Z8-Z6|

Prewitt梯度算子:▽f≈|(Z7+Z8+Z9)-(Z1+Z2+Z3)|+|(Z3+Z6+Z9)-(Z1+Z4+Z7)|

Sobel梯度算子:▽f≈|(Z7+2Z8+Z9)-(Z1+2Z2+Z3)|+|(Z3+2Z6+Z9)-(Z1+2Z4+Z7)|

posted @ 2017-08-02 21:52  进击的小猴子  阅读(2243)  评论(0编辑  收藏  举报