liangwl1751 2022-02-09 14:58 采纳率: 100%
浏览 1780
已结题

如何用Python+opencv提取图片中矩形顶点的坐标位置

比如下面这张图,如何确定张爱玲图片的四个顶角坐标并提取出它的图片?
我只能得到它的轮廓图,不能确定坐标😭😭

img

  • 写回答

3条回答 默认 最新

  • ilmss 2022-02-09 16:17
    关注

    先进行边缘检测:
    假设
    CANNY_THRESH_1 = 90
    CANNY_THRESH_2 = 120
    edges = cv2.Canny(gray, CANNY_THRESH_1, CANNY_THRESH_2)
    edges = cv2.dilate(edges, None, iterations=3)
    edges = cv2.erode(edges, None, iterations=1)
    边缘特征比较明显,不同的图片系数差别不大。当前系数效果可以使用。更细的参数没有调整。
    另外做了一些放大和腐蚀,把不需要的一些小的文字区域过滤掉了。方便过滤不需要的轮廓。

    然后提取轮廓:

    查找轮廓

    contours, _ = cv2.findContours(edges, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)

    显示所有轮廓

    mask = np.zeros(img.shape)for c in contours:

    过滤小面积

    if (cv2.contourArea(c) < scale ** 2):
    continue
    cv2.drawContours(mask, [c], 0, (0, 0, 255))cv2.imshow('contours', mask)
    关于函数findContours介绍可以参考:https://www.cnblogs.com/yiyi20120822/p/11506970.html

    提取到的轮廓后用一个比较单间的最小包围矩形就能得到想要的结果。

    最后提取矩形获取顶点:
    rect = cv2.minAreaRect(cnt)box = cv2.boxPoints(rect)box = np.int0(box)
    就可以得到顶点坐标

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 2月14日
  • 已采纳回答 2月10日
  • 赞助了问题酬金5元 2月9日
  • 创建了问题 2月9日

悬赏问题

  • ¥15 recipe通过gem协议传的是什么
  • ¥15 TS2307: Cannot find module 'cc'.
  • ¥15 100小时学会sap 书上pp章节5.22,标准成本计算逻辑?
  • ¥50 达梦数据库误删日志文件重做DAMENG01.log启动仍然-712错误
  • ¥15 cellranger化学处理类型报错
  • ¥15 用texstudio插入图片出现下面情况,怎么办
  • ¥15 ubantu 用samba挂载windows的共享文件夹,无法挂载二级目录和修改文件
  • ¥15 有没有会五轴RTCP算法,双转台AC结构。
  • ¥25 对于LSTM实践问题的疑问
  • ¥15 PHP中关于排名和显示的问题