版权声明:本文为博主原创文章,转载请在显著位置标明本文出处以及作者网名,未经作者允许不得用于商业目的。
EmguCV是一个基于OpenCV的开源免费的跨平台计算机视觉库,它向C#和VB.NET开发者提供了OpenCV库的大部分功能。
教程VB.net版本请访问:EmguCV学习笔记 VB.Net 目录-CSDN博客
教程C#版本请访问:EmguCV学习笔记 C# 目录-CSDN博客
笔者的博客网址:https://blog.csdn.net/uruseibest
教程配套文件及相关说明以及如何获得pdf教程和代码,请移步:EmguCV学习笔记
学习VB.Net知识,请移步: vb.net 教程 目录_vb中如何用datagridview-CSDN博客
学习C#知识,请移步:C# 教程 目录_c#教程目录-CSDN博客
5.4 图像修复
CvInvoke类的Inpaint方法用于图像修复,可以通过填充缺失的图像区域来恢复图像的完整性。该方法通常用于去除图像中的噪点、划痕或遮挡物等。该方法声明如下:
public static void Inpaint(
IInputArray src,
IInputArray mask,
IOutputArray dst,
double inpaintRadius,
InpaintType flags
)
参数说明:
- src:输入图像,可以是单通道或多通道图像。
- mask:修复区域的掩码图像,与输入图像具有相同的尺寸,掩码图像中的非零像素表示需要修复的区域。
- dst:输出图像,与输入图像具有相同的尺寸和深度。
- inpaintRadius:修复半径,用于指定修复算法的范围。
- flags:修复方法,InpaintType枚举,包括两个成员:
- NS:基于Navier-Stokes算法修复图像。
- Telea:基于Alexandru Telea算法修复图像。
【代码位置:frmChapter5】Button12_Click
//图像修复
private void Button12_Click(object sender, EventArgs e)
{
//需要修复的图像
Mat m = new Mat("C:\\learnEmgucv\\lenarepair.jpg", ImreadModes.Color);
ImageBox1.Image = m;
//设置掩码图像
Mat mMark = new Mat();
CvInvoke.CvtColor(m, mMark, ColorConversion.Bgr2Gray);
//二值化,其中非0的地方表示需要修复的地方
CvInvoke.Threshold(mMark, mMark, 235, 255, ThresholdType.Binary);
ImageBox2.Image = mMark;
//进行膨胀,扩大一定修复范围
Mat kernel = new Mat();
kernel = CvInvoke.GetStructuringElement(ElementShape.Rectangle, new Size(5, 5), new Point(-1, -1));
CvInvoke.Dilate(mMark, mMark, kernel, new Point(-1, -1), 1, BorderType.Constant, new MCvScalar(255, 0, 0));
//创建输出图像
Mat mout = new Mat();
//执行图像修复
CvInvoke.Inpaint(m, mMark, mout, 5, InpaintType.Telea);
ImageBox3.Image = mout;
}
运行后如下图所示:
图5-13 修复后的图像
【代码位置:frmChapter5】Button13_Click
//图像修复
//Inpaint似乎对分散、小面积、且标记的噪点更好修复
private void Button13_Click(object sender, EventArgs e)
{
//需要修复红色标记的图片
Mat msrc = new Mat("c:\\learnEmgucv\\w1.jpg", ImreadModes.Color);
//这里使用了一张对原图需要修复位置进行白色标注的图片作为模板
Mat msrcmark = new Mat("c:\\learnEmgucv\\w2.jpg", ImreadModes.Color);
//将白色标记部分提取为掩码图像
Mat mgray = new Mat();
CvInvoke.CvtColor(msrcmark, mgray, ColorConversion.Bgr2Gray);
Mat mMark = new Mat();
CvInvoke.Threshold(mgray, mMark, 240, 255, ThresholdType.Binary);
Mat kernel1 = new Mat();
kernel1 = CvInvoke.GetStructuringElement(ElementShape.Rectangle, new Size(5, 5), new Point(-1, -1));
CvInvoke.Dilate(mMark, mMark, kernel1, new Point(-1, -1), 1, BorderType.Constant, new MCvScalar(255, 0, 0));
Mat mout = new Mat();
CvInvoke.Inpaint(msrc, mMark, mout, 5, InpaintType.NS);
ImageBox1.Image = msrc;
ImageBox2.Image = mMark;
ImageBox3.Image = mout;
}
运行后如下图所示:
图5-14 修复后的图像