简单的集装箱号码识别
来源:互联网 发布:路由器端口转发80 编辑:程序博客网 时间:2024/04/30 06:48
网上大多资料都是车牌号码识别,集装箱号码可能所处的环境因素会复杂一点,比如号码横竖问题、拍摄角度不同、号码字体不同...但总体框架还是和车牌识别一个道理的;能力有限很多因素都没考虑进来,暑假有机会的话希望能进一步研究一下,这先做个小小总结以防时间久了想复习一下都不知道从哪抓起;
1 获取号码区域
集装箱号码类似与文字区域的检测,先使用 morphologyEx函数膨胀,再用 cvFindContours 函数提取轮廓;
集装箱号码的排列一般分横型和竖型,所以膨胀处理也对应两种
2 确定单个字符// 寻找所有矩形轮廓// 参数: // 1. pBinary: 输入二值图像,单通道,位深IPL_DEPTH_8U。 // 2. Size s: 横竖形态选择参数vectorFindRect(IplImage *src_img, Size s){vector Rectbuf;IplImage *gray_img = cvCreateImage(cvGetSize(src_img), 8, 1);cvSmooth(src_img, src_img, CV_GAUSSIAN);//IplI *arr转mat:mat(arr)cvCvtColor(src_img, gray_img, CV_BGR2GRAY);double th_maxArea = (gray_img->width*gray_img->height)*0.5;double th_minArea = (gray_img->width*gray_img->height)*0.01;double th_maxRatio = 0.3;//height/width比double th_minRatio = 0.01;Mat element1 = getStructuringElement(MORPH_RECT, s);//morphologyEx(cvarrToMat(gray_img), cvarrToMat(gray_img), MORPH_CLOSE, element1);morphologyEx(cvarrToMat(gray_img), cvarrToMat(gray_img), MORPH_DILATE, element1);IplImage *pBinary = cvCreateImage(cvGetSize(gray_img), 8, 1);int thresh = Otsu(gray_img);cvThreshold(gray_img, pBinary, thresh, 255, CV_THRESH_BINARY);//cvAdaptiveThreshold(gray_img, pBinary, 255, CV_ADAPTIVE_THRESH_MEAN_C, CV_THRESH_BINARY, 5, 5);CvSeq *pContour = NULL;CvMemStorage *pStorage = NULL;//IplImage *dst = cvCreateImage(cvGetSize(gray_img), 8, 3);// 执行条件 if (pBinary){// 查找所有轮廓 pStorage = cvCreateMemStorage(0);cvFindContours(pBinary, pStorage, &pContour, sizeof(CvContour), CV_RETR_LIST, CV_CHAIN_APPROX_SIMPLE); int cnt = 0;CvContourScanner scanner = cvStartFindContours(pBinary, pStorage);while (pContour = cvFindNextContour(scanner)){//double tmparea = fabs(cvContourArea(pContour));CvRect rect = cvBoundingRect(pContour, 0);double tmparea = rect.height*rect.width;//面积筛选if (tmparea < th_minArea || tmparea > th_maxArea){cvSubstituteContour(scanner, NULL);//删除当前的轮廓 continue;}double tmpRatio = (rect.height th_maxRatio)//长宽比筛选{cvSubstituteContour(scanner, NULL);//删除当前的轮廓 continue;}cnt++;Rectbuf.push_back(rect);//cvDrawContours(src_img, pContour, CV_RGB(0, 0, 255), CV_RGB(0, 0, 255), 0, 2, CV_FILLED, cvPoint(0, 0));cvRectangle(src_img, cvPoint(rect.x, rect.y), cvPoint(rect.x + rect.width, rect.y + rect.height), CV_RGB(255, 0, 0), 1, 8, 0);}pContour = cvEndFindContours(&scanner);cout << Rectbuf.size() << endl;cvReleaseMemStorage(&pStorage);pStorage = NULL;}cvNamedWindow("result");cvShowImage("result", src_img); waitKey();destroyWindow("result");cvReleaseImage(&pBinary);cvReleaseImage(&gray_img);return Rectbuf;}
3 识别字符
阅读全文
0 0
- 简单的集装箱号码识别
- 集装箱的种类
- 扫一扫识别车牌号码的软件sdk
- 扫一扫识别车牌号码的软件sdk
- Android 识别来电号码
- 号码识别正则表达式
- 简单号码分配器的实现分析
- GSM的网络结构、区域划分、识别号码、信道分类
- 电话主叫号码信息的识别及实现CID
- Android中TextView不能识别电信号码11888的问题。
- 用手机就能识别车牌号码的开发应用
- [读书笔记]集装箱中心站的规划设计
- 数据结构的总体思想(集装箱思想)
- 令人惊艳的废弃集装箱改造设计
- 简单的手势识别
- 短信的相似度识别——内容相似度+号码相似度+号码段相似度
- qq 号码简单分类
- 一个简单的获取最大ID号码的方法
- C++学习笔记(二)
- Android中CMake的使用之四调用第三方库的实战
- VirtualBox 里的Ubuntu虚拟机无法联网
- java与scala文件读写
- 老男孩带你了解perl正则表达式中的零宽断言
- 简单的集装箱号码识别
- 如何学习Linux操作系统
- 《深入理解mybatis原理》 MyBatis的架构设计以及实例分析
- (unix domain socket)使用udp发送>=128K的消息会报ENOBUFS的错误
- Linux 输出重定向>和>>
- 算法导论 思考题 15-6(公司聚会计划)
- C#学习笔记(八)—–LINQ查询之子查询
- powerdesiner 16.5.0 连接mysql
- 带边框按钮和不带边框按钮