二、基于OpenCV+OCR实现图像扫描

对于我们生活中拍的关于单据以及文稿,我们如何将其转为成文档形式呢?对此我们可以利用OpenCV的图像处理来实现。

一、设计思路

Step1:边缘检测,抓取出文稿的边缘。

Step:2:获取轮廓,利用轮廓识别等基本算法获取到文稿的基本外轮廓。

Step3:进行透视变换,使文稿更加直观的展现。

Step4:  OCR识别。

二、透视变换

图像的透视变换(Perspective Transformation)是指将图像利用透视变换矩阵投影到一个新的视平面(Viewing Plane),也称作投影映射(Projective Mapping)。

如图所示,将原先图像投影到一个新的平面,让图像更直观。

三、OCR识别

OCR 识别,即光学字符识别,是一种通过扫描和识别纸质文档上的文字,将其转换成计算机可编辑和处理的数字文本格式的技术。简单来说,OCR 识别就是将纸质文档上的文字“翻译”成电脑能读懂的文字。

四、代码复现

(1)首先导入一些需要用的模块并且自定义一些需要的函数

import numpy as np
import cv2
import pytesseract
from PIL import Image

#自定义一个函数,用来计算文档图像的各个点坐标
def order_points(pts):
	# 一共4个坐标点
	rect = np.zeros((4, 2), dtype = "float32")

	# 按顺序找到对应坐标0123分别是 左上,右上,右下,左下
	# 计算左上,右下
	s = pts.sum(axis = 1)
	rect[0] = pts[np.argmin(s)]
	rect[2] = pts[np.argmax(s)]

	# 计算右上和左下
	diff = np.diff(pts, axis = 1)
	rect[1] = pts[np.argmin(diff)]
	rect[3] = pts[np.argmax(diff)]

	return rect
#自定义仿射变换函数
def four_point_transform(image, pts):
	# 获取输入坐标点
	rect = order_points(pts)
	(tl, tr, br, bl) = rect

	# 计算输入的w和h值
	widthA = np.sqrt(((br[0] - bl[0]) ** 2) + ((br[1] - bl[1]) ** 2))
	widthB = np.sqrt(((tr[0] - tl[0]) ** 2) + ((tr[1] - tl[1]) ** 2))
	maxWidth = max(int(widthA), int(widthB))

	heightA = np.sqrt(((tr[0] - br[0]) ** 2) + ((tr[1] - br[1]) ** 2))
	heightB = np.sqrt(((tl[0] - bl[0]) ** 2) + ((tl[1] - bl[1]) ** 2))
	maxHeight = max(int(heightA), int(heightB))

	# 变换后对应坐标位置
	dst = np.array([
		[0, 0],
		[maxWidth - 1, 0],
		[maxWidth - 1, maxHeight - 1],
		[0, maxHeight - 1]], dtype = "float32")

#自定义一个resize函数,用来改变图像的大小
def resize(image, width=None, height=None, inter=cv2.INTER_AREA):
	dim = None
	(h, w) = image.shape[:2]
	if width is None and height is None:
		return image
	if width is None:
		r = height / float(h)
		dim = (int(w * r), height)
	else:
		r = width / float(w)
		dim = (width, int(h * r))
	resized = cv2.resize(image, dim, interpolation=inter)
	return resized

(2)读取进来需要处理的图像并进行预处理(灰度处理,高斯滤波及边缘检测)

#读取进来需要扫描的图像
image=cv2.imread('D:\\OpenCV\\practice\\Scan\\images\\page.jpg')
ratio = image.shape[0] / 1000.0
orig = image.copy()

# 预处理
gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)
gray = cv2.GaussianBlur(gray, (5, 5), 0)
edged = cv2.Canny(gray, 75, 200)

# 展示预处理结果
print("STEP 1: 边缘检测")
cv2.imshow("Image", image)
cv2.waitKey(5000)
cv2.destroyAllWindows()
cv2.imshow("Edged", edged)
cv2.waitKey(5000)
cv2.destroyAllWindows()

(3)轮廓检测

# 轮廓检测
cnts = cv2.findContours(edged.copy(), cv2.RETR_LIST, cv2.CHAIN_APPROX_SIMPLE)[1]
cnts = sorted(cnts)

# 遍历轮廓
for c in cnts:
	# 计算轮廓近似
	peri = cv2.arcLength(c, True)
	# C表示输入的点集
	# epsilon表示从原始轮廓到近似轮廓的最大距离,它是一个准确度参数
	# True表示封闭的
	approx = cv2.approxPolyDP(c, 0.02 * peri, True)
	# 4个点的时候就拿出来
	if len(approx) == 4:
		screenCnt = approx
		break

(4)透视变换,并且展示结果图

#仿射变换
warped = four_point_transform(orig, screenCnt.reshape(4, 2) * ratio)

# 二值处理
warped = cv2.cvtColor(warped, cv2.COLOR_BGR2GRAY)
ref = cv2.threshold(warped, 100, 255, cv2.THRESH_BINARY)[1]
cv2.imwrite('scan.jpg', ref)
# 展示结果
print("STEP 3: 变换")
cv2.imshow("Original", resize(orig, height = 250))
cv2.imshow("Scanned", resize(ref, height = 250))
cv2.waitKey(0)

(5)结果如图所示,对此我们再进行一步OCR识别即可实现文档转化。

cv2.imwrite('scan.jpg',ref)
image = Image.open('D:\OpenCV\scan.jpg')
code = pytesseract.image_to_string(image, lang='eng')
print(code) 

