EmguCV学习笔记 VB.Net 8.2 分水岭法 watershed

版权声明:本文为博主原创文章,转载请在显著位置标明本文出处以及作者网名,未经作者允许不得用于商业目的。

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博客

8.2 分水岭法 watershed

Watershed算法是一种图像处理算法,它是基于形态学的图像分割方法。在实现中,Watershed算法通常需要先对图像进行预处理,例如去除噪声、边缘检测等操作,以便更好的构建隔板。在填充山谷时,可以使用队列或其他数据结构来实现,以便管理待处理的像素。对于连通的区域,可以使用标记或者颜色来区分。最终得到的分割结果可以用于物体识别、形状分析等应用场景。

CvInvoke.Watershed方法用于执行图像的分水岭分割操作。该方法声明如下:

Public Shared Sub Watershed (

image As IInputArray,

markers As IInputOutputArray

)

参数说明:

  1. image:输入图像,必须是CV8U三通道彩色图。
  2. markers:指定的标记图像,这是一个CV32S的单通道图像,并且与输入图像具有相同的尺寸。可以通过FindContours和DrawContours来获得这个图像,使用像数值1、2、3......作为连通分量,来粗略勾勒出图像期望分割的区域,而未确定的区域未标记为0。

该方法没有返回值,而是直接在markers图像上进行分割操作。最终输出的图像,两个区域间使用-1作为分割线。

【代码位置:frmChapter8】Button4_Click、getRadomBgr

'分水岭法 watershed

Private Sub Button4_Click(sender As Object, e As EventArgs) Handles Button4.Click

Dim m As New Mat("c:\learnEmgucv\tower.jpg", ImreadModes.Color)

'灰度

Dim mgray As New Mat

CvInvoke.CvtColor(m, mgray, ColorConversion.Bgr2Gray)

'滤波

Dim mgaussian As New Mat

CvInvoke.GaussianBlur(mgray, mgaussian, New Drawing.Size(5, 5), 2)

ImageBox1.Image = mgaussian

'边缘检测

Dim mcanny As New Mat

CvInvoke.Canny(mgaussian, mcanny, 60, 120)

'ImageBox2.Image = mcanny

'获取轮廓

Dim contours As New VectorOfVectorOfPoint

Dim hierarchy As New VectorOfRect

CvInvoke.FindContours(mcanny, contours, hierarchy, RetrType.Tree, ChainApproxMethod.ChainApproxNone)

Dim mmark As New Mat

mmark = Mat.Zeros(mcanny.Rows, mcanny.Cols, DepthType.Cv32S, 1)

'仅为查看轮廓使用

Dim mcontours As New Mat(mcanny.Rows, mcanny.Cols, DepthType.Cv8U, 1)

For i As Integer = 0 To contours.Size - 1

'标记连通分量索引

CvInvoke.DrawContours(mmark, contours, i, New MCvScalar(i), 1, LineType.EightConnected, hierarchy)

'仅为查看轮廓使用

CvInvoke.DrawContours(mcontours, contours, i, New MCvScalar(255), 1, LineType.EightConnected, hierarchy)

Next

'仅为查看轮廓使用

CvInvoke.Imshow("mcontours", mcontours)

'mmark是32S,显示不了的

'CvInvoke.Imshow("mmark", mmark)

'分水岭法

CvInvoke.Watershed(m, mmark)

'仅演示,watershed后的数据

Dim mc As New Mat

mc = mmark.Clone

'转为可以显示的CV8U

mc.ConvertTo(mc, DepthType.Cv8U)

CvInvoke.Imshow("mc", mc)

'使用Matrix和Image便于生成图像(Mat操作像素点比较麻烦)

Dim matrwater As New Matrix(Of Int32)(mmark.Rows, mmark.Cols)

mmark.CopyTo(matrwater)

Dim imgwater As New Image(Of Bgr, Byte)(mmark.Cols, mmark.Rows)

'为每个区域填充不同的颜色

Dim HSpointcolor As New Hashtable() 'index,bgr

Dim count As Integer = 0

'对每个像素点操作

For i As Integer = 0 To matrwater.Rows - 1

For j As Integer = 0 To matrwater.Cols - 1

'获得连通分量(像素点值)

Dim index As Int32 = matrwater(i, j)

'如果是区域的分割线

If index = -1 Then

imgwater.Data(i, j, 0) = 255

imgwater.Data(i, j, 1) = 255

imgwater.Data(i, j, 2) = 255

Else

Dim pointcolor As Bgr

'检查是否已经存在索引对应的颜色

If HSpointcolor.ContainsKey(index) Then

pointcolor = HSpointcolor(index)

Else

'获得随机颜色

pointcolor = getRadomBgr()

'将已经使用的随机颜色加入List

HSpointcolor.Add(index, pointcolor)

count += 1

End If

'像素点填充颜色

imgwater.Data(i, j, 0) = pointcolor.Blue

imgwater.Data(i, j, 1) = pointcolor.Green

imgwater.Data(i, j, 2) = pointcolor.Red

End If

Next

Next

'输出使用分水岭法后的结果

CvInvoke.Imshow("imgwater", imgwater)

End Sub

'获得随机颜色

Private Function getRadomBgr() As Bgr

Dim rand As New Random(Now.Millisecond)

Dim b As Byte = rand.Next(0, 256)

Dim g As Byte = rand.Next(0, 256)

Dim r As Byte = rand.Next(0, 256)

Return New Bgr(b, r, g)

End Function

输出结果如下图所示:

图8-4 分水岭法使用随机颜色填充

相关推荐
Stara05114 分钟前
基于注意力机制与iRMB模块的YOLOv11改进模型—高效轻量目标检测新范式
人工智能·python·深度学习·神经网络·目标检测·计算机视觉·yolov11
知来者逆1 小时前
计算机视觉——MedSAM2医学影像一键实现3D与视频分割的高效解决方案
人工智能·深度学习·计算机视觉·图像分割·智能医疗·万物分割
小草cys1 小时前
树莓派4 yolo 11l.pt性能优化后的版本
opencv·计算机视觉·目标跟踪
bicijinlian2 小时前
.Net HttpClient 概述
c#·.net·httpclient·.net httpclient
码观天工3 小时前
.NET 原生驾驭 AI 新基建实战系列(七):Weaviate ── 语义搜索的智能引擎创新者
ai·c#·.net·向量数据库·weaviate
Zhen (Evan) Wang3 小时前
.NET 8 + Angular WebSocket 高并发性能优化
c#·.net·angular
Zhen (Evan) Wang4 小时前
.NET 8 API 实现websocket,并在前端angular实现调用
前端·websocket·.net
chenyuhao20244 小时前
链表面试题7之相交链表
数据结构·算法·链表·面试·c#
python算法(魔法师版)4 小时前
.NET 在鸿蒙系统上的适配现状
华为od·华为·华为云·.net·wpf·harmonyos
Blossom.1185 小时前
探索边缘计算:赋能物联网的未来
开发语言·人工智能·深度学习·opencv·物联网·机器学习·边缘计算