天天看点

HALCON示例程序edge_segments.hdev提取连续的边缘段HALCON示例程序edge_segments.hdev提取连续的边缘段

HALCON示例程序edge_segments.hdev提取连续的边缘段

示例程序源码(加注释)

  • 关于显示类函数解释

    dev_update_off ()

    dev_close_window ()

    read_image (Image, ‘mreut’)

    get_image_size (Image, Width, Height)

    dev_open_window_fit_image (Image, 0, 0, Width, Height, WindowID)

    set_display_font (WindowID, 12, ‘mono’, ‘true’, ‘false’)

    dev_set_draw (‘margin’)

    dev_set_line_width (3)

    dev_display (Image)

    disp_continue_message (WindowID, ‘black’, ‘true’)

    stop ()

  • edges_image - 使用Deriche,Lanser,Shen或Canny过滤器提取边缘。
  • edges_image(图片:边缘幅度,边缘方向:滤波器,高斯标准差,最大抑制,滞后阈值低值,滞后阈值高值 ?

    edges_image (Image, ImaAmp, ImaDir, ‘lanser2’, 0.5, ‘nms’, 20, 40)

    dev_display (ImaAmp)

    disp_continue_message (WindowID, ‘black’, ‘true’)

    stop ()

  • 二值化提取边缘

    threshold (ImaAmp, Region, 1, 255)

  • 分割连通域

    connection (Region, ConnectedRegions)

    dev_clear_window ()

    dev_set_colored (12)

    dev_display (ConnectedRegions)

    disp_continue_message (WindowID, ‘black’, ‘true’)

    stop ()

    dev_clear_window ()

    count_obj (ConnectedRegions, Number)

  • 生成一个空的对象

    gen_empty_obj (XLDContours)

    for i := 1 to Number by 1

    • 选取指定图像

      select_obj (ConnectedRegions, SingleEdgeObject, i)

    • split_skeleton_lines - 根据线的曲率分割线段
    • split_skeleton_lines(边缘 :: 线的最大距离:起点行坐标,起点列坐标,终点行坐标,终点列坐标)

      split_skeleton_lines (SingleEdgeObject, 2, BeginRow, BeginCol, EndRow, EndCol)

      for k := 0 to |BeginRow| - 1 by 1

      • 这个是根据多个线段生成多边形

        gen_contour_polygon_xld (Contour, [BeginRow[k],EndRow[k]], [BeginCol[k],EndCol[k]])

        concat_obj (XLDContours, Contour, XLDContours)

    endfor

    endfor

    dev_display (XLDContours)

处理思路

这个例子是主要讲解了边缘的提取与分割。edges_image、split_skeleton_lines 、gen_contour_polygon_xld

后记

大家有什么问题可以向我提问哈,我看到了第一时间回复,希望在学习的路上多多结交良师益友。

继续阅读