考研初试结束,毕设选择了印刷体汉字识别,准备先实现其基本功能。
在网上查阅资料后发现图像处理第一个步骤一般为图像预处理,即滤除图像噪声,并进行如灰度化、二值化、倾斜校正、图像平滑等基本操作。因为主要目的是学习,所以我写的较为繁琐,将各个步骤拆分了多个函数。
以下为代码:
(头文件省略了)
YuCHuLi.cpp
#include "YuChuLi.h"
using namespace std;
using namespace cv;
//灰度化 二值化 倾斜校正 规范化 图像平滑
#define Error 123
void YuChuLi::HuiDuHua(Mat &img)//灰度化
{
cvtColor(img,img, CV_RGB2GRAY);
}
void YuChuLi::ErZhiHua(Mat &img)//二值化
{
threshold(img, img,125,255,CV_THRESH_BINARY); //125为阀值,由默认值可知大于125置为255(白),因为针对白底黑字,阴影为主要干扰,所以适当降低阀值
}
void YuChuLi::XuanZhuan(Mat &img, double angle)//旋转
{
//定义旋转中心,为图像的中心即横竖坐标均为图像长度的一半
Point2f center;
center.x = float(img.cols / 2.0);
center.y = float(img.rows / 2.0);
int length = 0;
length = sqrt(img.cols*img.cols + img.rows*img.rows);
//计算二维旋转的仿射变换矩阵
Mat M = getRotationMatrix2