- OpenCV 教程
- OpenCV - 首页
- OpenCV - 概述
- OpenCV - 环境配置
- OpenCV - 图片存储
- OpenCV - 读取图片
- OpenCV - 写入图片
- OpenCV - 图形用户界面 (GUI)
- 绘图函数
- OpenCV - 绘制圆形
- OpenCV - 绘制直线
- OpenCV - 绘制矩形
- OpenCV - 绘制椭圆
- OpenCV - 绘制折线
- OpenCV - 绘制凸多边形
- OpenCV - 绘制带箭头的线
- OpenCV - 添加文本
- 滤波
- OpenCV - 双边滤波
- OpenCV - 方框滤波
- OpenCV - 平方盒滤波
- OpenCV - Filter2D
- OpenCV - 膨胀
- OpenCV - 腐蚀
- OpenCV - 形态学操作
- OpenCV - 图像金字塔
- Sobel 导数
- OpenCV - Sobel 算子
- OpenCV - Scharr 算子
- 摄像头和人脸检测
- OpenCV - 使用摄像头
- OpenCV - 图片中的人脸检测
- 使用摄像头进行人脸检测
- OpenCV 有用资源
- OpenCV - 快速指南
- OpenCV - 有用资源
- OpenCV - 讨论
OpenCV - Sobel 算子
使用Sobel 算子,您可以检测图像在水平和垂直方向上的边缘。您可以使用sobel()方法对图像应用 Sobel 算子。以下是此方法的语法:
Sobel(src, dst, ddepth, dx, dy)
此方法接受以下参数:
src − 表示源(输入)图像的 Mat 类对象。
dst − 表示目标(输出)图像的 Mat 类对象。
ddepth − 表示图像深度的整型变量 (-1)
dx − 表示 x 方向导数的整型变量。(0 或 1)
dy − 表示 y 方向导数的整型变量。(0 或 1)
示例
以下程序演示了如何在给定图像上执行 Sobel 算子。
import org.opencv.core.Core; import org.opencv.core.Mat; import org.opencv.imgcodecs.Imgcodecs; import org.opencv.imgproc.Imgproc; public class SobelTest { public static void main(String args[]) { // 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 ="E:/OpenCV/chap16/sobel_input.jpg"; Mat src = Imgcodecs.imread(file); // Creating an empty matrix to store the result Mat dst = new Mat(); // Applying sobel on the Image Imgproc.Sobel(src, dst, -1, 1, 1); // Writing the image Imgcodecs.imwrite("E:/OpenCV/chap16/sobel_output.jpg", dst); System.out.println("Image processed"); } }
假设以上程序中指定的输入图像是sobel_input.jpg。
输出
执行程序后,您将获得以下输出:
Image Processed
如果打开指定的路径,您可以观察到输出图像如下:
Sobel 变体
对最后两个参数 (dx 和 dy)(在 0 和 1 之间)传递不同的值,您将获得不同的输出:
// Applying sobel on the Image Imgproc.Sobel(src, dst, -1, 1, 1);
下表列出了Sobel()方法中变量dx和dy的各种值及其各自的输出。
X 方向导数 | Y 方向导数 | 输出 |
---|---|---|
0 | 1 | |
1 | 0 | |
1 | 1 |
广告