欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

OpenCV--提取水平与垂直线(形态学操作应用)

程序员文章站 2022-07-14 12:54:27
...

图像形态学操作的时候,可以通过自定义的结构元素实现结构元素对输入图像一些对象敏感,另外一些对象不敏感,这样就会让敏感的对象改变而不敏感的对象保留输出。通过使用两个最基本的形态学操作–膨胀与腐蚀,使用不同的结构元素实现对输入图像的操作,得到想要的结果。


操作过程:

  • 读取原图;
  • 转为灰度图像;
  • 转为二值图像;
  • 定义结构元素;
  • 开操作。

实例代码:

void GetLine(){
    Mat src,grayImg,binImg,dest;
    //①、读取图片
    src = imread("line.png");
    if(!src.data){
        cout << "图片打开失败!" << endl;
        return;
    }
    namedWindow("原图像",CV_WINDOW_AUTOSIZE);
    imshow("原图像",src);
    //②、转为灰度图
    cvtColor(src,grayImg,CV_RGB2GRAY);
    namedWindow("灰度图",CV_WINDOW_AUTOSIZE);
    imshow("灰度图",grayImg);
    //③、转为二值图像
    adaptiveThreshold(~grayImg,binImg,255,ADAPTIVE_THRESH_MEAN_C,THRESH_BINARY ,15,-2);
    namedWindow("二值图像",CV_WINDOW_AUTOSIZE);
    imshow("二值图像",binImg);
    //④、定义结构元素
    Mat kernel = getStructuringElement(MORPH_RECT,Size(1,20));
     //⑤、开操作
    morphologyEx(binImg,dest,MORPH_OPEN,kernel);
    namedWindow("最终结果",CV_WINDOW_AUTOSIZE);
    imshow("最终结果",~dest);

    cvWaitKey();
}

提取结果: 
OpenCV--提取水平与垂直线(形态学操作应用)


去除横线,提取字母: 
OpenCV--提取水平与垂直线(形态学操作应用)

实例代码:

void GetChar(){
    Mat src,grayImg,binImg,dest;
    //①、读取图片
    src = imread("char.png");
    if(!src.data){
        cout << "图片打开失败!" << endl;
        return;
    }
    namedWindow("原图像",CV_WINDOW_AUTOSIZE);
    imshow("原图像",src);
    //②、转为灰度图
    cvtColor(src,grayImg,CV_RGB2GRAY);
    namedWindow("灰度图",CV_WINDOW_AUTOSIZE);
    imshow("灰度图",grayImg);
    //③、转为二值图像
    /*
    void adaptiveThreshold(InputArray src, OutputArray dst, double maxValue, int adaptiveMethod, int thresholdType, int blockSize, double C)
    */
    adaptiveThreshold(~grayImg,binImg,255,ADAPTIVE_THRESH_MEAN_C,THRESH_BINARY ,15,-2);
    namedWindow("二值图像",CV_WINDOW_AUTOSIZE);
    imshow("二值图像",binImg);
    //④、定义结构元素
    Mat kernel = getStructuringElement(MORPH_RECT,Size(3,3));
     //⑤、开操作
    morphologyEx(binImg,dest,MORPH_OPEN,kernel);
    namedWindow("最终结果",CV_WINDOW_AUTOSIZE);
    imshow("最终结果",~dest); 
    cvWaitKey();
}

 处理结果: 
OpenCV--提取水平与垂直线(形态学操作应用)

转载自:https://blog.csdn.net/qq_25343557/article/details/78691828