C#:圆环的截取

2023-07-17  本文已影响0人  大龙10

一、圆检测

Cv2.HoughCircles(m2, HoughMethods.Gradient, 1, 30, 80, 20, 40, 80);

二、圆环切割

Mat maskROI = Mat.Zeros(dst.Size(), dst.Type());
Cv2.Circle(maskROI, (int)cs[0].Center.X, (int)cs[0].Center.Y, (int)cs[0].Radius+10, new Scalar(255, 255, 255), 30, LineTypes.AntiAlias);

Mat myROI = new Mat();
src_img.CopyTo(myROI, maskROI);

圆环的截取

三、掩膜

四、掩膜的作用

因为整个特性,在计算机视觉中,人们常用掩膜来作以下作用:

「暖仔会飞」的博客:
   https://blog.csdn.net/qq_42902997/article/details/105003522

五、程序

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Runtime.CompilerServices;
using System.Runtime.InteropServices;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using Sunny.UI;
using OpenCvSharp;
using OpenCvSharp.Extensions;

namespace Ky_HoughCircle
{
    public partial class Form1 : UIForm
    {

        public Form1()
        {
            InitializeComponent();
            this.SetStyle(ControlStyles.OptimizedDoubleBuffer | ControlStyles.ResizeRedraw | ControlStyles.AllPaintingInWmPaint, true);

        }
        private Image image = null;
        private Mat dst = new Mat();
        private Mat src_img;
        string filePath = "";
        //private static int Num = 20;
        private List<Mat> reList = new List<Mat>();
        private int step = 1;
        public struct CircleSegment0
        {
            public Point2f Center;
            public float Radius;
        };
        CircleSegment0[] cs0 = new CircleSegment0[10];

        private void openImage_Click(object sender, EventArgs e)
        {
            OpenFileDialog openFileDialog = new OpenFileDialog();
            openFileDialog.Title = "选择操作的图片";
            openFileDialog.Filter = "图片 *.jpg|*.jpg|*.bmp|*.bmp|图像*.png|*.png";
            if (openFileDialog.ShowDialog() == DialogResult.OK)
            {
                filePath = openFileDialog.FileName;
                image = Image.FromFile(filePath);
                src_img = Cv2.ImRead(filePath);
                Mat tem1 = new Mat();
                src_img.CopyTo(tem1);
                if (reList.Count > 0)
                {
                    reList[0] = tem1;
                }
                else
                {
                    reList.Add(tem1);
                }
            }
            if (filePath != "")
            {
                picBoxShowDel.Image = image;
                picShowOri.Image = image;
            }
        }

        private void uiButton2_Click(object sender, EventArgs e)
        {

            {
                //1:因为霍夫圆检测对噪声比较敏感,所以首先对图像做一个中值滤波或高斯滤波(噪声如果没有可以不做)
                Mat m1 = new Mat();
                Cv2.MedianBlur(src_img, m1, 3); //  ksize必须大于1且是奇数
                //2:转为灰度图像
                Mat m2 = new Mat();
                Cv2.CvtColor(m1, m2, ColorConversionCodes.BGR2GRAY);
                //3:霍夫圆检测:使用霍夫变换查找灰度图像中的圆。
                CircleSegment[] cs = Cv2.HoughCircles(m2, HoughMethods.Gradient, 1, 30, 80, 20, 40, 80);
                src_img.CopyTo(dst);

                for (int i = 0; i < cs.Count(); i++)
                {
                    //画圆
                    Cv2.Circle(dst, (int)cs[i].Center.X, (int)cs[i].Center.Y, (int)cs[i].Radius, new Scalar(0, 0, 255), 5, LineTypes.AntiAlias);
                    Cv2.Circle(dst, (int)cs[i].Center.X, (int)cs[i].Center.Y, (int)cs[i].Radius+30, new Scalar(0, 255, 255), 3, LineTypes.AntiAlias);
                    //加强圆心显示
                    Cv2.Circle(dst, (int)cs[i].Center.X, (int)cs[i].Center.Y, 3, new Scalar(0, 0, 255), 3, LineTypes.AntiAlias);

                    cs0[i].Center = cs[i].Center;
                    cs0[i].Radius = cs[i].Radius;
                    int x0 = (int)cs[i].Center.X;
                    int y0 = (int)cs[i].Center.Y;
                    //显示圆心坐标
                    Cv2.PutText(dst, i.ToString() + "(" + x0.ToString() + "," + y0.ToString() + ")", new OpenCvSharp.Point(x0 - 100, y0 + 200), 0, 1.25, new OpenCvSharp.Scalar(0, 0, 255), 2);
                }
                //using (new Window("OutputImage", WindowMode.AutoSize, dst))
                picBoxShowDel.Image = dst.ToBitmap();

                Mat maskROI = Mat.Zeros(dst.Size(), dst.Type());//在mask黑色背景下,画一样的圆,填充白色
                Cv2.Circle(maskROI, (int)cs[0].Center.X, (int)cs[0].Center.Y, (int)cs[0].Radius+10, new Scalar(255, 255, 255), 30, LineTypes.AntiAlias);
                Mat myROI = new Mat();
                src_img.CopyTo(myROI, maskROI);

                pictureBox1.Image = OpenCvSharp.Extensions.BitmapConverter.ToBitmap(myROI);
            }
        }
    }
}

上一篇 下一篇

猜你喜欢

热点阅读