【issue-halcon例程学习】edges_color.hdev

例程功能

演示如何使用edges_color,展示只能从彩色图像中提取某些边缘的图像,说明edges_coloredges_image输出之间的差异。

代码如下

cpp 复制代码
dev_update_off ()
read_image (Image, 'olympic_stadium')
get_image_size (Image, Width, Height)
dev_close_window ()
dev_open_window (0, 0, Width, Height, 'black', WindowHandle)
dev_set_part (0, 0, Height - 1, Width - 1)
set_display_font (WindowHandle, 16, 'mono', 'true', 'false')
dev_display (Image)
Message := 'Color image'
disp_message (WindowHandle, Message, 'window', 12, 12, 'black', 'true')
stop ()
* Convert the color image to a gray value image.  Note that there is no contrast
* between the soccer field and the track in the gray value image.
rgb1_to_gray (Image, GrayImage)
dev_display (GrayImage)
Message := 'Gray value image'
disp_message (WindowHandle, Message, 'window', 12, 12, 'black', 'true')
stop ()
* Compute the color edges without non-maximum suppression and hysteresis
* thresholding, i.e., the raw edge amplitude image.  Note that there is a clearly
* visible edge between the soccer field and the track in the color edge image.
edges_color (Image, ImaAmp, ImaDir, 'canny', 1, 'none', -1, -1)
dev_display (ImaAmp)
Message := 'Color edge image'
disp_message (WindowHandle, Message, 'window', 12, 12, 'black', 'true')
stop ()
* Compute the gray value edges without non-maximum suppression and
* hysteresis thresholding, i.e., the raw edge amplitude image.  Note that there is
* no visible edge between the soccer field and the track in the gray value edge
* image.
edges_image (GrayImage, ImaAmpGray, ImaDirGray, 'canny', 1, 'none', -1, -1)
dev_display (ImaAmpGray)
Message := 'Gray value edge image'
disp_message (WindowHandle, Message, 'window', 12, 12, 'black', 'true')
stop ()
* Now perform the color edge extraction including non-maximum suppression
* and hysteresis thresholding.  Note the segmented edge between the soccer
* field and the track.
edges_color (Image, ImaAmpHyst, ImaDirHyst, 'canny', 1, 'nms', 20, 40)
threshold (ImaAmpHyst, RegionColor, 1, 255)
skeleton (RegionColor, EdgesColor)
dev_display (Image)
dev_set_color ('blue')
dev_display (EdgesColor)
Message := 'Segmented color edges'
disp_message (WindowHandle, Message, 'window', 12, 12, 'black', 'true')
stop ()
* Now perform the gray value edge extraction including non-maximum
* suppression and hysteresis thresholding.  Note the absence of an edge
* between the soccer field and the track.
edges_image (GrayImage, ImaAmpGrayHyst, ImaDirGrayHyst, 'canny', 1, 'nms', 20, 40)
threshold (ImaAmpGrayHyst, RegionGray, 1, 255)
skeleton (RegionGray, EdgesGray)
dev_display (GrayImage)
dev_set_color ('blue')
dev_display (EdgesGray)
Message := 'Segmented gray value edges'
disp_message (WindowHandle, Message, 'window', 12, 12, 'black', 'true')
stop ()
* Now display everything again, while only showing the part of the image
* containing the soccer field and the track.
Row1 := 220
Col1 := 215
Row2 := 399
Col2 := 489
dev_set_part (Row1, Col1, Row2, Col2)
dev_display (Image)
stop ()
dev_display (GrayImage)
stop ()
dev_display (ImaAmp)
stop ()
dev_display (ImaAmpGray)
stop ()
dev_display (Image)
dev_set_color ('blue')
dev_display (EdgesColor)
stop ()
dev_display (GrayImage)
dev_set_color ('blue')
dev_display (EdgesGray)

要点

  1. 例程中着重说明图像中足球场和跑道两个区域间几乎没有对比度 。以此为难点分别用edges_coloredges_image分割图像边缘。
    没有对比度意味着灰度化后足球场和跑道区域间边缘特征不明显(看起来像一块区域),后接edges_image 确实没有检测出足球场边框。
    edges_color直接对彩色图像进行边缘提取,效果会好于edges_image方法。两个算子的参数相同,不同点在于入参图像分别为彩色图像和灰度图像。
    edges_color------使用 Deriche、Lanser、Shen 或 Canny 过滤器提取边缘;
    Image ------入参,待处理图像;
    ImaAmp ------出参,边缘幅度(梯度)分割结果;
    ImaDir ------出参,边缘方向分割结果;
    Filter ------入参,过滤器;
    Alpha ------入参,滤镜参数(值越小,平滑效果越强,细节越少,canny算子相反);
    NMS ------入参,极大值抑制;
    Low ------入参,滞后阈值分割的低阈值(不需要则置negative);
    High ------入参,滞后阈值分割的高阈值(不需要则置negative);
相关推荐
岂是尔等觊觎19 分钟前
PCB设计教程【入门篇】——电路分析基础-电路定理
经验分享·笔记·嵌入式硬件·学习·pcb工艺
linly121933 分钟前
MRI学习笔记-表征相似性分析(Representational Similarity Analysis, RSA)
笔记·学习
慕卿扬35 分钟前
基于python的机器学习(七)—— 数据特征选择
笔记·python·学习·机器学习·scikit-learn
每次的天空44 分钟前
Android-RecyclerView学习总结
android·学习
叒卮1 小时前
小白刷题 之 如何高效计算二进制数组中最大连续 1 的个数
c语言·数据结构·学习·算法
虾球xz1 小时前
游戏引擎学习第305天:在平台层中使用内存 Arena 的方法与思路
c++·学习·游戏引擎
wktomo10 小时前
GO语言学习(七)
开发语言·学习·golang
贺函不是涵10 小时前
【沉浸式求职学习day46】【华为5.7暑期机试题目讲解】
学习·算法·华为
BIYing_Aurora10 小时前
【IPMV】图像处理与机器视觉:Lec10 Edges and Lines
图像处理·人工智能·经验分享·线性代数·计算机视觉·视觉检测
红衣小蛇妖11 小时前
Python基础学习-Day30
开发语言·python·学习