71 形态学操作—击中击不中
代码
import cv2 as cv
import numpy as np
src = cv.imread("../images/cross.png")
cv.namedWindow("input", cv.WINDOW_AUTOSIZE)
cv.imshow("input", src)
# 图像二值化
gray = cv.cvtColor(src, cv.COLOR_BGR2GRAY)
ret, binary = cv.threshold(gray, 0, 255, cv.THRESH_BINARY_INV | cv.THRESH_OTSU)
# 击中击不中
se = cv.getStructuringElement(cv.MORPH_CROSS, (11, 11), (-1, -1))
binary = cv.morphologyEx(binary, cv.MORPH_HITMISS, se)
cv.imshow("black hat", binary)
cv.waitKey(0)
cv.destroyAllWindows()
实验结果
解释
形态学的击中击不中操作,根据结构元素不同,可以提取二值图像中的一些特殊区域,得到我们想要的结果。击中击不中操作的API也是我们前面一直用的API,只是对OP参数的修改
dst = cv.morphologyEx(src, op, kernel[, dst[, anchor[, iterations[, borderType[, borderValue]]]]])
src
输入图像op
形态学操作kernel
结构元素dst
输出图像anchor
中心位置锚定iterations
循环次数borderType
边缘填充类型borderValue
边界不变时的边界值。默认值具有特殊含义。
其中op指定为MORPH_HITMISS即表示使用击中击不中
所有内容均来源于贾志刚老师的知识星球——OpenCV研习社,本文为个人整理学习,已获得贾老师授权,有兴趣、有能力的可以加入贾老师的知识星球进行深入学习。