使用C#和OPenCV实现圆形检测

news2024/12/15 5:12:17

文章目录

  • 霍夫变换
  • 使用 OpenCV 和 C# 实现圆形检测

霍夫变换

 在计算机视觉中,圆形检测是一个常见且有用的任务,特别是在物体识别、图像分析和图形处理等领域。OpenCV 是一个强大的开源计算机视觉库,它提供了许多工具来实现不同的图像处理功能,其中包括圆形检测。本文将介绍如何使用 OpenCV 和 C# 实现圆形检测,探讨如何使用霍夫变换 (Hough Transform) 来检测图像中的圆形。
圆形检测的原理
 圆形检测的核心算法是 霍夫变换 (Hough Transform),它可以有效地在图像中检测出具有特定几何形状的物体。对于圆形,霍夫变换通过投票方式找到所有符合圆形方程的参数。具体来说,霍夫变换的基本思路是:

  • 每个图像中的边缘点在累加器中投票形成一组圆的候选参数。
  • 累加器中每个点的值表示该位置的圆心((x, y))以及半径(r)的可能性。
  • 然后,程序通过阈值化和圆心候选的聚集情况来确定最终的圆。

使用 OpenCV 和 C# 实现圆形检测

 OpenCV 提供了一个名为 HoughCircles 的函数,可以轻松地实现圆形检测。这个函数通过霍夫变换来检测图像中的圆。我们将用 C# 来调用 OpenCV 函数,下面是一个完整的实现过程。
1.安装OPenCVSharp库
 它是 OpenCV 的 C# 封装。你可以通过 NuGet 包管理器来安装:

Install-Package OpenCvSharp4

或者在项目上右键->管理NuGet程序包->搜索OPenCVSharp
在这里插入图片描述

2.代码实现

using OpenCvSharp;

class Program
{
    static void Main()
    {
        // 加载图像
        Mat src = Cv2.ImRead("图像路径", ImreadModes.Color);
		Mat src = Cv2.ImRead(imagePath, ImreadModes.Color);

		// 转为灰度图像
		Mat gray = new Mat();
		Cv2.CvtColor(src, gray, ColorConversionCodes.BGR2GRAY);

		// 高斯模糊,去噪
		Cv2.GaussianBlur(gray, gray, new OpenCvSharp.Size(9, 9), 2, 2);

		// 使用霍夫变换检测圆
		CircleSegment[] circles = Cv2.HoughCircles(
	    gray,              // 输入图像(灰度图像)
	    HoughModes.Gradient, // 霍夫变换方法
  		dp: 1.0,            // dp:图像分辨率与累加器分辨率的反比
  		minDist: 20,        // 圆心之间的最小距离
  		param1: 50,         // Canny边缘检测的高阈值
  		param2: 30,         // 圆心检测的阈值
  	 	minRadius: 0,       // 最小圆半径
  	 	maxRadius: 50      // 最大圆半径
);

		// 绘制检测到的圆
		foreach (var circle in circles){
 	  		// 将圆心从 Point2f 转换为 Point (整数)
 	  		var center = new OpenCvSharp.Point((int)circle.Center.X, (int)circle.Center.Y);
   			// 圆的半径是整数
   			int radius = (int)circle.Radius;

   			// 绘制圆
    		Cv2.Circle(src, center, radius, new Scalar(0, 0, 255), 2);

   			// 绘制圆心(使用一个小圆表示)
   			Cv2.Circle(src, center, 3, new Scalar(0, 255, 0), -1); // -1 表示填充
		}
		// 显示结果
        Cv2.ImShow("Detected Circles", src);
        Cv2.WaitKey();
        //将处理的好的图像渲染到pictureBox控件(需要装成Bitmap数据)
		//cvPicture.Image = MatToBitmap(src);
    }
}
private System.Drawing.Bitmap MatToBitmap(Mat mat)
{
    // 创建字节数组来接收编码的图像数据
    byte[] byteArray;

    // 使用 ImEncode 将 Mat 编码为指定格式(如 .bmp)
    if (Cv2.ImEncode(".bmp", mat, out byteArray))
    {
        // 将字节数组转换为 Bitmap
        using (MemoryStream ms = new MemoryStream(byteArray))
        {
            return new Bitmap(ms);  // 通过 MemoryStream 创建 Bitmap 对象
        }
    }
    else
    {
        throw new Exception("图像编码失败!");
    }
}

