opencv3/C++图像边缘提取方式

时间:2022-06-06 00:47:00

canny算子实现

使用track bar 调整canny算子参数,提取到合适的图像边缘。

  1. #include<iostream>
  2. #include<opencv2/opencv.hpp>
  3. using namespace cv;
  4.  
  5. void trackBar(int, void*);
  6. int s1=0,s2=0;
  7. Mat src, dst;
  8. int main()
  9. {
  10. src = imread("E:/image/image/daibola.jpg");
  11. if(src.empty())
  12. {
  13. printf("can not load image \n");
  14. return -1;
  15. }
  16. cvNamedWindow("input", CV_WINDOW_AUTOSIZE);
  17. imshow("input", src);
  18. dst = src.clone();
  19. cvNamedWindow("output", CV_WINDOW_AUTOSIZE);
  20. createTrackbar("canny1", "output", &s1, 255, trackBar);
  21. createTrackbar("canny2", "output", &s2, 255, trackBar);
  22. GaussianBlur(src,src,Size(3,3),0);
  23.  
  24. waitKey();
  25. return 0;
  26. }
  27.  
  28. void trackBar(int, void*)
  29. {
  30.  
  31. Canny(src,dst,s1,s2,3);
  32. imshow("output", dst);
  33. }

opencv3/C++图像边缘提取方式

Sobel算子实现

  1. #include<iostream>
  2. #include<opencv2/opencv.hpp>
  3. using namespace cv;
  4.  
  5. int main()
  6. {
  7. Mat src, dst;
  8. src = imread("E:/image/image/daibola.jpg");
  9.  
  10. if(src.empty())
  11. {
  12. printf("can not load image \n");
  13. return -1;
  14. }
  15. dst = Mat::zeros(src.size(), src.type());
  16. cvNamedWindow("input", CV_WINDOW_AUTOSIZE);
  17. imshow("input", src);
  18.  
  19. Mat kernel = (Mat_<int>(2,2)<<0,1,-1,0);
  20. filter2D(src,dst,-1,kernel,Point(-1,-1),0.0);
  21. Mat xgrad, ygrad;
  22. Sobel(src,xgrad,CV_16S,1,0,3);
  23. Sobel(src,ygrad,CV_16S,0,1,3);
  24. convertScaleAbs(xgrad,xgrad);
  25. convertScaleAbs(ygrad,ygrad);
  26.  
  27. addWeighted(xgrad,0.5,ygrad,0.5,0,dst);
  28. //addWeighted(dst,0.5,src,1,0,dst);
  29. cvNamedWindow("output", CV_WINDOW_AUTOSIZE);
  30. imshow("output", dst);
  31. waitKey();
  32. return 0;
  33. }

opencv3/C++图像边缘提取方式

以上这篇opencv3/C++图像边缘提取方式就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我们。

原文链接:https://blog.csdn.net/akadiao/article/details/78837606