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

如何用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 基于RTKLIB框架写的精密单点定位-AR
  • ¥15 PFENet的预训练权重
  • ¥15 程序哪有错误怎么改?
  • ¥15 交换机和交换机之间的链路带宽以及主机带宽的理解
  • ¥15 ai创想家对战模式代码
  • ¥15 集合A由3个2行4列二维数组构成,从集合A中任意取一个二维数组元素、如果该二维数组元素的对应列位置的上、下两数都是奇数,而且仅有2个列是奇数/奇数,则该数组有意义,并放入集合B中打印输出。
  • ¥15 电信IPV6 无法外网访问吗
  • ¥15 有偿求效果比较好的遥感影像匹配的c++代码
  • ¥15 博主,你好,我下载了你的智能网联汽车辅助驾驶安全信息检测系统,现在不会运行,可以教我吗,
  • ¥15 怎么在excle输入下列公式