显示在pictureBox中的效果,空心圆和实心圆都能识别.
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2259735.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

数字图像处理(23):YUV444与YUV422

(1)在YUV颜色空间中,“Y”表示灰度,可以体现人眼对亮度的敏感程度,如果没有U和V信息,只有Y信息,图像仍然可以显示出来,只不过是灰色的;“U”和“V”表示色度,…

HQChart使用教程30-K线图如何对接第3方数据42-DRAWTEXTREL,DRAWTEXTABS数据结构

HQChart使用教程30-K线图如何对接第3方数据42-DRAWTEXTREL,DRAWTEXTABS数据结构 效果图DRAWTEXTREL示例数据结构说明nametypecolorDrawVAlignDrawAlignDrawDrawTypeDrawDataFont DRAWTEXTABS示例数据结构说明nametypecolorDrawVAlignDrawAlignDrawDrawTypeDrawDataFont 效果图 …

elasticsearch 使用Painless脚本

文章目录 1. 创建索引2. 插入模拟数据Painless 脚本的基本特点:Painless 脚本的常见用途1. 脚本查询和过滤示例:基于脚本的查询 2. 脚本字段示例:脚本字段 3. 聚合中的脚本示例:脚本聚合 4. 文档更新中的脚本示例:文档…

PHP搭建环境

一、安装apache 1、获取Apache安装软件 2、双击安装即可:指定对应的路径:E:server/apache 3、选择安装模式:使用自定义模式 4、选择安装位置 二、Apache的目录结构说明 三、Httpd.exe的详细应用 1、服务器进程:运行之后才能够工作

spring cloud contract http实例