五、总结

到此我们完成了文档扫描这一操作,对于OCR大家可以自行安装并了解其用法。在下节内容中,将更新基于OpenCV的图像拼接,实现全景图像。

### 回答1: QT是一种跨平台的开发框架,可以用来开发各种应用程序。OpenCV是一个开源的计算机视觉库,可以用来处理图像和视频等图像处理任务。OCR(Optical Character Recognition)库是一种能够读取图像中文字并将其转换为可编辑文本的技术。 在使用QT和OpenCV来开发一个汉字识别的图像演示程序时,我们可以按照以下步骤进行: 1. 首先,需要创建一个QT项目,并添加OpenCV的库文件和头文件,以便在项目中使用OpenCV功能。 2. 然后,需要加载待识别的图像文件。可以使用QT的图像处理功能加载图像文件,并在QT的图形界面中显示出来。 3. 接下来,我们可以使用OpenCV图像处理功能对加载的图像进行预处理,以提高识别准确度。例如,可以使用图像平滑、值化等技术来消除噪声和增强图像的对比度。 4. 然后,我们可以使用OCR库来识别图像中的汉字。OCR库可以通过训练和学习,识别不同的汉字字符。可以使用OCR库提供的API来调用该功能,并将识别结果返回给应用程序。 5. 最后,我们可以将识别的汉字结果显示在QT的图形界面中,以便用户查看和编辑。可以使用QT的文本框组件来显示识别出的文字,并提供其他相关的编辑功能。 通过以上步骤,我们可以完成一个简单的QT和OpenCV结合的汉字识别图像演示程序。用户可以通过该程序加载图像文件,并对图像中的汉字进行识别和编辑。这个演示程序可以为用户展示汉字识别的基本原理和功能,并为用户提供一个直观的界面来操作和体验。 ### 回答2: Qt是一种跨平台的C++应用程序开发框架,OpenCV是一个用于图像处理和计算机视觉的开源库,OCR(Optical Character Recognition)是光学字符识别的缩写,用于将印刷体文字转化为可编辑的电子文字。 要实现在Qt中使用OpenCV进行OCR汉字识别,可以按照以下步骤进行: 1. 准备样本数据集:收集一些包含汉字的图像样本,包括不同字体、大小和倾斜度的样本,用于训练和测试OCR模型。 2. 安装OpenCV和Qt:下载并安装OpenCV和Qt开发环境,确保能够在Qt中调用OpenCV库。 3. 加载样本数据集:使用OpenCV读取样本数据集中的图像文件,并将其转换为适合进行OCR处理的数据格式。 4. 预处理图像:对加载的图像进行预处理,例如灰度化、值化、降噪等操作,以提高OCR的识别准确性。 5. 训练OCR模型:使用OpenCV的机器学习算法,如支持向量机(SVM)或卷积神经网络(CNN),对预处理后的图像进行训练,以建立用于识别汉字的模型。 6. 图像识别:使用训练好的OCR模型对待识别的图像进行处理,提取其中的汉字信息,并将其转化为可编辑的电子文字。 7. 在Qt界面中展示结果:将识别到的汉字结果显示在Qt的界面中,以供用户查看和编辑。 通过以上步骤,我们可以在Qt中使用OpenCV库进行OCR汉字识别的演示。用户可以加载图像,点击识别按钮后,程序将自动进行图像处理和汉字识别,并将结果显示在界面上。这样,用户可以方便地通过这个演示程序了解OCR汉字识别的基本原理和实现方式。 ### 回答3: QT是一种流行的跨平台应用程序开发框架,而OpenCV是一个广泛使用的计算机视觉库。OCR(Optical Character Recognition)库可以用于识别图像中的文字。下面是一个300字的中文回答,旨在介绍如何在QT中使用OpenCVOCR库来实现汉字识别的演示程序。 首先,我们需要在QT项目中集成OpenCV库。可以通过在项目文件中添加OpenCV相关的库路径和头文件路径来实现。然后,在QT项目中创建一个窗口,将图像显示在窗口上。 接下来,我们需要加载要识别的图像。使用OpenCV的函数,我们可以读取图像文件,并将其转换为OpenCV的Mat对象。然后,我们可以将Mat对象转换为QT图像对象,以便在QT窗口中显示。 在加载图像后,我们可以使用OCR库来识别其中的汉字。OCR库可以读取OpenCV的Mat对象,然后将其转换为文本。 为了在QT中使用OCR库,可能需要对其进行一些设置和配置。这包括选择合适的OCR引擎,以及设置字库和语言。这些设置可能因库的不同而有所不同,可参考OCR库的文档以获取详细的配置信息。 一旦配置完毕,我们可以调用OCR库的识别函数,将图像传递给它。OCR库将扫描图像,并将识别结果返回为文本。我们可以在QT窗口中显示这些识别结果。 最后,我们可以通过增加一些用户交互功能来改进演示程序。例如,我们可以添加一个按钮,使用户能够选择不同的图像进行识别。我们还可以让用户可以调整OCR库的一些参数,以改进识别的准确性。 总之,通过集成OpenCVOCR库,我们可以在QT中开发一个简单的汉字识别演示程序。这个演示程序可以加载图像,调用OCR库来识别汉字,并在QT窗口中显示识别结果。同时,我们可以通过增加一些用户交互功能来提高演示程序的实用性和可定制性。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值