一个基于SVM的数字手写识别分享给大家;源码见附件, VS2010 + OpenCV2.4.9开发
HandWrite.rar
(15.41 MB, 售价: 2 E币)
识别效果如下图所示:
部分源代码
- void CHandWriteDlg::OnBnClickedButtonIdentify()
- {
- // TODO: 在此添加控件通知处理程序代码
- if(m_firstFlag == false)
- {
- MessageBox(_T("请现在手写区写入数字!"));
- return ;
- }
-
- CvSVM svm;
- IplImage *test;
- CString strResult;
- char* str;
- CRect pRect;
- CWnd* pwnd=GetDlgItem(IDC_STATIC_HAND);//获取静态控件的指针 CRect pRect;
- CDC* pDC=pwnd->GetDC(); //使用控件指针创建绘图用的DC
- pwnd->GetClientRect(&pRect);
- int w, h;
- w = pRect.right - pRect.left;
- h = pRect.bottom - pRect.top;
- CBitmap bm;
- bm.CreateCompatibleBitmap(pDC, w, h);
- CDC memdc;
- memdc.CreateCompatibleDC(pDC);
- CBitmap*pOld=memdc.SelectObject(&bm);
- memdc.BitBlt( 0, 0, w, h, pDC, pRect.left, pRect.top, SRCCOPY );
- BITMAP btm;
- bm.GetBitmap(&btm);
- DWORD size=btm.bmWidthBytes*btm.bmHeight;
- LPSTR lpData=(LPSTR)::GlobalAlloc(GPTR,size);
- BITMAPINFOHEADER bih;
- bih.biBitCount=btm.bmBitsPixel;
- bih.biClrImportant=0;
- bih.biClrUsed=0;
- bih.biCompression=0;
- bih.biHeight=btm.bmHeight;
- bih.biPlanes=1;
- bih.biSize=sizeof(BITMAPINFOHEADER);
- bih.biSizeImage=size;
- bih.biWidth=btm.bmWidth;
- bih.biXPelsPerMeter=0;
- bih.biYPelsPerMeter=0;
- GetDIBits(memdc,bm,0,bih.biHeight,lpData,(BITMAPINFO*)&bih,DIB_RGB_COLORS);
- BITMAPFILEHEADER bfh;
- bfh.bfReserved1=bfh.bfReserved2=0;
- bfh.bfType=((WORD)('M'<< 8)|'B');
- bfh.bfSize=54+size;
- bfh.bfOffBits=54;
- CFile bf;
- if(bf.Open(_T("a.bmp"),CFile::modeCreate|CFile::modeWrite))
- {
- bf.Write(&bfh,sizeof(BITMAPFILEHEADER));
- bf.Write(&bih,sizeof(BITMAPINFOHEADER));
- bf.Write(lpData,size);
- ……………………
- …………限于本文篇幅 余下代码请下载附件…………
复制代码
【必读】版权免责声明
1、本主题所有言论和内容纯属会员个人意见,与本论坛立场无关。2、本站对所发内容真实性、客观性、可用性不做任何保证也不负任何责任,网友之间仅出于学习目的进行交流。3、对提供的数字内容不拥有任何权利,其版权归原著者拥有。请勿将该数字内容进行商业交易、转载等行为,该内容只为学习所提供,使用后发生的一切问题与本站无关。 4、本网站不保证本站提供的下载资源的准确性、安全性和完整性;同时本网站也不承担用户因使用这些下载资源对自己和他人造成任何形式的损失或伤害。 5、本网站所有软件和资料均为网友推荐收集整理而来,仅供学习用途使用,请务必下载后两小时内删除,禁止商用。6、如有侵犯你版权的,请及时联系我们(电子邮箱1370723259@qq.com)指出,本站将立即改正。
|