欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

opencv使用sobel算子提取图像的边缘信息

程序员文章站 2022-07-14 11:53:35
...

import cv2
import numpy as np

img = cv2.imread('../data/ren.png', 0)


sobelx = cv2.Sobel(img, cv2.CV_64F, 1, 0)  # 获取水平方向边缘梯度,第二个参数表示获取所有边缘信息不要遗漏
sobely = cv2.Sobel(img, cv2.CV_64F, 0, 1)  # 获取垂直方向边缘梯度,第二个参数表示获取所有边缘信息不要遗漏

sobelx = cv2.convertScaleAbs(sobelx)  # 取绝对值
sobely = cv2.convertScaleAbs(sobely)  # 取绝对值

dst = cv2.addWeighted(sobelx, 1, sobely, 1, 0)  # 将两个方向的梯度结合成新的一个完整图像的梯度

cv2.imshow('dst', dst)
cv2.waitKey()
cv2.destroyAllWindows()

cv2.imwrite('../data/sobel.jpg', dst)

原图
opencv使用sobel算子提取图像的边缘信息
opencv使用sobel算子提取图像的边缘信息

2020年,我想给自己好好去爱一次的机会

相关标签: 计算机视觉