python身份证识别仪_C#身份证识别相关技术功能详解

本文介绍了使用C#结合EmguCV库进行身份证识别的方法,包括环境搭建、DLL引用、图像处理及OCR识别代码示例。虽然识别率不高,但提供了基本的身份证图像识别流程。
摘要由CSDN通过智能技术生成

最近研究C#相关的OCR技术,图像识别一般C和C++这种底层语言做的比较多,C#主要是依托一些封装好的组件进行调用,这里介绍一种身份证识别的方法。

环境搭建

在File类别下下载这个EXE,进行安装,安装后在目录下能找相应组件,还有些应用的案例。

dll文件夹中的dll引用到C#项目中,x64,x86,tessdata对应OCR识别的类库和语言库,我tessdata中已添加中文语言包,将这三个文件夹放入程序执行文件夹中。

Demo

自己做的小Demo如图:身份证图片是百度上下载的

不得不说这个类库唯一弊端就是文字识别率太低,图像识别效果也不太好

using System;

using System.Collections.Generic;

using System.ComponentModel;

using System.Data;

using System.Drawing;

using System.Linq;

using System.Text;

using System.Threading.Tasks;

using System.Windows.Forms;

using Emgu.CV;

using Emgu.CV.OCR;

using Emgu.CV.Structure;

using System.IO;

namespace EmguCV

{

public partial class Form1 : Form

{

Image imageThreshold;

public Form1()

{

InitializeComponent();

pictureBox1.Enabled = false;

}

private void Form1_Load(object sender, EventArgs e)

{

}

private void button1_Click(object sender, EventArgs e)

{

//第一个参数是语言包文件夹的地址,不写默认在执行文件夹下

Tesseract _ocr = new Tesseract(@"", "chi_sim", OcrEngineMode.TesseractOnly);

_ocr.SetImage(imageThreshold);

_ocr.Recognize();

String text = _ocr.GetUTF8Text();

this.textBox1.Text = text;

}

private void pictureBox2_Click(object sender, EventArgs e)

{

OpenFileDialog of = new OpenFileDialog();

of.Title = "请选择图片";

if (of.ShowDialog() == DialogResult.OK)

{

string file = of.FileName;

Image img = Image.FromFile(file);

pictureBox1.Image = img;

}

Bitmap bitmap = (Bitmap)this.pictureBox1.Image;

Image imageSource = new Image(bitmap);

Image imageGrayscale = imageSource.Convert();

imageGrayscale = randon(imageGrayscale);

imageThreshold = imageGrayscale.ThresholdBinary(new Gray(100), new Gray(255));

this.pictureBox2.Image = imageThreshold.ToBitmap();

}

///

/// 旋转校正

///

///

///

private Image randon(Image imageInput)//图像投影旋转法倾斜校正子函数定义

{

int nwidth = imageInput.Width;

int nheight = imageInput.Height;

int sum;

int SumOfCha;

int SumOfChatemp = 0;

int[] sumhang = new int[nheight];

Image resultImage = imageInput;

Image ImrotaImage;

//20度范围内的调整

for (int ang = -20; ang < 20; ang = ang + 1)

{

ImrotaImage = imageInput.Rotate(ang, new Gray(1));

for (int i = 0; i < nheight; i++)

{

sum = 0;

for (int j = 0; j < nwidth; j++)

{

sum += ImrotaImage.Data[i, j, 0];

}

sumhang[i] = sum;

}

SumOfCha = 0;

for (int k = 0; k < nheight - 1; k++)

{

SumOfCha = SumOfCha + (Math.Abs(sumhang[k] - sumhang[k + 1]));

}

if (SumOfCha > SumOfChatemp)

{

resultImage = ImrotaImage;

SumOfChatemp = SumOfCha;

}

}

return resultImage;

}

private void pictureBox1_Click(object sender, EventArgs e)

{

}

}

}

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

时间: 2017-07-12

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值