
- 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 | ![]() |
廣告