当前位置: 首页 > news >正文

C# OpenCvSharp-HoughCircles(霍夫圆检测) 简单计数

目录

效果

项目

代码

下载 


效果

项目

代码

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using OpenCvSharp;
using OpenCvSharp.Extensions;

namespace OpenCvSharp_HoughCircles_霍夫圆检测_
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }

        private void button1_Click(object sender, EventArgs e)
        {
            pictureBox1.Image = new Bitmap("test01.jpg");
            Mat mat = new Mat("test01.jpg");
            Mat matClone = mat.Clone();
            Cv2.CvtColor(mat, mat, ColorConversionCodes.RGB2GRAY);//将彩色图像变成单通道灰度图像
            //霍夫圆检测:使用霍夫变换查找灰度图像中的圆。
            /*
             * 参数:
             *      1:输入参数: 8位、单通道、灰度输入图像
             *      2:实现方法:目前,唯一的实现方法是HoughCirclesMethod.Gradient
             *      3: dp      :累加器分辨率与图像分辨率的反比。默认=1
             *      4:minDist: 检测到的圆的中心之间的最小距离。(最短距离-可以分辨是两个圆的,否则认为是同心圆- src_gray.rows/8)
             *      5:param1:   第一个方法特定的参数。[默认值是100] canny边缘检测阈值低
             *      6:param2:   第二个方法特定于参数。[默认值是100] 中心点累加器阈值 – 候选圆心
             *      7:minRadius: 最小半径
             *      8:maxRadius: 最大半径
             */
            CircleSegment[] cs = Cv2.HoughCircles(mat, HoughMethods.Gradient, 1, 100, 100, 30, 40, 50);

            //排序
            Array.Sort(cs, (cs1, cs2) =>
            {
                if (cs1 != null && cs1 != null)
                {
                    if (cs1.Center.Y > cs2.Center.Y)
                        return 1;
                    else if (cs1.Center.Y == cs2.Center.Y)
                    {
                        if (cs1.Center.X < cs2.Center.X)
                            return 1;
                        else return -1;
                    }
                    else
                        return -1;
                }
                return 0;

            });

            int index = 1;
            for (int i = 0; i < cs.Count(); i++)
            {
                //画圆
                Cv2.Circle(matClone, (OpenCvSharp.Point)cs[i].Center, (int)cs[i].Radius, new Scalar(255, 255, 0), 2);
                Cv2.PutText(matClone, (index++).ToString(), (OpenCvSharp.Point)cs[i].Center, 0, 1, new OpenCvSharp.Scalar(0, 0, 0), 2);
            }
            pictureBox2.Image = BitmapConverter.ToBitmap(matClone);
        }
    }
}
 

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using OpenCvSharp;
using OpenCvSharp.Extensions;namespace OpenCvSharp_HoughCircles_霍夫圆检测_
{public partial class Form1 : Form{public Form1(){InitializeComponent();}private void button1_Click(object sender, EventArgs e){pictureBox1.Image = new Bitmap("test01.jpg");Mat mat = new Mat("test01.jpg");Mat matClone = mat.Clone();Cv2.CvtColor(mat, mat, ColorConversionCodes.RGB2GRAY);//将彩色图像变成单通道灰度图像//霍夫圆检测:使用霍夫变换查找灰度图像中的圆。/** 参数:*      1:输入参数: 8位、单通道、灰度输入图像*      2:实现方法:目前,唯一的实现方法是HoughCirclesMethod.Gradient*      3: dp      :累加器分辨率与图像分辨率的反比。默认=1*      4:minDist: 检测到的圆的中心之间的最小距离。(最短距离-可以分辨是两个圆的,否则认为是同心圆- src_gray.rows/8)*      5:param1:   第一个方法特定的参数。[默认值是100] canny边缘检测阈值低*      6:param2:   第二个方法特定于参数。[默认值是100] 中心点累加器阈值 – 候选圆心*      7:minRadius: 最小半径*      8:maxRadius: 最大半径*/CircleSegment[] cs = Cv2.HoughCircles(mat, HoughMethods.Gradient, 1, 100, 100, 30, 40, 50);//排序Array.Sort(cs, (cs1, cs2) =>{if (cs1 != null && cs1 != null){if (cs1.Center.Y > cs2.Center.Y)return 1;else if (cs1.Center.Y == cs2.Center.Y){if (cs1.Center.X < cs2.Center.X)return 1;else return -1;}elsereturn -1;}return 0;});int index = 1;for (int i = 0; i < cs.Count(); i++){//画圆Cv2.Circle(matClone, (OpenCvSharp.Point)cs[i].Center, (int)cs[i].Radius, new Scalar(255, 255, 0), 2);Cv2.PutText(matClone, (index++).ToString(), (OpenCvSharp.Point)cs[i].Center, 0, 1, new OpenCvSharp.Scalar(0, 0, 0), 2);}pictureBox2.Image = BitmapConverter.ToBitmap(matClone);}}
}

下载 

Demo下载

http://www.lryc.cn/news/329582.html

相关文章:

  • MybatisPlus速成
  • 【Django开发】0到1美多商城项目md教程第4篇:图形验证码,1. 图形验证码接口设计【附代码文档】
  • 八股 -- C#
  • 科创新格局·共赢双循环“2024上海智能科技与创新展览会”
  • Chatopera 云服务的智能问答引擎实现原理,如何融合 #聊天机器人 技术 #Chatbot #AI #NLP
  • 基于CNN-RNN的动态手势识别系统实现与解析
  • 华为鲲鹏认证考试内容有哪些
  • Gitlab CI---could not read username for xxx: no such device or address
  • 三个AI创业方向各有特点和市场潜力
  • C语言学习笔记二
  • Sublime Text4 4169 安装激活【亲测可用】
  • 【数据结构与算法初阶(c语言)】插入排序、希尔排序、选择排序、堆排序、冒泡排序、快速排序、归并排序、计数排序-全梳理(万字详解,干货满满,建议三连收藏)
  • [蓝桥杯 2019 省赛 AB] 完全二叉树的权值
  • 亮数据Bright Data,引领高效数据采集新体验
  • C#学习笔记
  • 【A-006】基于SSH的新闻发布系统(含论文)
  • c语言-static
  • zuul的性能调优
  • C++中的动态内存管理
  • es6的核心语法
  • Unity | 射线检测及EventSystem总结
  • 职业经验 2024 年测试求职手册
  • Spring Boot与Redis深度整合:实战指南
  • 微服务(基础篇-006-Docker安装-CentOS7)
  • 前端-css-01
  • Java学习36-Java 多线程安全:懒汉式和饿汉式
  • sql常用之CASE WHEN THEN
  • 【PduR路由】IPduM模块详细介绍
  • 【MySQL】6.MySQL主从复制和读写分离
  • Lucene及概念介绍