OpenCv案例(三):基于OpenCVSharp识别试卷中下划线

需求:识别图片中填空题的下划线,并且高亮显示;

原图:

处理后图像如下:

:

 代码部分:

 public Mat DetectLines(Mat src)
        {
            Mat mat = Cv2.ImRead(src, ImreadModes.Grayscale);
            Mat gaussianBlurMat = new Mat();
            Cv2.GaussianBlur(mat, gaussianBlurMat, new Size(3, 3), 15, 0, BorderTypes.Default);
            Cv2.ImShow("gaussianBlurMat", gaussianBlurMat);
            Mat laplanceMat = new Mat();
            //Cv2.Canny(gaussianBlurMat, cannyMat, ThresholdValue, ThresholdValue * 2, 3, false);
            Cv2.Laplacian(gaussianBlurMat, laplanceMat, MatType.CV_8UC1, 3, 3);
            Cv2.ImShow("Laplacian", laplanceMat);
            Mat binaryImg = new Mat();
            Mat morhpImage = new Mat();
            //binaryImage
            Cv2.Threshold(laplanceMat, binaryImg, 0, 255, ThresholdTypes.Binary | ThresholdTypes.Otsu);
            Cv2.ImShow("binary", binaryImg);

            //morphology operation    new Size(20, 1):一条横线
            Mat kernel = Cv2.GetStructuringElement(MorphShapes.Rect, new Size(60, 1), new Point(-1, -1));
            //开操作 先腐蚀 后膨胀
            Cv2.MorphologyEx(binaryImg, morhpImage, MorphTypes.Open, kernel, new Point(-1, -1));
            //Cv2.MorphologyEx(binaryImg, morhpImage, MorphTypes.Erode, kernel, new Point(-1, -1));
            //Cv2.ImShow("morphImg Erode", morhpImage);
            //Cv2.MorphologyEx(morhpImage, morhpImage, MorphTypes.Dilate, kernel, new Point(-1, -1));
            Cv2.ImShow("morphImg", morhpImage);

            //dilate img
            kernel = Cv2.GetStructuringElement(MorphShapes.Rect, new Size(3, 3), new Point(-1, -1));
            Cv2.Dilate(morhpImage, morhpImage, kernel);
            Cv2.ImShow("morph lines", morhpImage);

            LineSegmentPoint[] lines = Cv2.HoughLinesP(morhpImage, 1, Cv2.PI / 180, 30, 20.0, 0);

            Mat retMat = src.Clone();
            Cv2.CvtColor(retMat, retMat, ColorConversionCodes.GRAY2BGR);
            for (int i = 0; i < lines.Length; i++)
            {
                Cv2.Line(retMat, lines[i].P1, lines[i].P2, new Scalar(0, 0, 255), 2, LineTypes.Link8, 0);
            }
            Cv2.ImShow("out", retMat);
            return retMat;
        }

该案例的图像基本处理步骤如上,主要难点是如何去除非直线内容;针对不同图像,需要对上述算法中一些参数进行调整(若不理解部分算法参数含义,查找相关资料学习); 

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值