感谢您提前阅读此内容。
我正在做一个与信用卡 OCR 相关的项目,其中一个步骤需要为已经轮廓化的图像填充颜色。
示例图像包括:
我的目标是用黑色填充空白:
虽然看起来很简单,但我没有找到令人满意的解决方案。
我正在尝试该findContours
功能,但发现它非常混乱。运行以下函数后:
findContours( cvMatImage, contours, hierarchy, CV_RETR_TREE, CV_CHAIN_APPROX_SIMPLE, cv::Point(0, 0) );
奇怪的是,不仅没有正确提取轮廓点,而且原始输入图像似乎有自己的颜色反转。
findContours
非常感谢有关我应该如何完成目标或如何正确使用功能的任何输入。
更新:
非常感谢您的友好输入。
事实上,我的问题中包含的图像已经被二值化了——而且我已经对图像应用了“自适应阈值”程序。
原始图像如下所示:http://i.stack.imgur.com/DkIKt.png
CGColorSpaceRef colorSpace = CGImageGetColorSpace(self.CGImage);
CGFloat cols = self.size.width;
CGFloat rows = self.size.height;
Mat cvMat(rows, cols, CV_8UC4); // 8 bits per component, 4 channels
CGContextRef contextRef = CGBitmapContextCreate(cvMat.data, // Pointer to data
cols, // Width of bitmap
rows, // Height of bitmap
8, // Bits per component
cvMat.step[0], // Bytes per row
colorSpace, // Colorspace
kCGImageAlphaNoneSkipLast |
kCGBitmapByteOrderDefault); // Bitmap info flags
CGContextDrawImage(contextRef, CGRectMake(0, 0, cols, rows), self.CGImage);
CGContextRelease(contextRef);
CGColorSpaceRelease(colorSpace);
Mat cvImage_gray, cvImage_threshold;
cvtColor(cvImageOrg, cvImage_gray, CV_RGB2GRAY); //Binarize
adaptiveThreshold(cvImage_gray, cvImage_threshold, 255, ADAPTIVE_THRESH_MEAN_C, THRESH_BINARY, neighbor, threshRed); //Adaptive threshold