最终效果如下:
不仅标出了裂纹位置,还标出了裂纹的尺寸
原图如下:
环境:
python 3.9.13
numpy 1.24.4
opencv-python 3.4.18.65
核心原理就是基于opencv的图片处理及轮廓查找,具体逻辑看代码,话不多说上代码:
# 在一张图片上检测圆
import cv2
import numpy as np
def detect_circle(img):
"""在一张图片上检测圆
img: 必须是二值化的图
"""
roi=np.zeros(img.shape[:2], dtype=np.uint8)
mask = np.ones_like(img) * 255
#