本文介绍如何使用Python和OpenCV库,高效处理9000x7000像素的大尺寸图片,准确识别其中白色区域内的圆形。 直接处理如此高分辨率的图片效率低下,因此我们将采用图像缩放、二值化和霍夫变换等技术优化处理流程。
原始方法中使用霍夫变换检测圆形,但结果包含大量冗余信息。为了提高准确性,我们需要改进算法,主要步骤如下:
cv2.resize
函数缩小图像尺寸,降低计算复杂度,同时保持足够的细节用于圆形识别。cv2.threshold
函数将灰度图像二值化,将白色区域与其他区域清晰地区分开。 这里设置合适的阈值至关重要,可以根据图片的实际情况调整。cv2.HoughCircles
函数进行霍夫圆变换,检测图像中的圆形。 参数需要根据图像特点进行微调,例如param1
和param2
控制边缘检测的敏感度和累加器阈值。以下是一个改进后的Python代码示例:
import cv2 import numpy as np image_path = r"C:Users17607Desktopsmls picturesPic_20231122151507973.bmp" # 请替换为你的图片路径 def detect_circles(image_path): # 读取图像 img = cv2.imread(image_path) # 缩放图像 (调整缩放比例根据实际情况修改) img = cv2.resize(img, (img.shape[1] // 10, img.shape[0] // 10)) # 转换为灰度图像 gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) # 二值化处理 (调整阈值根据实际情况修改) _, thresh = cv2.threshold(gray, 200, 255, cv2.THRESH_BINARY) # 霍夫圆变换 (调整参数根据实际情况修改) circles = cv2.HoughCircles(gray, cv2.HOUGH_GRADIENT, 1, 40, param1=50, param2=30, minRadius=0, maxRadius=0) if circles is not None: circles = np.round(circles[0, :]).astype("int") for (x, y, r) in circles: # 筛选位于白色区域的圆形 (调整阈值根据实际情况修改) if np.mean(thresh[y - r:y + r, x - r:x + r]) > 200: cv2.circle(img, (x, y), r, (0, 255, 0), 2) # 画出圆圈 cv2.circle(img, (x, y), 2, (0, 0, 255), 3) # 画出圆心 return img result_image = detect_circles(image_path) cv2.imshow("Detected Circles", result_image) cv2.waitKey(0) cv2.destroyAllWindows()
此代码首先缩放图像以提高效率,然后进行灰度转换和二值化处理,再使用霍夫圆变换检测圆形。最后,通过检查圆形区域的平均灰度值来筛选出位于白色区域内的圆形,并将其绘制在图像上。 请根据实际图像调整代码中的阈值和霍夫变换参数以获得最佳结果。 这比之前的版本更简洁高效,并提供了更清晰的注释。