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();
}
提取结果:
去除横线,提取字母:
实例代码:
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();
}
处理结果:
转载自:https://blog.csdn.net/qq_25343557/article/details/78691828
上一篇: OpenCV11---提取水平与垂直线