Halcon实战:精准定位与提取:基于形态学处理的猴子眼睛区域检测完整方案

在机器视觉与图像处理领域,区域定位与特征提取是许多应用中的核心任务。本文将以一张猴子图像为例,详细介绍如何使用 Halcon 软件实现对其眼睛区域的精准定位与提取。我们将通过一系列图像处理操作,逐步拆解处理流程,帮助大家理解每一步的作用与意义。

一、图像读取与灰度化

首先,我们读取原始彩色图像,并将其转换为灰度图像。这样做可以减少后续处理的复杂度,同时保留足够的结构信息。

复制代码
read_image (Image, 'D:/Machine_vision_images_and_programs/monkey.jpg')
rgb1_to_gray (Image, GrayImage)
二、阀值分割(二值化与区域粗选)

我们通过设定灰度阈值(50~110)对图像进行二值化,初步提取出可能包含眼睛的区域。这一步是"粗选",目的是将目标区域从背景中分离出来。

复制代码
threshold (GrayImage, Region, 50, 110)
三、区域填充与连通域分析

由于二值化后的区域可能存在空洞,我们使用 fill_up 进行填充,确保区域完整。接着通过 connection 操作将图像中不连续的区域分离为多个连通域,便于后续筛选。

复制代码
fill_up (Region, RegionFillUp)
connection (RegionFillUp, ConnectedRegions)
四、形状筛选

我们根据区域的面积特征进行筛选,只保留面积在 1950~2000 像素之间的区域。这一步能够有效排除不符合条件的干扰区域。

复制代码
select_shape (ConnectedRegions, SelectedRegions, 'area', 'and', 1950, 2000)
五、形态学去噪

为了进一步去除微小噪声或边缘毛刺,我们使用圆形结构元素进行腐蚀与膨胀操作。这一对操作能够平滑区域边界,并去除不规则的细小区域。

复制代码
erosion_circle (SelectedRegions, RegionErosion, 3.5)
dilation_circle (RegionErosion, RegionDilation, 3.5)
六、区域合并

最后,我们将所有处理后的区域合并为一个整体区域,便于后续分析或输出。

复制代码
union1 (RegionDilation, RegionUnion)

本方案通过"灰度化 → 二值化 → 填充 → 连通域分析 → 形状筛选 → 形态学去噪 → 区域合并"这一完整流程,实现了对猴子眼睛区域的精准提取。该方法具有较强的可扩展性,适用于其他类似场景中的区域定位任务。

以下创建封装函数:

以下是在封装函数内求猴子眼睛的面积:

相关推荐
JMchen12317 小时前
现代Android图像处理管道:从CameraX到OpenGL的60fps实时滤镜架构
android·图像处理·架构·kotlin·android studio·opengl·camerax
jay神19 小时前
基于YOLOv8的木材表面缺陷检测系统
人工智能·深度学习·yolo·计算机视觉·毕业设计
HDO清风21 小时前
CASIA-HWDB2.x 数据集DGRL文件解析(python)
开发语言·人工智能·pytorch·python·目标检测·计算机视觉·restful
工程师老罗1 天前
什么是目标检测?
人工智能·目标检测·计算机视觉
沃达德软件1 天前
图像处理与复原技术
图像处理·人工智能·深度学习·神经网络·目标检测·计算机视觉·目标跟踪
Dfreedom.1 天前
图像滤波:非线性滤波与边缘保留技术
图像处理·人工智能·opencv·计算机视觉·非线性滤波·图像滤波
Dfreedom.1 天前
开运算与闭运算:图像形态学中的“清道夫”与“修复匠”
图像处理·python·opencv·开运算·闭运算
工程师老罗1 天前
目标检测数据标注的工具与使用方法
人工智能·目标检测·计算机视觉
AomanHao1 天前
【ISP】图像质量评价指标-通透度
图像处理·通透度·评价标准
wgfhill1 天前
【亲测可用】照片相似度检测删除一键清理重复图片!智能相似度检测工具,释放海量存储空间
图像处理