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

2024-08-31 19:12

本文主要是介绍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)

        'mmark32S,显示不了的

        '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)

        '使用MatrixImage便于生成图像(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 分水岭法使用随机颜色填充

这篇关于EmguCV学习笔记 VB.Net 8.2 分水岭法 watershed的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1124762

相关文章

javax.net.ssl.SSLHandshakeException:异常原因及解决方案

《javax.net.ssl.SSLHandshakeException:异常原因及解决方案》javax.net.ssl.SSLHandshakeException是一个SSL握手异常,通常在建立SS... 目录报错原因在程序中绕过服务器的安全验证注意点最后多说一句报错原因一般出现这种问题是因为目标服务器

Go学习记录之runtime包深入解析

《Go学习记录之runtime包深入解析》Go语言runtime包管理运行时环境,涵盖goroutine调度、内存分配、垃圾回收、类型信息等核心功能,:本文主要介绍Go学习记录之runtime包的... 目录前言:一、runtime包内容学习1、作用:① Goroutine和并发控制:② 垃圾回收:③ 栈和

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio

重新对Java的类加载器的学习方式

《重新对Java的类加载器的学习方式》:本文主要介绍重新对Java的类加载器的学习方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、介绍1.1、简介1.2、符号引用和直接引用1、符号引用2、直接引用3、符号转直接的过程2、加载流程3、类加载的分类3.1、显示

使用easy connect之后,maven无法使用,原来需要配置-Djava.net.preferIPv4Stack=true问题

《使用easyconnect之后,maven无法使用,原来需要配置-Djava.net.preferIPv4Stack=true问题》:本文主要介绍使用easyconnect之后,maven无法... 目录使用easGWowCy connect之后,maven无法使用,原来需要配置-DJava.net.pr

在.NET平台使用C#为PDF添加各种类型的表单域的方法

《在.NET平台使用C#为PDF添加各种类型的表单域的方法》在日常办公系统开发中,涉及PDF处理相关的开发时,生成可填写的PDF表单是一种常见需求,与静态PDF不同,带有**表单域的文档支持用户直接在... 目录引言使用 PdfTextBoxField 添加文本输入域使用 PdfComboBoxField

Java学习手册之Filter和Listener使用方法

《Java学习手册之Filter和Listener使用方法》:本文主要介绍Java学习手册之Filter和Listener使用方法的相关资料,Filter是一种拦截器,可以在请求到达Servl... 目录一、Filter(过滤器)1. Filter 的工作原理2. Filter 的配置与使用二、Listen

利用Python快速搭建Markdown笔记发布系统

《利用Python快速搭建Markdown笔记发布系统》这篇文章主要为大家详细介绍了使用Python生态的成熟工具,在30分钟内搭建一个支持Markdown渲染、分类标签、全文搜索的私有化知识发布系统... 目录引言:为什么要自建知识博客一、技术选型:极简主义开发栈二、系统架构设计三、核心代码实现(分步解析

Java进阶学习之如何开启远程调式

《Java进阶学习之如何开启远程调式》Java开发中的远程调试是一项至关重要的技能,特别是在处理生产环境的问题或者协作开发时,:本文主要介绍Java进阶学习之如何开启远程调式的相关资料,需要的朋友... 目录概述Java远程调试的开启与底层原理开启Java远程调试底层原理JVM参数总结&nbsMbKKXJx

基于.NET编写工具类解决JSON乱码问题

《基于.NET编写工具类解决JSON乱码问题》在开发过程中,我们经常会遇到JSON数据处理的问题,尤其是在数据传输和解析过程中,很容易出现编码错误导致的乱码问题,下面我们就来编写一个.NET工具类来解... 目录问题背景核心原理工具类实现使用示例总结在开发过程中,我们经常会遇到jsON数据处理的问题,尤其是