【发布时间】:2018-05-12 06:36:44
【问题描述】:
扫描的样本令牌:https://ibin.co/3irqGlxXezL3.jpg
输入图片:https://ibin.co/3irmfXKjYocz.jpg
如您所见,我已经应用了 .submat,但我不确定为什么它会掩盖轮廓的内部而不是外表面。此外,过滤最大轮廓也不一致。关于如何根据票证的尺寸使其更健壮的任何想法,因为我的目标是扫描具有相同尺寸的票证。
作为一名新手 OpenCV 爱好者,我希望有人能指导我完成我在这里的最终任务,即从票证中的日历中获取年、月、日和时间,并以文本形式显示。
票上会有打孔作为标记。所以,我的想法是跟踪每个(孔)blob并将其与周围的数字一起提取,以了解它基于其周围的数字,并对所有具有某种层次结构的blob(孔)执行此操作知道提取是分别来自“年”字段还是月或日字段。或者还有其他更好的方法吗?
@Override
public Mat onCameraFrame(CameraBridgeViewBase.CvCameraViewFrame inputFrame) {
Mat srcMat = inputFrame.rgba();
Mat processedMat = new Mat();
Imgproc.cvtColor(srcMat, processedMat, Imgproc.COLOR_BGR2GRAY);
Imgproc.GaussianBlur(processedMat, processedMat, new Size(3, 3), 0);
Imgproc.threshold(processedMat, processedMat, 98, 255, Imgproc.THRESH_BINARY);
List<MatOfPoint> contours = new ArrayList<>();
Mat hierarchy = new Mat();
Imgproc.findContours(processedMat, contours, hierarchy, Imgproc.RETR_EXTERNAL, Imgproc.CHAIN_APPROX_SIMPLE);
Log.e(TAG, "ContourSize: " + contours.size());
double maxVal = 0;
int maxValIdx = 0;
for (int contourIdx = 0; contourIdx < contours.size(); contourIdx++) {
double contourArea = Imgproc.contourArea(contours.get(contourIdx));
if (maxVal < contourArea) {
maxVal = contourArea;
maxValIdx = contourIdx;
}
}
Imgproc.drawContours(srcMat, contours, maxValIdx, new Scalar(0, 255, 0), -2);
if (!contours.isEmpty()) {
Log.e("largestContour", "" + contours.get(maxValIdx));
Rect rect = Imgproc.boundingRect(contours.get(maxValIdx));
srcMat.submat(rect);
}
return srcMat;
}
【问题讨论】: