9.OpenCvSharp图像灰度直方图(BGR、HSV、Lab多通道及单通道的灰度直方图)——c#OpenCvSharp学习笔记

OpenCvSharp图像灰度直方图(BGR、HSV、Lab多通道及单通道的灰度直方图

在这里插入图片描述
在这里插入图片描述

项目概述

项目实现了基于OpenCvSharp实现了BGR、HSV、Lab多通道及单通道的灰度直方图,包含了HSV和Lab的转换,及使用chart控件绘制直方图,可将打开后的图片处理后并保存到本地磁盘。

源代码在本文底部

1基础步骤和界面设计

1.1引用using OpenCvSharp;using OpenCvSharp.Extensions;
1.2将Picturebox、Label、Button等控件进行布局、改名、调整形状和字体,形成如下界面:
在这里插入图片描述

2功能实现

2.1初始化变量

        Mat Img1 = new Mat();//用 Mat类定义图片1
        Mat Img2 = new Mat();//用 Mat类定义图片2
        Mat ImgCvt = new Mat();
        Bitmap bitmap;//Bitmap类定义picturebox2要显示的图片
        string pathname;//定义图片打开路径

2.2图表参数设置

 private void chart_load()//设置图表参数
        {
            chart1.Series.Clear();
            chart1.ChartAreas[0].AxisX.Title = "灰度";
            chart1.ChartAreas[0].AxisX.TitleFont =new Font("宋体",15f) ;
            chart1.ChartAreas[0].AxisX.TitleForeColor = Color.Red;
            chart1.ChartAreas[0].AxisX.TitleForeColor = System.Drawing.Color.Crimson;
            chart1.ChartAreas[0].AxisY.Title = "个数";
            chart1.ChartAreas[0].AxisY.TitleFont = new Font("宋体", 15f);
            chart1.ChartAreas[0].AxisY.TitleForeColor = Color.Blue;
            chart1.ChartAreas[0].AxisY.TitleForeColor = System.Drawing.Color.Crimson;
            chart1.ChartAreas[0].AxisY.TextOrientation = TextOrientation.Horizontal;
         }

2.3 HSV或Lab转换及三通道的直方图

private void button20_Click(object sender, EventArgs e)
        {
            if (pictureBox1.Image == null)//判断图片是否已打开
            {
                MessageBox.Show("没有打开图片");
                return;
            }
            Mat src = Cv2.ImRead(pathname);//读取路径下的图片

            Cv2.CvtColor(src, src, ColorConversionCodes.BGR2HSV);//

          

            bitmap = BitmapConverter.ToBitmap(src); //把Mat格式的图片转换成Bitmap
            pictureBox2.Image = bitmap;


            chart1.Series.Clear();//清空cShart

            Series H = new Series("H");//H通道
            Series S = new Series("S");//S通道
            Series V= new Series("V");//V通道

            Mat[] picturechannel = new Mat[3];
            Cv2.Split(src, out picturechannel);
            int[] histSize = { 256 };
            Rangef[] histRange = { new Rangef(0, 256) }; //the upper boundary is exclusive               

            bool uniform = true, accumulate = false;
            Mat channel1 = new Mat();
            Mat channel2 = new Mat();
            Mat channel3 = new Mat();

            Cv2.CalcHist(picturechannel, new int[] { 0 }, null, channel1, 1, histSize, histRange, uniform, accumulate);
            Cv2.CalcHist(picturechannel, new int[] { 1 }, null, channel2, 1, histSize, histRange, uniform, accumulate);
            Cv2.CalcHist(picturechannel, new int[] { 2 }, null, channel3, 1, histSize, histRange, uniform, accumulate);



            for (int i = 1; i < histSize[0]; i++)
            {


                H.Points.AddXY(i, Math.Round(channel1.At<float>(i - 1)));
                S.Points.AddXY(i, Math.Round(channel2.At<float>(i - 1)));
                V.Points.AddXY(i, Math.Round(channel3.At<float>(i - 1)));

            }

            //绘制曲线
            chart1.Series.Add(H);
            chart1.Series.Add(S);
            chart1.Series.Add(V);

        }

2.4单通道法

 private void button7_Click(object sender, EventArgs e)
        {

            if (pictureBox1.Image == null)//判断图片是否已打开
            {
                MessageBox.Show("没有打开图片");
                return;
            }
            Mat src = Cv2.ImRead(pathname);//读取路径下的图片

            bitmap = BitmapConverter.ToBitmap(src); //把Mat格式的图片转换成Bitmap
            Mat dst = new Mat(src.Size(), MatType.CV_8U);
   
            int height = src.Rows;
            int width = src.Cols;
            for (int row = 0; row < height; row++)
            {
                for (int col = 0; col < width; col++)
                {
                    dst.At<byte>(row, col) = (byte)src.At<Vec3b>(row, col)[0];
                }
            }
            bitmap = BitmapConverter.ToBitmap(dst); //把Mat格式的图片转换成Bitmap
            pictureBox2.Image = bitmap;


            chart1.Series.Clear();//清空chart

            Series B = new Series("B");//B通道
            B.Color=Color.Gray;

            Mat[] picturechannel = new Mat[3];
            Cv2.Split(src, out picturechannel);
            int[] histSize = { 256 };
            Rangef[] histRange = { new Rangef(0, 256) }; //the upper boundary is exclusive               

            bool uniform = true, accumulate = false;
            Mat channel1 = new Mat();
       

            Cv2.CalcHist(picturechannel, new int[] { 0 }, null, channel1, 1, histSize, histRange, uniform, accumulate);
   



            for (int i = 1; i < histSize[0]; i++)
            {


                B.Points.AddXY(i, Math.Round(channel1.At<float>(i - 1)));
              
            }

            //绘制曲线
            chart1.Series.Add(B);
       
        }

**

源代码:https://download.csdn.net/download/sunsoldeir1/87254081

**

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
### 回答1: OpenCvSharp是一个基于OpenCV的C#编程库,它提供了许多图像处理和计算机视觉功能。其中,图像灰度是一种非常基本的处理方法。 图像灰度是指将彩色图像转换为灰度图像的过程。在图像灰度处理中,每个像素的RGB值被替换为一个单一的亮度值,这个值表示像素的加权平均值,其中不同颜色的加权系数可能不同。 例如,当一个像素的原始RGB值为(120,150,200),并且所选的加权系数为0.299,0.587和0.114(这些系数与人眼感知的亮度有关),该像素的灰度值为(0.299*120+0.587*150+0.114*200)=157.7。 在OpenCvSharp中进行图像灰度处理非常简单,只需使用以下代码: Mat src = Cv2.ImRead("image.jpg"); Mat gray = new Mat(); Cv2.CvtColor(src, gray, ColorConversionCodes.BGR2GRAY); Cv2.ImShow("Gray image", gray); Cv2.WaitKey(0); 以上代码从文件读取图像,将其转换为灰度图像,并将其显示在窗口中。Cv2.CvtColor函数用于将图像BGR颜色空间转换为灰度颜色空间。 总之,OpenCvSharp提供了简便易行的方法来进行图像灰度处理,使得使用OpenCV进行图像处理变得更加方便。 ### 回答2: OpenCVSharp是一个基于C#开发的计算机视觉库。该库可以对图像进行各种操作,包括灰度化处理。 在数字图像处理的领域中,灰度化是最常用的一种预处理方式。灰度化是将彩色图像转换为灰度图像的过程。在灰度图像中,每个像素点的灰度值只有一个数值,它代表了该像素点的亮度值。 在OpenCVSharp中,要进行灰度化处理,首先需要对图像进行读取。可以借助Mat类实现图像读取功能。 然后,可以使用CV方法中的CvtColor()函数将彩色图像转换为灰度图像。其中,需要指定转换的代码,即从BGR色彩空间到灰度色彩空间的转换方法。 以下是一个简单的示例代码,可以将彩色图像转换为灰度图像: ```C# using (Mat src = Cv2.ImRead("lena.jpg", ImreadModes.Color)) { Mat gray = new Mat(); Cv2.CvtColor(src, gray, ColorConversionCodes.BGR2GRAY); Cv2.ImWrite("lena_gray.jpg", gray); } ``` 同时,需要注意的是,灰度化处理只是数字图像处理的起始步骤,在实际应用中还需要进行更多的图像处理和分析操作。 ### 回答3: OpenCVSharp 是一款基于 OpenCV 库的 C# 开源图像处理库,可以实现图像的灰度化操作。图像灰度化是指将图像转化为只有黑白两种颜色的灰度图像,也称为黑白转换。 在 OpenCVSharp 中,可以使用 cvtColor() 函数进行图像的颜色空间转换,从而实现图像的灰度化。该函数的调用方法如下: Cv2.CvtColor(src, dst, ColorConversionCodes.BGR2GRAY); 其中,src 表示源图像,dst 表示转换后的目标图像BGR2GRAY 表示将 BGR 格式的彩色图像转换为灰度图像。 经过灰度化处理后,图像中的每个像素只有一个灰度值,该值表示该点的亮度。灰度化操作可以降低图像数据的维度,同时能够去除图像中的颜色信息,使得图像更便于处理和分析。 在实际应用中,灰度化操作常常用于图像处理中的前置步骤,例如在图像识别和目标检测中,灰度化操作可以减少计算量,提高算法效率。此外,灰度化操作也适用于图像压缩、美化和增强等领域。
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值