一、先是在程序中图像的导入,我是根据图像路径实现,其中path是string类型,是图像路径。

IntPtr img=CvInvoke.cvLoadImage(path, Emgu.CV.CvEnum.LOAD_IMAGE_TYPE.CV_LOAD_IMAGE_ANYCOLOR);

二、图像灰度化处理,先创建一幅尺寸大小为为原图的8位图像GrayImg1:

Rectangle cr = CvInvoke.cvGetImageROI(img1);

int width = cr.Width;

int height = cr.Height;

IntPtr GrayImg1 = CvInvoke.cvCreateImage(cr.Size, Emgu.CV.CvEnum.IPL_DEPTH.IPL_DEPTH_8U, 1);

现在就能使用cvCvtColor函数实现灰度化:

CvInvoke.cvCvtColor(img1, GrayImg1, Emgu.CV.CvEnum.COLOR_CONVERSION.CV_BGR2GRAY);

三、直方图的创建,并获取数据

int[] hist_size = new int[1] { 256 };//建一个数组来存放直方图数据

IntPtr HistImg=CvInvoke.cvCreateHist(1, hist_size, Emgu.CV.CvEnum.HIST_TYPE.CV_HIST_ARRAY, null, 1);//创建了一个空的直方图

CvInvoke.cvCalcHist(inPtr1, HistImg,false,System.IntPtr.Zero);//计算inPtr1指向图像的数据,并传入Histimg中,其中IntPtr[] inPtr1 = new IntPtr[1] { SubImg}。

现在要获取Histimg中的具体数据:

for (int i = 0; i < 256; i++)

{

temphist[i] = CvInvoke.cvQueryHistValue_1D(histImg, i);

}

这样在数组temphist中保存了直方图数据。

四、对第一步中由cvLoadImage导入的图像进行像素点的操作。由于img 是IntPtr类型无法直接进行操作,所以首先要进行格式的转化,把IntPtr型转换成MIplImage:

Emgu.CV.Structure.MIplImage MIpImg =

(Emgu.CV.Structure.MIplImage)System.Runtime.InteropServices.Marshal.PtrToStructure(img, typeof(Emgu.CV.Structure.MIplImage));

然后再C#中使用unsafe中指针操作:npixel = (int)((byte*)img.imageData + img.widthStep * i)[j];

五、IntPtr Dyncontour = new IntPtr();//存放检测到的图像块的首地址

IntPtr Dynstorage = CvInvoke.cvCreateMemStorage(0);开辟内存区域

int n= CvInvoke.cvFindContours(tempimg, Dynstorage, ref Dyncontour, StructSize.MCvContour, Emgu.CV.CvEnum.RETR_TYPE.CV_RETR_CCOMP,Emgu.CV.CvEnum.CHAIN_APPROX_METHOD.CV_CHAIN_APPROX_NONE, new Point(0, 0));

n表示检测到不为零区域的个数。

六、对第五步检测到的区域绘制轮廓

for(;DyncontourTemp!=null&&DyncontourTemp.Ptr.ToInt32()!=0;DyncontourTemp=DyncontourTemp.HNext)

{

CvInvoke.cvDrawContours(tempContImg, DyncontourTemp,new MCvScalar(255, 255, 255),new MCvScalar(255, 255, 255), 0, 1, Emgu.CV.CvEnum.LINE_TYPE.EIGHT_CONNECTED, new Point(0, 0));

}

其中的DyncontourTemp为

Seq<Point> DyncontourTemp1= new Seq<Point>(Dyncontour, null);//方便对IntPtr类型进行操作

Seq<Point> DyncontourTemp=DyncontourTemp1;

七、对第五步检测出的区域的坐标提取,通过cvFindContours函数的调用在 Dyncontour中存放的是不为零区域坐标的值存储在内存中的首地址指针。

seq<Point> DyncontourTemp1= new Seq<Point>(Dyncontour, null); //方便对IntPtr类型进行操作

int total=contourImg.Total;//contourImg包含的元素的总数

int TempX = 0;  int TempY = 0;int[,] contourArray = new int[2,total];

//获得轮廓的坐标值

for (int i = 0; i < total;i++ )

{

contourArray[0,i]=contourImg[i].X;

contourArray[1,i]=contourImg[i].Y;

}

