在 Python (OpenCV) 中从左到右对轮廓进行排序

2023-12-20

我正在使用 Python 和 OpenCV 来检测图像中的轮廓。但是,当我运行以下代码以使用轮廓索引仅绘制特定轮廓时,由于分配的索引是随机的,因此我得到了错误的输出。

所以我找到了质心(在我的例子中,所有质心都位于同一水平线上)。 有什么方法可以根据质心的 x 值从左到右(从 0 到 n)对轮廓索引进行排序?

您能显示相同的代码吗?任何帮助将不胜感激!

contours, hierarchy = cv2.findContours(thresh,cv2.RETR_LIST,cv2.CHAIN_APPROX_SIMPLE)
i = 9         ## Contour Index <----

cv2.drawContours(img,contours[i:i+1],-1,(0,0,255),2)

centroids = []

for cnt in contours:        
    mom = cv2.moments(cnt)        
    (x,y) = int(mom['m10']/mom['m00']), int(mom['m01']/mom['m00'])         
    cv2.circle(org,(x,y),4,(255,255,255),-1)        
    centroids.append((x,y)

在python中实现列表的de sort功能here https://softwareengineering.stackexchange.com/questions/151069/sorting-using-a-custom-definition-of-and-in-python.

在实现的函数中,您计算​​中心并验证 X 位置是否大于或小于另一个位置。如果大于则返回 1,小于-1 等于 0。

def greater(a, b):
    momA = cv2.moments(a)        
    (xa,ya) = int(momA['m10']/momA['m00']), int(momA['m01']/momA['m00'])

    momB = cv2.moments(b)        
    (xb,yb) = int(momB['m10']/momB['m00']), int(momB['m01']/momB['m00'])
    if xa > xb:
        return 1

    if xa == xb:
        return 0
    else
        return -1

当然,如果只计算一次中心,你可以做得更好。

然后就做

contours.sort(greater)
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

在 Python (OpenCV) 中从左到右对轮廓进行排序 的相关文章

随机推荐

  • 如何使用第一个逗号将字符串拆分为段落?

    我有字符串 address 10 Madison Avenue New York NY 212 538 1884 像这样分割它的最好方法是什么 p 10 Madison Avenue p p New York NY 212 538 1884
  • Apache Maven 错误:无法将工件 org.apache.maven.plugins:maven-clean-plugin:pom: 2.5 传输到中央

    我对此很陌生 我正在 apache maven 上工作 我在代理服务器后面工作 每次 我都会尝试构建maven项目 它给了我这个错误 我还更改了 settings xml 文件中的代理设置 但它不起作用 它一直给我同样的问题 构建失败 我在
  • 如何修复缺少对象的 git 存储库?

    我的开发存储库在某个时候丢失了一个对象 git fsck fatal failed to read object 2dddc84156fa30e4614a7ea5a1895885011b8db8 Invalid argument git c
  • 如何允许特定服务器访问我的API?

    我正在使用node js express和mongodb编写一个API 它将在另一台服务器中使用 我只希望该服务器 或将来的更多服务器 能够访问我的 API 我怎样才能做到这一点 如果您只想根据另一台服务器的 IP 进行限制 那么您可以定义
  • numpy 和 pandas timedelta 错误

    在 Python 中 我使用 pandas 生成了一个日期数组 或从 CSV 文件中读取 并且我想为每个日期添加一年 我可以使用 pandas 让它工作 但不能使用 numpy 我究竟做错了什么 或者这是 pandas 或 numpy 中的
  • 线性回归预测中的个别项

    我在 R 中对某些数据集进行了回归分析 并尝试预测数据集中每行的每个自变量对因变量的贡献 所以像这样 set seed 123 y lt rnorm 10 m lt data frame v1 rnorm 10 v2 rnorm 10 v3
  • 停止Excel科学计数法转换[关闭]

    Closed 这个问题不符合堆栈溢出指南 help closed questions 目前不接受答案 有没有办法停止Excel将数据转换为科学记数法 Microsoft Excel 显然假定任何包含数字和 E 的数据都应该是科学记数法并将其
  • 编写集成高斯的 Python 函数的最佳方法?

    在尝试使用 scipy 的四边形方法对高斯进行积分时 假设有一个名为 gauss 的高斯方法 我在将所需参数传递给高斯并让四边形对正确的变量进行积分时遇到问题 有谁有一个关于如何使用四元组和多维函数的好例子吗 但这让我产生了一个更宏大的问题
  • 在 JavaFX 中使用包含伪类的查询

    我正在尝试在编程查询中使用伪类Node lookupAll 然而这似乎给出了意想不到的结果 我在网上搜索过 找不到任何表明 Node lookupAll 不支持伪类的信息 public class Foo extends Applicati
  • jQuery Ajax 调用和 Html.AntiForgeryToken()

    我已经在我的应用程序中实施了缓解措施CSRF 攻击 https en wikipedia org wiki Cross site request forgery以下是我在互联网上的一些博客文章中读到的信息 特别是这些帖子是我实施的驱动力 A
  • 找不到 *.apk 错误

    2011 06 22 23 55 09 main Android Launch 2011 06 22 23 55 09 main adb is running normally 2011 06 22 23 55 09 main Could
  • 在公司防火墙后面运行 npm:我需要告诉安全团队什么?

    我正在尝试运行 node js 但无法安装任何软件包npm被阻止 我已经尝试过这里的解决方案 如何在cntlm配置文件中填写代理信息 https stackoverflow com questions 9181637 how to fill
  • 使用逗号时将 String 转换为 double

    我有一个 UITextfield 它正在由数据库中的数据填充 该值的格式是用逗号分隔小数部分 所以 结构类似于 1 250 50 我将数据保存在字符串中 当我尝试使用 doubleValue 方法将字符串转换为双精度数或浮点数时 我得到 1
  • 多对多关系中的问题

    我有两张桌子jewelry j id j name Description and style style id style name image 每张表与另一张表之间是多对多的关系 因为一个珠宝产品可以有多种款式 并且同一款式的产品有多个
  • 实现普通的 javascript 轮播。(无需插件)

    我正在通过纯 JavaScript 实现轮播 不使用插件 我想设置上一个和下一个按钮来控制幻灯片图像 var firstval 0 function Carousel firstval 2 parent document getElemen
  • Bouncy Castle ECDSA 从私钥创建公钥

    我正在尝试用 C 签署比特币交易 我有 2 位代码正在尝试完成 我可以使用 Bouncy castle 创建一组私钥和公钥 我可以将其转换为钱包导入格式 我还可以从 ECDSA 公钥生成比特币地址 但是 我想签署一笔交易 而我拥有的只是我的
  • 如何在QtCreator中为项目创建文件夹或子目录? [复制]

    这个问题在这里已经有答案了 我想创建子目录和文件夹来组织 Qt 中的代码 我尝试在 shell explorer 中手动创建该目录 但 Qt 无法识别它 在 QT Creator 3 1 x 之前 您可以右键单击您的项目 gt 添新 and
  • Apache Camel 到底是如何处理 JMSReplyTo 的?骆驼什么时候隐式使用目的地?

    使用 spring camel 我构建了一条从 JMS 主题进行消费的路由 预计为每个输入消息设置 JMSReplyTo 将消息分割成更小的块 将它们发送到 REST 处理器 然后聚合答案并应该生成发送到 JMSReplyTo 指向的目的地
  • Android,ListView IllegalStateException:“适配器的内容已更改,但 ListView 未收到通知”

    我想做的事 运行一个后台线程来计算 ListView 内容并部分更新 ListView 同时计算结果 我知道我必须避免什么 我不能弄乱后台线程中的 ListAdapter 内容 因此我继承了 AsyncTask 并从 onProgressU
  • 在 Python (OpenCV) 中从左到右对轮廓进行排序

    我正在使用 Python 和 OpenCV 来检测图像中的轮廓 但是 当我运行以下代码以使用轮廓索引仅绘制特定轮廓时 由于分配的索引是随机的 因此我得到了错误的输出 所以我找到了质心 在我的例子中 所有质心都位于同一水平线上 有什么方法可以