OpenCV - Canny 边缘检测(Python实现)

Canny 边缘检测
在 OpenCV 中只需要一个函数: cv2.Canny(),就可以完成以上几步。让我们看如何使用这个函数。这个函数的第一个参数是输入图像。第二和第三个分别是 minVal 和 maxVal。第三个参数设置用来计算图像梯度的 Sobel卷积核的大小,默认值为 3。最后一个参数是 L2gradient,它可以用来设定求梯度大小的方程。如果设为 True,就会使用我们上面提到过的方程,否则使用方程: Edge−Gradient (G) = jG2 xj + jG2 yj 代替,默认值为 False。

import cv2
import numpy as np

minVal,maxVal = 0,0 #阈值

def nothing(x):#回调函数更新图像
    #获取滑条位置
    minVal = cv2.getTrackbarPos('minVal','Canny')
    maxVal = cv2.getTrackbarPos('maxVal','Canny')
    edges = cv2.Canny(img,minVal,maxVal)
    cv2.imshow('Canny',edges)
        
img = cv2.imread('image.jpg',0)#读取图片
cv2.namedWindow('image')#显示原图
cv2.imshow('image',img)

cv2.namedWindow('Canny')#显示检测图
#创建两个滑条
cv2.createTrackbar('minVal','Canny',0,255,nothing)
cv2.createTrackbar('maxVal','Canny',0,255,nothing)

e
  • 2
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值