【Emgu CV教程】10.15、FillPoly()不规则形状填充颜色

2024-06-06 13:04

本文主要是介绍【Emgu CV教程】10.15、FillPoly()不规则形状填充颜色,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 一、概念
  • 二、填充不规则图形
    • 1.原始素材
    • 2.代码
    • 3.运行结果
  • 二、最大轮廓填充颜色
    • 1.原始素材
    • 2.代码
    • 3.运行结果


一、概念

图像的连通域是指图像中具有相同像素值并且位置相邻的像素组成的区域,连通域分析是指在图像中寻找出彼此互相独立的连通域并将其标记出来。

上一篇讲的是利用ConnectedComponentsWithStats查找连通区域,如果我们已经得到了一个由n个点组成的轮廓,想把这个区域填充成某个颜色,怎么办呢,Emgu CV中有这样一个函数:

public static FillPoly
(IInputOutputArray img, // 输入输出图像IInputArray points, // 点的集合,或者是轮廓MCvScalar color, // 要填充的颜色LineType lineType = LineType.EightConnected, // 线形int shift = 0, // 不知道,一般用不上Point offset = default(Point) // 不知道,一般用不上
)

此函数输入图像和输出图像使用一个变量传入,然后只需要再设定points和color两个参数就行。

二、填充不规则图形

1.原始素材

原始素材srcMat如下图:
在这里插入图片描述
图像宽737,长349。

2.代码

下面代码实现随机的五边形,填充到原始图像中:

Mat dstMat = srcMat.Clone();VectorOfVectorOfPoint contours = new VectorOfVectorOfPoint();
VectorOfPoint vPoints1 = new VectorOfPoint();
System.Drawing.Point[] pt = new System.Drawing.Point[1];
int width = dstMat.Width;
int height = dstMat.Height;
Random random = new Random();
for (int i = 0; i < 5; i++)
{pt[0].X = Convert.ToInt32(random.Next(0, width));pt[0].Y = Convert.ToInt32(random.Next(0, height));vPoints1.Push(pt);
}contours.Push(vPoints1);
CvInvoke.FillPoly(dstMat, contours, new MCvScalar(random.Next(0, 255), random.Next(0, 255), random.Next(0, 255)));
CvInvoke.Imshow("Final result image, " + dstMat.Size.ToString(), dstMat);

3.运行结果

上面的代码很简单,直接上运行结果:
在这里插入图片描述

二、最大轮廓填充颜色

1.原始素材

原始素材srcMat如下图:
在这里插入图片描述

图像宽979,长755。

2.代码

Mat tempMat = srcMat.Clone();
Mat dstMat = srcMat.Clone();
Mat gray = new Mat();
int threshold = Convert.ToInt16(TextBoxThreshold.Text.Trim().ToString());// 转成灰度图再二值化
CvInvoke.CvtColor(tempMat, gray, ColorConversion.Bgr2Gray);
CvInvoke.Threshold(gray, gray, threshold, 255, ThresholdType.Binary);
CvInvoke.Imshow("Gray and threshold", gray);// 定义轮廓集合
VectorOfVectorOfPoint contours = new VectorOfVectorOfPoint();
VectorOfRect hierarchy = new VectorOfRect();// 根据下拉框选择轮廓检索模式,查找轮廓并绘制
switch (ComboBoxType.Text)
{case "External":CvInvoke.FindContours(gray, contours, hierarchy, RetrType.External, ChainApproxMethod.ChainApproxNone);break;case "List":CvInvoke.FindContours(gray, contours, hierarchy, RetrType.List, ChainApproxMethod.ChainApproxNone);break;case "Ccomp":CvInvoke.FindContours(gray, contours, hierarchy, RetrType.Ccomp, ChainApproxMethod.ChainApproxNone);break;case "Tree":CvInvoke.FindContours(gray, contours, hierarchy, RetrType.Tree, ChainApproxMethod.ChainApproxNone);break;default:CvInvoke.FindContours(gray, contours, hierarchy, RetrType.Tree, ChainApproxMethod.ChainApproxNone);break;
}// 在一张黑色图中画出所有轮廓
Mat allContours = new Mat(new System.Drawing.Size(gray.Cols, gray.Rows), DepthType.Cv8U, 1);
allContours.SetTo(new MCvScalar(0, 0, 0));
CvInvoke.DrawContours(allContours, contours, -1, new MCvScalar(255, 255, 255), 1);// 按照面积筛选,太小的轮廓不计算
Dictionary<int, double> dict = new Dictionary<int, double>();
if (contours.Size > 0)
{for (int i = 0; i < contours.Size; i++){double girth = CvInvoke.ArcLength(contours[i], true);if (girth > 10 && girth < 3000000){dict.Add(i, girth);}}
}var item = dict.OrderByDescending(v => v.Value); // v.Value就代表周长,是降序排列// 给最大轮廓绘制颜色
Random random = new Random();
foreach (var it in item)
{int key = it.Key;CvInvoke.FillPoly(dstMat, contours[key], new MCvScalar(random.Next(0, 255), random.Next(0, 255), random.Next(0, 255)));break;
}CvInvoke.Imshow("All contours, " + dict.Count(), allContours);
CvInvoke.Imshow("Final result image, " + dstMat.Size.ToString(), dstMat);