EmguCV 一些基本操作相关推荐

  1. EmguCV基本操作(一)

    1 EmguCV 1.1 访问图片 //默认彩色模式打开Mat srcImg = CvInvoke.Imread(@"C:\Users\Administrator\Desktop\22.jp ...

  2. C#使用EmguCV库(图像读取、显示、保存)(二)

    使用C#+EmguCV处理图像入门(图像读取_显示_保存)二 上个随笔已经介绍EmguCV的一些常用库和程序安装以及环境变量的配置,这次写的是如何使用这个类库对图像进行操作. EmguCV图像处理系统 ...

  3. 第一章 初识EmguCV

    第一章 初识EmguCV 1.1 EmguCV的基本介绍 1.1.1 计算机视觉.OpenCV和EmguCV 计算机视觉是一门研究如何使机器"看"的科学,更进一步的说,就是是指用摄 ...

  4. 学习OpenCV(6) EmguCV 双目视觉

    使用EmguCV进行双目视觉的基本操作 EmguCV是什么? 简单的来讲,EmguCV是一个在.NET环境下的对OpenCV中的函数进行了封装的库,类似的还有OpencvSharp,其实如果我们想在C ...

  5. 数据结构(03)— 数据处理基本操作(数据的查找、新增、删除、修改)

    我们先来看一个关于查找的例子.查找,就是从复杂的数据结构中,找到满足某个条件的元素.通常可从以下两个方面来对数据进行查找操作:​ 根据元素的位置或索引来查找: 根据元素的数值特征来查找. 针对上述两种 ...

  6. pytorch方法,Tensor及其基本操作_重点

    由于之前的草稿都没了,现在只有重写-. 我好痛苦 本章只是对pytorch的常规操作进行一个总结,大家看过有脑子里有印象就好,知道有这么个东西,需要的时候可以再去详细的看,另外也还是需要在实战中多运用 ...

  7. Gradle安装使用以及基本操作

    转自:https://www.cnblogs.com/linkstar/p/7899191.html Gradle安装使用以及基本操作 阅读目录 简单介绍 安装 使用idea创建一个web的Gradl ...

  8. c++文件读取空格_程序员术与道:术—C语言对文件进行处理,文件处理的基本操作...

    各种编程语言都实现了文件的基本操作,提供了对应的接口,本篇文章先为你介绍C语言对文件进行处理和文件处理的基本操作.主要从以下几个方面进行介绍: 读取文件 写入文件 重命名文件 读取目录 读取目录下的文 ...

  9. 【Pandas库】(3) DataFrame的创建方法及基本操作

    各位同学好,今天给大家介绍一下Pandas库中DataFrame类型数据的创建方法和基本操作. 文章内容如下: (1)使用字典类创建. 字典类有:①数组.列表.元组构成的字典:②Series构造的字典 ...

最新文章

  1. asp.net mvc @RenderBody()的问题
  2. Linux下基本栈溢出攻击【转】
  3. 张萍萍 计科高职13-1 201303014010
  4. javafx2_JavaFX 2 GameTutorial第5部分
  5. LaTex在Linux下编写高质量的文档
  6. 使用Python把PowerPoint文件转换为配乐MP4视频
  7. 关于使用IDEA导入项目后依赖报错的解决方案
  8. matlab创建一个简易的MP3播放器GUI程序
  9. Godot 2D碰撞体节点
  10. Jquery仿IGoogle实现可拖动窗口(源码)
  11. Android 商品详情页
  12. Linux基操 笔记
  13. 9个常用的3D建模软件,你还知道哪些?
  14. 3D建模软件大总结,你都知道哪些?
  15. WAF(Web应用层防火墙)了解学习
  16. android移动支付——微信支付
  17. mysql微擎用户名密码_微擎后台管理员密码忘记怎么办?教你一个简单的方法
  18. 万字长文 | 2023届校招算法岗知识总结
  19. 表单输入框聚焦输入内容显示叉叉清除效果
  20. 支持幻灯片演示的思维导图软件NovaMind

热门文章

  1. OllyDBG反汇编快速找到程序入口一点分析
  2. 《MySQL——增删改查以及常用语法》
  3. scala char_Scala中的Char数据类型
  4. 面向对象(匿名内部类在开发中的应用)
  5. java,jdk安装,配置环境变量,window10系统
  6. 【汇编语言】除法(DIV/IDIV)
  7. h5分享到朋友圈_微信朋友圈创意招聘广告制作方法 H5模板
  8. 111. 二叉树的最小深度 golang
  9. 455. 分发饼干 golang
  10. Ubuntu 18的中文界面切换《图解教程》亲测成功