Emgucv使用中常用函数总结
Emgucv常用函数总结:
读取图片
Mat SCr = new Mat(Form1.Path, Emgu.CV.CvEnum.LoadImageType.AnyColor);
//根据路径创建指定的灰度图片
Mat scr = new Mat(Form1.Path, Emgu.CV.CvEnum.LoadImageType.Grayscale);
获取灰度 //图像类型转换, bgr 转成 gray 类型。MAT Bw = New MAT
CvInvoke.CvtColor(SCr, bw, Emgu.CV.CvEnum.ColorConversion.Bgr2Gray);
//相当于二值化图 --黑白 根据大小10判断为0还是255
CvInvoke.Threshold(bw,bw,,,Emgu.CV.CvEnum.ThresholdType.BinaryInv);
//获取指定区域图片 SCr为mat类型
Rectangle rectangle = new Rectangle(,,,);
SCr = SCr.ToImage<Bgr, byte>().GetSubRect(rectangle).Mat;
//将Mat类型转换为Image类型
Image<Bgr, byte> Su = SCr.ToImage<Bgr, byte>();
Image<Bgr, byte> Img = new Image<Bgr, byte>(new Bitmap(""));//路径声明
Image<Bgr, byte> Sub = SCr.ToImage<Bgr, byte>().GetSubRect(rectangle);//指定范围
//指定参数获得结构元素
Mat Struct_element = CvInvoke.GetStructuringElement(Emgu.CV.CvEnum.ElementShape.Cross, new Size(, ), new Point(-, -));
//膨胀
CvInvoke.Dilate(bw, bw, Struct_element, new Point(,),,Emgu.CV.CvEnum.BorderType.Default, new MCvScalar(, , ));
//腐蚀 当Struct_element模型创建不合理或者膨胀腐蚀次数较大时可能图像会发生偏移
CvInvoke.Erode(bw, bw, Struct_element, new Point(-, -), ,Emgu.CV.CvEnum.BorderType.Default, new MCvScalar(, , ));
//轮廓提取
VectorOfVectorOfPoint contours = new VectorOfVectorOfPoint();
//筛选后
CvInvoke.FindContours(bw, contours, null, Emgu.CV.CvEnum.RetrType.List, Emgu.CV.CvEnum.ChainApproxMethod.ChainApproxSimple);
int ksize = contours.Size;//获取连通区域的个数。
VectorOfPoint contour = contours[i];//获取独立的连通轮廓
Rectangle rect = CvInvoke.BoundingRectangle(contour);//提取最外部矩形。
double Length = CvInvoke.ArcLength(contour, false);//计算连通轮廓的周长。
//画出轮廓
Mat mask = bw.ToImage<Bgr, byte>().CopyBlank().Mat;
//获取一张背景为黑色的图像, 大小与 scr 的大小一样, 类型为 Bgr。
CvInvoke.DrawContours(mask, contours, -, new MCvScalar(, , ));
Image<Ycc, byte> ycc_img = bgr_img.Convert<Ycc, byte>();//把 bgr颜色图片转成ycbcr类型。
Ycc min = new Ycc(, , );//最小值的颜色。
Ycc max = new Ycc(, , );//最大值得颜色。
Image<Gray, byte> result = ycc_img.InRange(min, max);//进行颜色提取。
Image<Bgr, byte> bgr_img = Ma.ToImage<Bgr, byte>();//载入一张 Bgr 类型的图片。
Bgr min = new Bgr(, , );//白色的最小值, 允许一定154的误差。
Bgr max = new Bgr(, , );//白色的最大值, 允许一定的误差。
Image<Gray, byte> result = bgr_img.InRange(min, max);//进行颜色提取。
Image<Bgr, Byte> imageSource = new Image<Bgr, Byte>(SCr.Bitmap);
Image<Hsv, Byte> imageHsv = imageSource.Convert<Hsv, Byte>();//将色彩空间从BGR转换到HSV
Image<Gray, Byte>[] imagesHsv = imageHsv.Split();//分解成H、S、V三部分
CvInvoke.AbsDiff(Ma1, Ma2, Ma); // 返回两幅图片或此图与某个yanse像素的差的绝对值的图片
CvInvoke.Add(Ma1, Ma2, Ma); // 返回这张图片与图片或颜色直接相加的图片(矩阵加法) (适应两种效果)
//CvInvoke.HConcat(Ma1, Ma2, Ma); //返回与另一张图片横向链接的图片
//CvInvoke.VConcat(Ma1, Ma2, Ma);//返回与另一张图片纵向链接的图片 //清除小于平均顶点10的二值图
Point[] po = { new Point(, ), new Point(res.Width, ), new Point(res.Width, minAvg - Gets.Fges[] + ), new Point(, minAvg - Gets.Fges[] + ) };
VectorOfPoint vp = new VectorOfPoint(po);
//CvInvoke.DrawContours(res, vp, -1, new MCvScalar(0, 0, 255));
CvInvoke.FillConvexPoly(res,vp,new MCvScalar(),LineType.EightConnected);//填充指定区域 /// <summary>
/// 灰度直方图计算 手动计算、/获取百分比的阀值 0.95
/// </summary>
public static void GetDenseHistogram95(ref int huidu, Mat ma)
{
DenseHistogram dense = new DenseHistogram(, new RangeF(, ));
dense.Calculate(new Image<Gray, Byte>[] { ma.ToImage<Gray, byte>() }, true, null);
//计算直方图数据。
float[] data = dense.GetBinValues();
float[] data2 = dense.GetBinValues();
//获得直方图数据。
/*** 进行数据归一化到[0,256]区域内并且绘制直方图***/
float max = data[]; //最大值
for (int j = ; j < data.Length; j++)
{
if (data[j] > max)
{
max = data[j];
}
}
float Sum = data2.ToList().Sum();
float FloCount = ;
for (int k = ; k < data.Length; k++)
{
data[k] = data[k] * / max;
FloCount += data2[k];
if (FloCount / Sum >= 0.95)
{
huidu = k;
break;
}
}} //各种颜色空间 Hsv/Rgb/Hls/Xyz/Ycc/Gray
public static Image<Hsv, Byte> imageHsv=new Image<Hsv, byte>(mat.Bitmap);
public static Image<Rgb, Byte> Rgbimg = new Image<Rgb, byte>(mat.Bitmap);
public static Image<Hls, Byte> Hlsimg = new Image<Hls, byte>(mat.Bitmap);
public static Image<Xyz, Byte> Xyzimg = new Image<Xyz, byte>(mat.Bitmap);
public static Image<Ycc, Byte> Yccimg = new Image<Ycc, byte>(mat.Bitmap);
public static Image<Gray, Byte> Grayimg = new Image<Gray, byte>(mat.Bitmap);
Image<Gray, Byte>[] imagesHsvs = imageHsv.Split();//分解成H、S、V三部分其他相同
//高斯滤波实现
CvInvoke.GaussianBlur(ma, ma, new Size(, ), );
//形态学闭运算,先膨胀后腐蚀 Others.matWithPhi(by)自定义模型
CvInvoke.MorphologyEx(ma, ma, Emgu.CV.CvEnum.MorphOp.Close, Others.matWithPhi(by), new Point(-, -), , Emgu.CV.CvEnum.BorderType.Default, new MCvScalar(, , ));
CvInvoke.MedianBlur(ma, ma, );//中值滤波实现
CvInvoke.PutText(ma05, "G num: 1", new Point(, ), FontFace.HersheyComplex, 0.5, new MCvScalar()); //指定坐标(10, 100)显示文字,中文乱码,
VectorOfPoint vp = new VectorOfPoint();
CvInvoke.ConvexHull(pointof, vp);////查找最小外接矩形cvInpaint
double dou = CvInvoke.ContourArea(vp, false); //计算面积
VectorOfPoint vect = new VectorOfPoint();
CvInvoke.FindNonZero(ma, vect); //获取非0的点
Mat maSave1 = ma5.Clone();//备份 保留原有图片
CvInvoke.AdaptiveThreshold(ma, mas, , AdaptiveThresholdType.GaussianC, Emgu.CV.CvEnum.ThresholdType.Binary, , );//查找最适合二值图
收集的Emgucv的整理书籍资料和Emgucv动态调试器:下载地址
本文代码下载:下载
Emgucv使用中常用函数总结的更多相关文章
- EXCLE使用中常用函数和公式
1.查找重复项 IF(COUNTIF(A:A,A1)>1"重复""") 或者 IF(COUNTIF($A$1:$A$100,A1)=1,"&qu ...
- EmguCV常用函数总结
Emgucv常用函数总结: 读取图片 Mat SCr = new Mat(Form1.Path, Emgu.CV.CvEnum.LoadImageType.AnyColor); //根据路径创建指定的 ...
- 【转载】gcc 使用中常用的参数及命令
本文转载自:http://www.cnblogs.com/yaozhongxiao/archive/2012/03/16/2400473.html 如需转载,请注明原始出处.谢谢. --------- ...
- 转战JS(1) 初探与变量类型、运算符、常用函数与转换
转战JS(1)初探与变量类型.运算符.常用函数与转换 做为一名.NET后台开发人员,正考滤向Web前端开发转型,之前也写过一代前端代码,可是当再回头看JS,并有转向它的意愿的时候,突然发现:原来JS不 ...
- STL之map与pair与unordered_map常用函数详解
STL之map与pair与unordered_map常用函数详解 一.map的概述 map是STL的一个关联容器,它提供一对一(其中第一个可以称为关键字,每个关键字只能在map中出现一次,第二个可能称 ...
- oracle常用函数及示例
学习oracle也有一段时间了,发现oracle中的函数好多,对于做后台的程序猿来说,大把大把的时间还要学习很多其他的新东西,再把这些函数也都记住是不太现实的,所以总结了一下oracle中的一些常用函 ...
- 总结js常用函数和常用技巧(持续更新)
学习和工作的过程中总结的干货,包括常用函数.常用js技巧.常用正则表达式.git笔记等.为刚接触前端的童鞋们提供一个简单的查询的途径,也以此来缅怀我的前端学习之路. PS:此文档,我会持续更新. Aj ...
- [转]SQL 常用函数及示例
原文地址:http://www.cnblogs.com/canyangfeixue/archive/2013/07/21/3203588.html --SQL 基础-->常用函数 --===== ...
- PHP常用函数、数组方法
常用函数:rand(); 生成随机数rand(0,50); 范围随机数时间:time(); 取当前时间戳date("Y-m-d H:i:s"); Y:年 m:月份 d:天 H:当前 ...
随机推荐
- 2018-2019-2 《Java程序设计》第9周学习总结
20175319 2018-2019-2 <Java程序设计>第9周学习总结 教材学习内容总结 本周学习任务: 下载安装MySQL数据库管理系统. 教材介绍在官网下载安装Mysql服务,启 ...
- Aras 引入外部的dll
1.在vs中编译项目.然后找到项目目录生成好的dll. 2.找到Aras的安装目录:...\Aras\Innovator\Innovator\Server,将dll放到该目录下.然后在该目录下找到me ...
- #0 scrapy爬虫学习中遇到的坑记录
python 基础学习中对于scrapy的使用遇到了一些问题. 首先进行的是对Amazon.cn的检索结果页进行爬取,很顺利,无碍. 下一个目标是对baidu的搜索结果进行爬取 1,反爬虫 1.1 我 ...
- S2-045漏洞初步分析
0x01 前言 前几天刚分析完s2-032这个漏洞,今天又爆发了一个s2-045的漏洞,又是直接的命令执行,影响了struts2绝大多数的版本. 官方给的漏洞公告在这里 https://cwiki ...
- 使用第三方工具Thumbnailator动态改变图片尺寸
Thumbnailator项目git地址:https://github.com/coobird/thumbnailator 使用步骤 1.添加依赖 <!-- Thumbnailator图片处理 ...
- Lombok插件看法浅谈
背景 最近接触的几个工程中Lombok插件出现频率比较高,趁机了解一下原理. 简要说明: 受益于JSR 269 API,程序可以在编译阶段对AST进行节点的操作,从而注入相关的功能结点,从而包含在最终 ...
- 2018-2019-2 20165234 《网络对抗技术》 Exp0 Kali安装 Week1
Week1 kali安装 一.下载系统镜像文件 首先下载系统镜像,进入kali官网,在Downloads中选择Download Kali Linux. 我选择的是64位版本,点击HTTP下载镜像文件. ...
- BFS 模拟队列(水题)
BFS 这道题 觉得比较适合BFS新手入门写,也许大家都以为最入门 的BFS题是在二维图上搜索,但是这道题是线性搜索,更加简单 POJ 3278 Catch That Cow Time Limit: ...
- C# 解压缩工具类GZip
using System; using System.Collections.Generic; using System.IO; using System.IO.Compression; using ...
- python正则表达式--分组、后向引用、前(后)向断言
无名.有名分组 (1)正则表达式—无名分组 从正则表 达式的左边开始看,看到的第一个左括号“(”表示表示第一个分组,第二个表示第二个分组, 依次类推. 需要注意的是,有一个隐含的全局分组(就是索引号为 ...