python opencv之提取轮廓并拟合圆

图片存储地址为:C:\Users\Pictures\test.png,该图像图片背景是黑色的,目标区域是亮的,目标区域是两段圆弧和两段曲线构成的封闭区域,其中两段圆弧属于同一个圆,但在目标区域的相对位置,也就是不是相邻的,现在用python+opencv提取轮廓并拟合圆弧的圆心和半径。

1、拟合所有圆弧

python 复制代码
import cv2
import numpy as np
​
# 读取图像
image_path = r'C:\Users\Pictures\test.png'
image = cv2.imread(image_path)
​
# 转换为灰度图像
gray_image = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)
​
# 对图像进行二值化处理
_, threshold_image = cv2.threshold(gray_image, 127, 255, cv2.THRESH_BINARY)
​
# 查找图像轮廓
contours, _ = cv2.findContours(threshold_image, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)
​
# 迭代所有轮廓
for contour in contours:
    # 拟合轮廓为圆弧(仅拟合最小外接圆)
    (x, y), radius = cv2.minEnclosingCircle(contour)
​
    # 绘制圆弧
    cv2.circle(image, (int(x), int(y)), int(radius), (0, 255, 0), 2)
​
# 显示结果图像
cv2.imshow('Detected Arcs', image)
cv2.waitKey(0)
cv2.destroyAllWindows()

2、拟合最大圆弧

python 复制代码
import cv2
import numpy as np
​
# 读取图像
image_path = r'C:\Users\Pictures\test.png'
image = cv2.imread(image_path)
​
# 转换为灰度图像
gray_image = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)
​
# 对图像进行二值化处理
_, threshold_image = cv2.threshold(gray_image, 127, 255, cv2.THRESH_BINARY)
​
# 查找图像轮廓
contours, _ = cv2.findContours(threshold_image, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)
​
max_radius = 0
max_circle_center = None
​
# 迭代所有轮廓
for contour in contours:
    # 拟合轮廓为圆弧(仅拟合最小外接圆)
    (x, y), radius = cv2.minEnclosingCircle(contour)
​
    if radius > max_radius:
        max_radius = radius
        max_circle_center = (int(x), int(y))
​
# 绘制最大半径的圆
cv2.circle(image, max_circle_center, int(max_radius), (0, 255, 0), 2)
​
# 在图像上标注圆心和直径
cv2.putText(image, f"Center: {max_circle_center}", (50, 50), cv2.FONT_HERSHEY_SIMPLEX, 1, (0, 0, 255), 2)
cv2.putText(image, f"Diameter: {2 * max_radius}", (50, 100), cv2.FONT_HERSHEY_SIMPLEX, 1, (0, 0, 255), 2)
​
# 显示结果图像
cv2.imshow('Detected Arcs', image)
cv2.waitKey(0)
cv2.destroyAllWindows()
相关推荐
Ashlee_code16 分钟前
关税战火中的技术方舟:新西兰证券交易所的破局之道 ——从15%关税冲击到跨塔斯曼结算联盟,解码下一代交易基础设施
java·python·算法·金融·架构·系统架构·区块链
qq_3168377520 分钟前
String boot 接入 azure云TTS
python·flask·azure
蓝倾97635 分钟前
电商API接口的优势、数据采集方法及功能说明
开发语言·python·api·开放api·电商开放平台
倔强青铜三43 分钟前
GIL竟是Python命中注定的解药?统治AI时代的核心秘密!
人工智能·python·ai编程
cliffordl44 分钟前
wxPython 实践(二)基础控件
python
倔强青铜三1 小时前
大揭秘!Python类没有真正私有属性的原因
人工智能·python·ai编程
嗯诺1 小时前
切换python多版本
笔记·python
Joker-01111 小时前
深入 Go 底层原理(十):defer 的实现与性能开销
开发语言·golang·defer
筏.k1 小时前
用 Qt 打造优雅的密码输入框:添加右侧眼睛图标切换显示
开发语言·数据库·qt
仪器科学与传感技术博士1 小时前
python:前馈人工神经网络算法之实战篇,以示例带学,弄明白神经网络算法应用的思路、方法与注意事项等
人工智能·python·深度学习·神经网络·算法·机器学习