飘零雁 2023-05-28 17:10 采纳率: 33.3%
浏览 20

open cv 检测矩形是否闭合

img

img

两个图中四个顶点的对应坐标是一样,那么如何通过 opencv api 检测到以上两张图片内容的不同。

  • 写回答

2条回答 默认 最新

  • 于扶摇 2023-05-28 18:11
    关注
    
    import cv2  
      
    # 读取图片  
    img1 = cv2.imread('image1.jpg')  
    img2 = cv2.imread('image2.jpg')  
      
    # 检测第一个矩形  
    rect1 = cv2.minAreaRect(cv2.findContours(img1, cv2.RETR_EXTERNAL))  
    box1 = cv2.boxPoints(rect1)  
    pt1 = tuple(box1[0])  
    pt2 = tuple(box1[1])  
    pt3 = tuple(box1[2])  
    pt4 = tuple(box1[3])  
    cv2.drawContours(img1, [pt1, pt2, pt3, pt4], -1, (0, 0, 255), 2)  
      
    # 检测第二个矩形  
    rect2 = cv2.minAreaRect(cv2.findContours(img2, cv2.RETR_EXTERNAL))  
    box2 = cv2.boxPoints(rect2)  
    pt5 = tuple(box2[0])  
    pt6 = tuple(box2[1])  
    pt7 = tuple(box2[2])  
    pt8 = tuple(box2[3])  
    cv2.drawContours(img2, [pt5, pt6, pt7, pt8], -1, (0, 0, 255), 2)  
      
    # 检查两个矩形是否闭合  
    if cv2.isClosed(box1, pt1) == True and cv2.isClosed(box1, pt2) == True and \  
       cv2.isClosed(box1, pt3) == True and cv2.isClosed(box1, pt4) == True and \  
       cv2.isClosed(box2, pt5) == True and cv2.isClosed(box2, pt6) == True and \  
       cv2.isClosed(box2, pt7) == True and cv2.isClosed(box2, pt8) == True:  
        print('The two rectangles are closed.')  
    else:  
        print('The two rectangles are not closed.')  
      
    # 显示图片  
    cv2.imshow('image1', img1)  
    cv2.imshow('image2', img2)  
    cv2.waitKey(0)  
    cv2.destroyAllWindows()
    
    评论

报告相同问题?

问题事件

  • 创建了问题 5月28日

悬赏问题

  • ¥15 c语言怎么用printf(“\b \b”)与getch()实现黑框里写入与删除?
  • ¥20 怎么用dlib库的算法识别小麦病虫害
  • ¥15 华为ensp模拟器中S5700交换机在配置过程中老是反复重启
  • ¥15 java写代码遇到问题,求帮助
  • ¥15 uniapp uview http 如何实现统一的请求异常信息提示?
  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?