【OpenCV学习】第10课:形态学操作的应用-图像去掉干扰线丶干扰点

仅自学做笔记用,后续有错误会更改

理论
去干扰线干扰点的操作方法, 大体上与第9课所说的提取水平/垂直线一致, 只是把核改为矩形, 不要线型就行,反正都是通过开操作来实行的。

操作流程:

  1. 输入图像(一般是彩色图像,imread)
  2. 转换为灰度图像(cvtColor)
  3. 转换为二值图像(adaptiveThreshold)
  4. 定义结构元素(矩形)
  5. 开操作(先腐蚀,后膨胀)

相关API
转换为二值图像 - 通过adaptiveThreshold这个接口去转换
adaptiveThreshold(
Mat src, //输入的灰度图像
Mat dst, //输出的二值图像
double maxValue, //超过阈值的部分取值是多少(对于cv.THRESH_BINARY而言)
int adaptiveMethod, //自适应阈值算法,只能选其中之一: ADAPTIVE_THRESH_MEAN_C,ADAPTIVE_THRESH_GAUSSIAN_C
int thresholdType, //阈值类型, 必须为THRESH_BINARY或THRESH_BINARY_INV
int blockSize, //核的大小
double C, //常量, 可以是正数,0,负数, 它是减去平均或加权平均值后的常数值,通常为正数
);

代码示例

Mat src,dst;
src = imread(...);
// 先显示原图
namedWindow("input image", CV_WINDOW_AUTOSIZE);
imshow("input image", src);
// 再显示灰度图
Mat gray_dst;
cvtColor(src, gray_dst, CV_BGR2GRAY);
namedWindow("gray image", CV_WINDOW_AUTOSIZE);
imshow("gray image", gray_dst);
// 再显示二值图
Mat binImg_dst;
adaptiveThreshold(~gray_dst, binImg_dst, 255, ADAPTIVE_THRESH_MEAN_C, THRSH_BINARY, 15, -2); //注意这个gray_dst有个取反符号,表示先取反再进行二值转换, 如果是白色背景的图, 就会变为黑色
namedWindow("binary image", CV_WINDOW_AUTOSIZE);
imshow("binary image", binImg_dst);
// 再显示开操作之后的图
Mat kernel = getStructuringElement(MORPH_RECT, Size(5, 5), Point(-1, -1));
Mat temp;
erode(binImg_dst, temp, kernel );	 // 先腐蚀
dilate(temp, dst, kernel );			     // 再膨胀
bitwise_not(dst, dst); 					     // 图像取反操作, 将黑色背景再转为白色
namedWindow("result image", CV_WINDOW_AUTOSIZE);
imshow("result image", dst);

效果截图:
原图:
在这里插入图片描述
灰度图:
在这里插入图片描述
取反之后的二值图:
在这里插入图片描述
开操作之后的图:
在这里插入图片描述
由上图结果可以看出,我们的提取不大顺利, 把字母也去掉了一些, 那么我们改一下代码
将:

Mat kernel = getStructuringElement(MORPH_RECT, Size(5, 5), Point(-1, -1));

改为:

Mat kernel = getStructuringElement(MORPH_RECT, Size(3, 3), Point(-1, -1));

也就是把核的大小变小一点, 再来看结果图:
在这里插入图片描述

### 回答1: 可以使用形态学操作去掉干扰的小块区域。以下是一个基本的示例代码: ```java import org.opencv.core.*; import org.opencv.imgcodecs.Imgcodecs; import org.opencv.imgproc.Imgproc; public class RemoveSmallBlobs { public static void main(String[] args) { // Load image Mat image = Imgcodecs.imread("input.png"); // Convert to grayscale Mat gray = new Mat(); Imgproc.cvtColor(image, gray, Imgproc.COLOR_BGR2GRAY); // Threshold image Mat thresh = new Mat(); Imgproc.threshold(gray, thresh, 0, 255, Imgproc.THRESH_BINARY_INV+Imgproc.THRESH_OTSU); // Morphological opening Mat kernel = Imgproc.getStructuringElement(Imgproc.MORPH_ELLIPSE, new Size(5,5)); Mat opened = new Mat(); Imgproc.morphologyEx(thresh, opened, Imgproc.MORPH_OPEN, kernel); // Save output image Imgcodecs.imwrite("output.png", opened); } } ``` 这个示例代码将读取名为 "input.png" 的图像,将其转换为灰度图像应用二值化阈值,然后使用形态学开运算操作去除小的干扰区域,并将结果保存为名为 "output.png" 的图像。你可以调整 `kernel` 的大小和形状来控制去除的小块的大小和形状。 ### 回答2: 要使用Java OpenCV去掉干扰的小块区域,可以采用以下步骤: 1. 导入Java OpenCV库,并加载图像:在开始的代码中,首先导入Java OpenCV库,并加载你要处理的图像。 2. 转换图像为灰度图:使用OpenCV的cvtColor函数将加载的图像转换为灰度图像。这样做是因为在灰度图像上更容易进行像素操作图像分析。 3. 图像二值化:使用OpenCV的阈值化函数(threshold)将灰度图像转换为二值图像。通过设定一个合适的阈值,可以将图像中的物体与背景分离出来。 4. 查找和筛选轮廓:使用OpenCV的findContours函数查找图像中的所有轮廓。然后,可以通过一些条件(如面积、宽高比等)筛选出符合要求的轮廓。 5. 去掉干扰的小块区域:遍历筛选后的轮廓,对每个轮廓进行处理。可以使用OpenCV的boundingRect函数获得轮廓的边界框(矩形),并计算框的面积。如果面积小于某个阈值,就可以将其视为干扰的小块区域,然后通过给区域的像素置为背景色(黑色或白色)来去掉。 6. 显示和保存结果:最后,使用OpenCV的imshow函数显示处理后的图像,并使用imwrite函数将结果保存到磁盘上。 通过以上步骤,你可以使用Java OpenCV去掉干扰的小块区域,从而得到更干净、更简洁的图像。 ### 回答3: 要使用Java和OpenCV去除干扰的小块区域,可以按照以下步骤进行操作。 1. 导入OpenCV库:首先需要在Java项目中导入OpenCV库,确保可以使用OpenCV图像处理功能。 2. 读取图像:使用OpenCV的函数读取待处理的图像文件,并将其转换为OpenCV支持的格式。 3. 图像预处理:根据具体的需求进行图像预处理操作,例如灰度化、二值化、平滑滤波等。这些操作有助于减少噪和增强要检测的目标。 4. 检测小块区域:使用OpenCV图像处理算法检测并标记出待去除的小块区域。可以利用形态学操作、轮廓检测等技术来实现。这些小块可能是噪声、干扰或者不感兴趣的区域。 5. 去除小块区域:根据检测到的小块区域的位置信息,在原始图像中将这些区域进行遮盖或者直接删除,从而去除它们的影响。这可以通过对像素进行操作实现。 6. 显示结果:将处理后的图像显示出来,以便观察去除小块区域的效果。 7. 输出图像:将处理后的图像保存到文件中,以便后续使用或者展示。 以上是使用Java和OpenCV去除干扰的小块区域的基本步骤。具体的实现可以根据具体的需求和图像进行调整和优化,如调整预处理参数、选择合适的算法等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值