码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 一种基于OpenCV的图片倾斜矫正方法


    需求描述:

    对倾斜的图片进行矫正,返回倾斜角度和矫正后的图片。

    解决方法:

    1、各种角度点被投影到一个累加器阵列中,其中倾斜角度可以定义为在最大化对齐的搜索间隔内的投影角度。

    2、以不同的角度旋转图像,并为每次迭代生成像素的直方图。

    3、为了确定倾斜角度,比较峰值之间的最大差异,并使用这个倾斜角度,旋转图像来纠正倾斜。

    1. #coding=utf-8
    2. import cv2
    3. import numpy as np
    4. def rotate_image(image, angle):
    5. (h, w) = image.shape[: 2]
    6. center = (w // 2, h // 2)
    7. M = cv2.getRotationMatrix2D(center, angle, 1.0)
    8. corrected = cv2.warpAffine(image, M, (w, h), flags = cv2.INTER_CUBIC, \
    9. borderMode = cv2.BORDER_REPLICATE)
    10. return corrected
    11. def determine_score(arr):
    12. histogram = np.sum(arr, axis = 2, dtype = float)
    13. score = np.sum((histogram[..., 1 :] - histogram[..., : -1]) ** 2, \
    14. axis = 1, dtype = float)
    15. return score
    16. def correct_skew(image, delta = 0.1, limit = 5):
    17. thresh = cv2.threshold(image, 0, 255, cv2.THRESH_BINARY_INV + \
    18. cv2.THRESH_OTSU)[1]
    19. angles = np.arange(-limit, limit + delta, delta)
    20. img_stack = np.stack([rotate_image(thresh, angle) for angle \
    21. in angles], axis = 0)
    22. scores = determine_score(img_stack)
    23. best_angle = angles[np.argmax(scores)]
    24. corrected = rotate_image(image, best_angle)
    25. return best_angle, corrected
    26. if __name__ == "__main__":
    27. file_path=r'D:/_21.png'
    28. img = cv2.imread(file_path, 0)
    29. angle, corrected = correct_skew(img)
    30. print(angle)
    31. cv2.imwrite(r'D:/temp_' + file_path.split('/')[-1], corrected)

    执行结果:

    矫正前:

    矫正后:

  • 相关阅读:
    【8.2】代码源 - 【货币系统】【硬币】【新年的问题(数据加强版)】【三段式】
    3_SpringMVC_执行流程
    注意力机制详解(Attention详解)
    日常问题:MySQL排序字段数据相同不能分页问题
    java计算机毕业设计游戏账号交易源程序+mysql+系统+lw文档+远程调试
    再回首 Java核心技术 2 —— Java数据类型
    go旧版依赖切换到新版
    浅析Redis基础数据结构
    五款好用到爆炸的小众软件,用过的都好说!建议收藏转发
    ARM GNU汇编代码分析
  • 原文地址:https://blog.csdn.net/shenliang1985/article/details/137798608
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号