- OpenCV简介
- OpenCV开发环境配置
- OpenCV存储图像
- OpenCV读取图像
- OpenCV写入图像
- OpenCV用户界面
- 图像类型
- 图像转换
- 绘图函数
- 模糊功能
- 过滤功能
- 阈值
- 索贝尔衍生品
- 变换操作
- 相机和人脸检测
- 几何变换
- 杂篇
OpenCV Canny边缘检测
Canny边缘检测用于检测图像中的边缘。 它接受灰度图像作为输入,并使用多级算法。可以使用imgproc
类的Canny()
方法在图像上执行此操作,以下是此方法的语法。
Imgproc.Canny(image, edges, threshold1, threshold2)
该方法接受以下参数 -
- image - 表示此操作的源(输入图像)的
Mat
对象。 - edges - 表示此操作的目标(边缘)的
Mat
对象。 - threshold1 - 类型为
double
的变量表示滞后过程的第一个阈值。 - threshold2 - 类型为
double
的变量表示滞后过程的第二个阈值。
示例
以下程序是演示如何在给定图像上执行Canny边缘检测操作的示例。
package com.zyiz.miscellaneous; import org.opencv.core.Core; import org.opencv.core.Mat; import org.opencv.imgcodecs.Imgcodecs; import org.opencv.imgproc.Imgproc; public class CannyEdgeDetection { public static void main(String args[]) throws Exception { // Loading the OpenCV core library System.loadLibrary(Core.NATIVE_LIBRARY_NAME); // Reading the Image from the file and storing it in to a Matrix object String file = "F:/worksp/opencv/images/sample3.jpg"; // Reading the image Mat src = Imgcodecs.imread(file); // Creating an empty matrix to store the result Mat gray = new Mat(); // Converting the image from color to Gray Imgproc.cvtColor(src, gray, Imgproc.COLOR_BGR2GRAY); Mat edges = new Mat(); // Detecting the edges Imgproc.Canny(gray, edges, 60, 60*3); // Writing the image Imgcodecs.imwrite("F:/worksp/opencv/images/canny_output.jpg", edges); System.out.println("Image Loaded"); } }
假定以下是上述程序中指定的输入图像:sample3.jpg
。
执行上面示例代码,得到以下结果 -
上一篇:OpenCV彩色映射图
下一篇:OpenCV霍夫线变换
关注微信小程序
扫描二维码
程序员编程王