3.运行结果

二值化阈值选择40,轮廓检索模式选择External,运行结果:
![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/f0466f69a9574797af1b75bb7f352ad0.png
二值化图形中,轮廓周长最大的,就是下面的那个球,所以整体都被填充成新的颜色了。


原创不易,请勿抄袭。共同进步,相互学习。

这篇关于【Emgu CV教程】10.15、FillPoly()不规则形状填充颜色的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Elasticsearch 在 Java 中的使用教程

《Elasticsearch在Java中的使用教程》Elasticsearch是一个分布式搜索和分析引擎,基于ApacheLucene构建,能够实现实时数据的存储、搜索、和分析,它广泛应用于全文... 目录1. Elasticsearch 简介2. 环境准备2.1 安装 Elasticsearch2.2 J

Linux系统中卸载与安装JDK的详细教程

《Linux系统中卸载与安装JDK的详细教程》本文详细介绍了如何在Linux系统中通过Xshell和Xftp工具连接与传输文件,然后进行JDK的安装与卸载,安装步骤包括连接Linux、传输JDK安装包... 目录1、卸载1.1 linux删除自带的JDK1.2 Linux上卸载自己安装的JDK2、安装2.1

Linux卸载自带jdk并安装新jdk版本的图文教程

《Linux卸载自带jdk并安装新jdk版本的图文教程》在Linux系统中,有时需要卸载预装的OpenJDK并安装特定版本的JDK,例如JDK1.8,所以本文给大家详细介绍了Linux卸载自带jdk并... 目录Ⅰ、卸载自带jdkⅡ、安装新版jdkⅠ、卸载自带jdk1、输入命令查看旧jdkrpm -qa

Java使用Curator进行ZooKeeper操作的详细教程

《Java使用Curator进行ZooKeeper操作的详细教程》ApacheCurator是一个基于ZooKeeper的Java客户端库,它极大地简化了使用ZooKeeper的开发工作,在分布式系统... 目录1、简述2、核心功能2.1 CuratorFramework2.2 Recipes3、示例实践3

springboot简单集成Security配置的教程

《springboot简单集成Security配置的教程》:本文主要介绍springboot简单集成Security配置的教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录集成Security安全框架引入依赖编写配置类WebSecurityConfig(自定义资源权限规则

MySQL Workbench 安装教程(保姆级)

《MySQLWorkbench安装教程(保姆级)》MySQLWorkbench是一款强大的数据库设计和管理工具,本文主要介绍了MySQLWorkbench安装教程,文中通过图文介绍的非常详细,对大... 目录前言:详细步骤:一、检查安装的数据库版本二、在官网下载对应的mysql Workbench版本,要是

python+opencv处理颜色之将目标颜色转换实例代码

《python+opencv处理颜色之将目标颜色转换实例代码》OpenCV是一个的跨平台计算机视觉库,可以运行在Linux、Windows和MacOS操作系统上,:本文主要介绍python+ope... 目录下面是代码+ 效果 + 解释转HSV: 关于颜色总是要转HSV的掩膜再标注总结 目标:将红色的部分滤

通过Docker Compose部署MySQL的详细教程

《通过DockerCompose部署MySQL的详细教程》DockerCompose作为Docker官方的容器编排工具,为MySQL数据库部署带来了显著优势,下面小编就来为大家详细介绍一... 目录一、docker Compose 部署 mysql 的优势二、环境准备与基础配置2.1 项目目录结构2.2 基

Linux安装MySQL的教程

《Linux安装MySQL的教程》:本文主要介绍Linux安装MySQL的教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux安装mysql1.Mysql官网2.我的存放路径3.解压mysql文件到当前目录4.重命名一下5.创建mysql用户组和用户并修

最新Spring Security实战教程之Spring Security安全框架指南

《最新SpringSecurity实战教程之SpringSecurity安全框架指南》SpringSecurity是Spring生态系统中的核心组件,提供认证、授权和防护机制,以保护应用免受各种安... 目录前言什么是Spring Security?同类框架对比Spring Security典型应用场景传统