HALCON示例程序surface_scratch.hdev提取划痕

小哥哥小姐姐觉得有用点个赞呗!
在这里插入图片描述

HALCON示例程序surface_scratch.hdev提取划痕

示例程序源码(加注释)

  • 关于显示类函数解释
    dev_update_off ()
    dev_close_window ()
    read_image (Image, ‘surface_scratch’)
    get_image_size (Image, Width, Height)
    dev_open_window_fit_image (Image, 0, 0, Width, Width, WindowID)
    set_display_font (WindowID, 16, ‘mono’, ‘true’, ‘false’)
    dev_set_draw (‘margin’)
    dev_set_line_width (4)
    dev_display (Image)
    Message := ‘This program shows the extraction of’
    Message[1] := ‘surface scratches via local thresholding’
    Message[2] := ‘and morphological post-processing’
    disp_message (WindowID, Message, ‘window’, 12, 12, ‘black’, ‘true’)
    disp_continue_message (WindowID, ‘black’, ‘true’)
    stop ()
  • 使用动态阈值进行分割
    mean_image (Image, ImageMean, 7, 7)
    dyn_threshold (Image, ImageMean, DarkPixels, 5, ‘dark’)
  • 分割连通域
    connection (DarkPixels, ConnectedRegions)
    dev_set_colored (12)
    dev_display (Image)
    dev_display (ConnectedRegions)
    Message := ‘Connected components after image segmentation’
    Message[1] := ‘using a local threshold.’
    disp_message (WindowID, Message, ‘window’, 12, 12, ‘black’, ‘true’)
    disp_continue_message (WindowID, ‘black’, ‘true’)
    stop ()
  • 面积筛选
    select_shape (ConnectedRegions, SelectedRegions, ‘area’, ‘and’, 10, 1000)
    dev_display (Image)
    dev_display (SelectedRegions)
    disp_message (WindowID, ‘Large Regions’, ‘window’, 12, 12, ‘black’, ‘true’)
    disp_continue_message (WindowID, ‘black’, ‘true’)
    stop ()
    open_zoom_window (0, round(Width / 2), 2, 303, 137, 496, 3, WindowHandleZoom)
    dev_set_color (‘blue’)
    dev_display (Image)
    dev_display (SelectedRegions)
    set_display_font (WindowHandleZoom, 16, ‘mono’, ‘true’, ‘false’)
    disp_message (WindowHandleZoom, ‘Fractioned scratches’, ‘window’, 12, 12, ‘black’, ‘true’)
    disp_continue_message (WindowHandleZoom, ‘black’, ‘true’)
    stop ()
  • 合并区域
    union1 (SelectedRegions, RegionUnion)
  • 膨胀区域
    dilation_circle (RegionUnion, RegionDilation, 3.5)
    dev_display (Image)
    dev_display (RegionDilation)
    Message := ‘Region of the scratches after dilation’
    disp_message (WindowHandleZoom, Message, ‘window’, 12, 12, ‘black’, ‘true’)
    disp_continue_message (WindowHandleZoom, ‘black’, ‘true’)
    stop ()
  • 提取区域骨架
    skeleton (RegionDilation, Skeleton)
    connection (Skeleton, Errors)
    dev_set_colored (12)
    dev_display (Image)
    dev_display (Errors)
    Message := ‘Fractioned scratches merged via morphology’
    disp_message (WindowHandleZoom, Message, ‘window’, 12, 12, ‘black’, ‘true’)
    disp_continue_message (WindowHandleZoom, ‘black’, ‘true’)
    stop ()
    close_zoom_window (WindowHandleZoom, Width, Height)
    select_shape (Errors, Scratches, ‘area’, ‘and’, 50, 10000)
    select_shape (Errors, Dots, ‘area’, ‘and’, 1, 50)
    dev_display (Image)
    dev_set_color (‘red’)
    dev_display (Scratches)
    dev_set_color (‘blue’)
    dev_display (Dots)
    Message := ‘Extracted surface scratches’
    Message[1] := ‘Not categorized as scratches’
    disp_message (WindowID, Message, ‘window’, 440, 310, [‘red’,‘blue’], ‘true’)

处理思路

这个例子是主要讲解了金属划痕提取。

后记

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

  • 5
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值