C# OpenCV 通过高度图去筛选轮廓

csharp 复制代码
//输入图像
threshCropMap.ImWrite("D:\\test\\threshCropMap_BeforeFilterByBlob.bmp");
//设定我们要筛选的高度
var ResultHeight = 60;
//创建对应高度的图像,由于是高度信息图,所有要使用32位来存放数据
Mat mat = new Mat(filter.Rows, filter.Cols, MatType.CV_32F, new Scalar(ResultHeight));
mat.ImWrite("D:\\test\\mat.bmp");

Mat ResultMat = new Mat(filter.Rows, filter.Cols, MatType.CV_32F, new Scalar(0));
//将基础图像减去高度图像,将低于指定高度的图像置为负值
Cv2.Subtract(threshCropMap, mat, ResultMat);
ResultMat.ImWrite("D:\\test\\ResultMat.bmp");
//将负值的数值置为0,仅保留大于指定高度的图像
Mat mask = new Mat();
Cv2.Compare(ResultMat, new Scalar(0), mask, CmpType.GT);
mask.ImWrite("D:\\test\\mask.bmp");

 Mat resultMat = new Mat();
ResultMat.CopyTo(resultMat, mask);
//将最终图像转换为8位灰度图,方便后续处理结果
resultMat.ConvertTo(resultMat, MatType.CV_8UC1);
int num = resultMat.CountNonZero();
Point[][] contours;
HierarchyIndex[] hierarchy;
Cv2.FindContours(resultMat, out contours, out hierarchy, RetrievalModes.External, ContourApproximationModes.ApproxSimple);            




相关推荐
柳鲲鹏7 小时前
OpenCV:超分辨率、超采样及测试性能
人工智能·opencv·计算机视觉
sali-tec11 小时前
C# 基于OpenCv的视觉工作流-章16-凸包
图像处理·人工智能·opencv·算法·计算机视觉
暮疯不疯12 小时前
C#常见术语表格
开发语言·c#
扶尔魔ocy12 小时前
【国产桌面操作系统】打包opencv的离线安装包
opencv·离线安装·国产信创
JQLvopkk13 小时前
VS2015使用C#连接KepserverEX并操作读写节点
开发语言·c#
光羽隹衡13 小时前
计算机视觉--Opencv(轮廓检测+轮廓特征+轮廓近似)
人工智能·opencv·计算机视觉
qwy71522925816314 小时前
5-图像加法运算
人工智能·opencv·计算机视觉
sali-tec14 小时前
C# 基于OpenCv的视觉工作流-章17-外接矩形
图像处理·人工智能·opencv·算法·计算机视觉
流水线上的指令侠15 小时前
补充说明——针对《C#:从 0 到 1 创建基于 NUnit + FlaUI 的 WPF UI 自动化测试项目》
功能测试·ui·c#·自动化·wpf
流水线上的指令侠15 小时前
C# 实战:从 0 到 1 搭建基于 NUnit + FlaUI 的 WPF UI 自动化测试项目
功能测试·ui·c#·自动化·wpf·visual studio