本篇介绍数字的自动分割。将每行的数字单独分割出来才能够一个一个识别。
1.方法
- 进行腐蚀操作,去除图片中的杂点。
- 膨胀,保证一个数字中数码管相互连接(由于是数码管,有时会出现两管之间不连接的情况)
- 使用cvFindContours查找各个数字边缘
- 分别建立各个轮廓的轮廓矩
- 将每个矩形切割出来,并单独存为一个图像
旋转后的行图片如图,一共有4行,这里就只贴一行了。
分割后的数字图片如图:
2.代码
先给出全部函数代码,之后再详细解释。
/**************数字分割子程序**************/
//函数名称:int CutNum(IplImage *RotateRow,int row)
//功能:将每行的数字进行分割
//入口参数:*RotateRow,row
//出口参数:数字个数Num
//生成:数字图像Num(row).1.2.3...
/***************************************/
int CutNum(IplImage *RotateRow,int row)
{
cvThreshold(RotateRow,RotateRow,50,255,CV_THRESH_BINARY);
cvErode(RotateRow,RotateRow,0,1);
cvDilate(RotateRow,RotateRow,0,2);
//对每列图像查找边缘
CvMemStorage *OutlineSto=cvCreateMemStorage();
CvSeq *Outlineseq=NULL;
IplImage *TmpImage=cvCloneImage(RotateRow);
int Num=cvFindContours(TmpImage,OutlineSto,&Outlineseq,sizeof(CvContour),CV_RETR_EXTERNAL,CV_CHAIN_APPROX_SIMPLE,cvPoint(0,0));
//确定轮廓顺序
int *Rect_x=new int[Num];
int x=0;