图像处理技术OpencvSharp入门

目录

第一部分 初识Opencv

1.C# 下Opencv库

2.安装OpenCvSharp

第二部分 OpencvSharp入门

1.加载图像文件

2.显示图像

第三部分 基础应用

1.颜色转换

2.尺寸调整

3.二值化

4.四则运算

5.颜色分割

6.直线检测

初识Opencv

C# 下使用Opencv 库

 

•在.NET下常用OpenCV进行图像处理工作,常用的.NET下的OpenCV库有Emgu CV和OpenCVSharp。

• Emgu CV是.NET平台下对OpenCV图像处理库的封装,也就是.NET版的OpenCV。由于OpenCV是用C和C++编写的,Emgu用C#对其进行封装,允许用.Net语言来调用OpenCV函数,如C#、VB、VC++等。

•OpenCvSharp 是一个OpenCV的.Net wrapper,应用最新的OpenCV库开发,使用习惯比EmguCV更接近原始的OpenCV,有详细的使用样例供参考。该库采用LGPL发行,对商业应用友好。使用OpenCvSharp,可用C#,VB.NET等语言实现多种流行的图像处理(image processing)与计算机视觉(computer vision)算法。

•使用VS2022新建一个.net6窗体项目。

•搜索安装opencvsharp4,安装OpenCvSharp4.Windows包。

 

OpencvSharp入门

加载图像文件

•创建一个帮助类OpencvHelper,后面都在此类中实现功能

•首先 usingOpenCvSharp;

•如何加载一个图像,返回Mat对象

•Mat mat= Cv2.ImRead(fileName, ImreadModes.Color);//加载为彩色图像,结果是三通道

•Mat mat= Cv2.ImRead(fileName, ImreadModes.Grayscale);//加载为灰度图像,结果是单通道,彩色的默认转灰色

•Mat mat= Cv2.ImRead(fileName, ImreadModes.AnyColor);//加载任意图像,结果随图像,灰色或者彩色。

Cv2.ImShow(“窗口名称”, mat);//mat是将要显示的Mat对象,

此处显示Mat对象必须是BGR格式,其他像素格式,需要转回BGR格

式再显示

•Cv2.WaitKey();//用于Cv2.ImShow的等待。没有此句则立即执行下一行代码

颜色转换

•Mat mat = Cv2.ImRead(fileName, ImreadModes.Color);

•Mat gray= newMat();

Cv2.CvtColor(mat, gray, ColorConversionCodes.BGR2GRAY);

 

 

 

•Mat mat = Cv2.ImRead(fileName, ImreadModes.Color);

•Mat hsv= newMat();

Cv2.CvtColor(mat, gray, ColorConversionCodes.BGR2HSV);//BGR转HSV格式

重点:ColorConversionCodes枚举

 

尺寸调整

•Mat result = newMat();

•Cv2.Resize(mat, result,  newOpenCvSharp.Size(100,100));

•重点:Cv2.Resize方法,有多个重载

 

二值化

•Mat gray = newMat();

•Cv2.CvtColor(mat, gray, ColorConversionCodes.BGR2GRAY);//转灰度图

•Scalarscalar  = Cv2.Mean(gray);//计算灰度图平均值

•Cv2.Threshold(gray, gray, scalar.Val0, 255, ThresholdTypes.Binary);//二值化

 

 

 

四则运算

•原则:通道相同,尺寸相同,才能运算。

Cv2.BitwiseAnd//与预算

Cv2.BitwiseNot//取反运算

Cv2.BitwiseOr //或运算

Cv2.BitwiseXor //异或运算

Cv2.Add//两图相加

Cv2.Subtract//两图相减

Cv2.Multiply //乘法

Cv2.Divide //除法

颜色分割

 

•//  HSV:H颜色范围

•// Orange  0 - 22

•//Yellow 22 - 38

•// Green 38 - 75

•// Blue 75 - 130

•// Violet 130 - 160

•// Red 160 - 179

 

•下面示例实分割红色区域代码

public static Mat GetColor(Mat mat){

•Cv2.ImShow("mat", mat);

•Mat hsv = newMat();//HSV格式对象

•Cv2.CvtColor(mat,hsv, ColorConversionCodes.BGR2HSV);//颜色转换

•var mask = hsv.InRange(newScalar(0, 46, 46), newScalar(29, 255, 255));//红色区域

•varmask2 = hsv.InRange(newScalar(165, 46, 46), newScalar(180, 255, 255));//红色区域

•Cv2.BitwiseOr(mask, mask2, mask);//范围叠加

•Cv2.BitwiseNot(mask, mask);//取反,黑白颜色反过来

•Cv2.ImShow("mask", mask);

•Mat mat1 = newMat();

•Cv2.CvtColor(mask, mat1, ColorConversionCodes.GRAY2BGR);//灰度图转彩色图,

•Cv2.Add(mat, mat1, mat1);//与原图相加,获取红色的区域

•Cv2.ImShow("mat1", mat1);

•Cv2.WaitKey();

•returnmat1;

}

 

直线检测

 Cv2.ImShow("mat", mat);

Mat gray = ConvertToBlackBinary(mat);

Cv2.ImShow("二值化", gray);

varkenal3 = Cv2.GetStructuringElement(MorphShapes.Rect, newOpenCvSharp.Size(2, 2));

Cv2.Dilate(gray, gray, kenal3);//

Cv2.ImShow("二值化Dilate", gray);

Cv2.Canny(gray, gray, 50, 150);

Cv2.ImShow("Canny", gray);

varlines = Cv2.HoughLinesP(gray, 1, Math.PI / 180, 100, 250, 50);

if (lines.Length > 0)

{

  for (int i = 0; i < lines.Length; i++)

  {

   Cv2.Line(mat, lines[i].P1, lines[i].P2,newScalar(255,0,0),1, LineTypes.AntiAlias);

  }

}

Cv2.ImShow("结果", mat);

return mat;

 

 

欢迎加入QQ群交流群进行技术交流,

本文项目代码地址:


OpenCvSharpStudy: OpenCvSharp学习实践项目 (gitee.com)

 

posted on 2022-12-05 12:01  饶玉田  阅读(2581)  评论(0编辑  收藏  举报