微服务很多时,服务之前相互调用,接口参数的一致性要变得很难维护。 spring cloud contract 提供了测试接口一致性的方法。 一 项目配置 plugins {id "groovy"id "org.springframework.cloud.contract" version "4.0.5"i…

【GIS教程】使用GDAL-Python将tif转为COG并在ArcGIS Js前端加载-附完整代码

目录 一、数据格式 二、COG特点 三、使用GDAL生成COG格式的数据 四、使用ArcGIS Maps SDK for JavaScript加载COG格式数据 一、数据格式 COG(Cloud optimized GeoTIFF)是一种GeoTiff格式的数据。托管在 HTTP 文件服务器上,可以代替geose…

python数据分析之爬虫基础:解析

目录 1、xpath 1.1、xpath的安装以及lxml的安装 1.2、xpath的基本使用 1.3、xpath基本语法 2、JsonPath 2.1、jsonpath的安装 2.2、jsonpath的使用 2.3、jsonpath的基础语法 3、BeautifulSoup 3.1、bs4安装及创建 3.2、beautifulsoup的使用 3.3、beautifulsoup基本语…

【Python网络爬虫笔记】10- os库存储爬取数据

os库的作用 操作系统交互:os库提供了一种使用Python与操作系统进行交互的方式。使用os库来创建用于存储爬取数据的文件夹,或者获取当前工作目录的路径,以便将爬取的数据存储在合适的位置。环境变量操作:可以读取和设置环境变量。在…

TCP 为什么是 3 次握手 4 次挥手?

前言: TCP 的 3 次握手 4 次挥手是一个非常经典的问题,相信各位从事 Java 的朋友在职业生涯中没少被问到这个问题,本篇我们就展开分析一下 TCP 为什么是 3 次握手 4 次挥手。 TCP 协议 要搞清楚 TCP 为什么是 3 次握手 4 次挥手我们需要先…

智能客户服务:科技赋能下的新体验

在当今这个数字化时代,客户服务已经不仅仅是简单的售后服务,它已竞争的关键要素之一。随着人工智能、大数据、云计算等技术的飞速发展,智能客户服务正逐步改变着传统的服务模式,为企业和消费者带来了前所未有的新体验。 一、智能客…

C++ 内存管理和模板与STL

此篇目是之后各种C库的基础 目录 内存管理 内存分布 内存管理方式 new和delete operator new 与 operator delete函数 实现原理 定位new表达式(placement-new) 模板基础 泛型编程 模板 函数模板 类模板 STL 组成部分 内存管理 内存分布 int globalVar 1; //全局变量 静…

深入理解 CSS 文本换行: overflow-wrap 和 word-break

前言 正常情况下,在固定宽度的盒子中的中文会自动换行。但是,当遇到非常长的英文单词或者很长的 URL 时,文本可能就不会自动换行,而会溢出所在容器。幸运的是,CSS 为我们提供了一些和文本换行相关的属性;今…

Polars数据聚合与旋转实战教程

在这篇博文中,我们的目标是解决数据爱好者提出的一个常见问题:如何有效地从Polars DataFrame中创建汇总视图,以便在不同时间段或类别之间轻松进行比较。我们将使用一个实际的数据集示例来探索实现这一目标的各种方法。 Polars简介 Polars 是…

STM32CUBEMX+STM32F4+IAP串口升级应用,亲测可用,带详解

一、IAP的基本概念 IAP,全名为in applacation programming,即在应用编程。 也就是在应用程序中升级。好处就太多了,比如远程在线升级,不用人到现场拆开,用烧写器连接升级。 实现IAP技术的核心是一段预先烧写在单片机内部的IAP程序。这段程…

CTFHub 命令注入-综合练习(学习记录)

综合过滤练习 命令分隔符的绕过姿势 ; %0a %0d & 那我们使用%0a试试,发现ls命令被成功执行 /?ip127.0.0.1%0als 发现一个名为flag_is_here的文件夹和index.php的文件,那么我们还是使用cd命令进入到文件夹下 http://challenge-438c1c1fb670566b.sa…

深入探索 JVM:原理、机制与实战

一、JVM 概述 JVM(Java Virtual Machine)是 Java 程序运行的核心组件,它提供了一个独立于硬件和操作系统的执行环境,使得 Java 程序能够在不同平台上具有跨平台的特性。 JVM 主要由以下几部分组成: 类装载器&#xf…

视频推拉流EasyDSS无人机直播技术巡查焚烧、烟火情况

焚烧作为一种常见的废弃物处理方式,往往会对环境造成严重污染。因此,减少焚烧、推广绿色能源和循环经济成为重要措施。通过加强森林防灭火队伍能力建设与长效机制建立,各地努力减少因焚烧引发的森林火灾,保护生态环境。 巡察烟火…

挺详细的记录electron【V 33.2.0】打包vue3项目为可执行程序

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言 一、直接看效果 二、具体步骤 1.安装配置electron 1.将 electron 包安装到应用的开发依赖中。 2.安装electron-packager依赖(打包可执行文件&#…

基本分页存储管理

一、实验目的 目的:熟悉并掌握基本分页存储管理的思想及其实现方法,熟悉并掌握基本分页存储管理的分配和回收方式。 任务:模拟实现基本分页存储管理方式下内存空间的分配和回收。 二、实验内容 1、实验内容 内存空间的初始化——可以由用户输…

Vue Web开发(五)

1. axios axios官方文档 异步库axios和mockjs模拟后端数据,axios是一个基于promise的HTTP库,使用npm i axios。在main.js中引入,需要绑定在Vue的prototype属性上,并重命名。   (1)main.js文件引用 imp…