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)
原图


2020年,我想给自己好好去爱一次的机会
本文介绍如何使用Python和OpenCV库进行图像边缘检测。通过Sobel算子获取水平和垂直方向的边缘梯度,然后结合两个方向的梯度形成完整的图像梯度。最后展示了处理后的图像效果。
175

被折叠的 条评论
为什么被折叠?



