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 用三极管设计—个共射极放大电路
  • ¥15 请完成下列相关问题!
  • ¥15 drone 推送镜像时候 purge: true 推送完毕后没有删除对应的镜像,手动拷贝到服务器执行结果正确在样才能让指令自动执行成功删除对应镜像,如何解决?
  • ¥15 求daily translation(DT)偏差订正方法的代码
  • ¥15 js调用html页面需要隐藏某个按钮
  • ¥15 ads仿真结果在圆图上是怎么读数的
  • ¥20 Cotex M3的调试和程序执行方式是什么样的?
  • ¥20 java项目连接sqlserver时报ssl相关错误
  • ¥15 一道python难题3
  • ¥15 牛顿斯科特系数表表示