Java+opencv3.2.0之sobel算子

sobel算子主要是应用于边缘检测的一个离散的一阶差分算子,用来计算图像亮度函数的一阶梯度的近似值。
sobel算子的计算过程:
假设作用图像为I,
(1)分别求得在x和y方向的导数
水平变化:将I与一个奇数大小的内核Gx卷积
垂直变化:将I与一个奇数大小的内核Gy卷积
(2)在图像的每一点,求出近似梯度

函数: Imgproc.Sobel(Mat src, Mat dst, int ddepth, int dx, int dy, int ksize, double scale, double delta, int borderType)
参数说明:
src:源图像
dst:检测结果图像
ddepth:输出图像的深度
dx:x方向上的差分阶数
dy:y方向上的差分阶数
ksize:sobel核的大小,默认为3
scale:缩放因子
delta:结果存入输出图像前可选的delta值,默认为0
borderType:边界模式,默认BORDER_DEFAULT

示例代码:

public static void main(String[] args)
    {
        System.loadLibrary(Core.NATIVE_LIBRARY_NAME);

        Mat src = Imgcodecs.imread("F:\\2011031213205880528.jpg", Imgcodecs.IMREAD_GRAYSCALE);

        Mat dst = src.clone();
        Mat dstx = src.clone();
        Mat dsty = src.clone();
        Imgproc.GaussianBlur(src, dst, new Size(3, 3), 0);

        Imgproc.Sobel(dst, dstx, -1, 1, 0, 3, 1, 0, Core.BORDER_DEFAULT);
        Imgcodecs.imwrite("F:\\dstx.jpg", dstx);

        Imgproc.Sobel(dst, dsty, -1, 0, 1, 3, 1, 0, Core.BORDER_DEFAULT);
        Imgcodecs.imwrite("F:\\dsty.jpg", dsty);

        Core.addWeighted(dstx, 0.5, dsty, 0.5, 0, dst);

        Imgcodecs.imwrite("F:\\dst.jpg", dst);
    }

源图片:
这里写图片描述

x方向sobel:
这里写图片描述

y方向sobel:
这里写图片描述

整体方向:
这里写图片描述

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值