文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

opencv+python实现图像矫正

2024-04-02 19:55

关注

本文实例为大家分享了opencv+python实现图像矫正的具体代码,供大家参考,具体内容如下

需求:将斜着拍摄的文本图像进行矫正

python代码

import numpy as np
import cv2 as cv


def shape_correction(img):
    (height, width) = img.shape[:2]
    print(img.shape)

    img_gau = cv.GaussianBlur(img, (5, 5), 0)
    canny = cv.Canny(img_gau, 60, 200)
    # cv.imshow("g-canny", canny)
    
    kernel = cv.getStructuringElement(cv.MORPH_CROSS, (4,3)) 
    
    dilated = cv.dilate(canny, kernel, iterations=8)  
    # cv.imshow('img_dilated', dilated)

    # 寻找轮廓
    contours, hierarchy = cv.findContours(dilated, cv.RETR_EXTERNAL, cv.CHAIN_APPROX_NONE)
    # print(len(contours), hierarchy, sep='\n')

    # 找到最外层面积最大的轮廓

    area = 0
    # print("area:{}".format(area))

    index = 0
    for i in range(len(contours)):
        x, y, w, h = cv.boundingRect(contours[i])
        # 排除非文本区域
        if w < 35 and h < 35:
            continue
        # 防止矩形区域过大不精准    
        if h > 0.99 * height or w > 0.99 * width:
            continue
        # draw rectangle around contour on original image
        # cv.rectangle(img, (x, y), (x + w, y + h), (255, 0, 255), 2)
        tmpArea = w * h
        if tmpArea >= area:
            area = tmpArea
            index = i

    # 得到最小外接矩形的(中心(x,y), (宽,高), 旋转角度)
    rect = cv.minAreaRect(contours[index])
    # 画出矩形框
    # box = cv.boxPoints(rect)
    # box = np.int0(box)
    # cv.drawContours(img, [box], 0, (0, 0, 255), 2)

    # cv.imshow('img', img)
    print("rect:{}".format(rect))
    angle = rect[-1]
    # print(angle)

    # 角度大于85度或小于5度不矫正
    if angle > 85 or angle < 5:
        angle = 0
    elif angle < 45:
        angle = angle - 0
    else:
        angle = angle - 90

    M = cv.getRotationMatrix2D(rect[0], angle, 1)
    rotated = cv.warpAffine(img, M, (width, height), flags=cv.INTER_CUBIC, borderValue=(255, 255, 255))
    
    cv.imshow('Rotated', rotated)
    return rotated


src = cv.imread('/res-normal.png', 0)
rotated = shape_correction(src)
cv.waitKey(0)

算法流程

算法核心思想:

获取图像中的文本区域矩形轮廓,找到其中面积最大的,对其进行最小外接矩形计算,得到最小外接矩形的旋转角度,再根据旋转角度进行仿射变换。

测试效果

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程网。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