• Halcon学习:图像灰度变化


     灰度线性变换:图像相加 

     1 *关闭过程更新,不更新变量窗口,让程序更快
     2 dev_update_off ()
     3 *读取图片
     4 dev_open_file_dialog ('read_image', 'default', 'default', Selection)
     5 read_image (Image, Selection)
     6 
     7 *图像转为灰度图
     8 rgb1_to_gray (Image, GrayImage)
     9 
    10 *图像相加,c(a+b)+d  0.8x(GrayImage+GrayImage)+100  
    11 add_image (GrayImage, GrayImage, ImageResult, 0.8, 100)
    12 
    13 *获得图像区域以及坐标
    14 get_domain (GrayImage, Domain)
    15 get_region_points (Domain, Rows, Columns)
    16 
    17 *获得图像每个坐标的灰度
    18 get_grayval (GrayImage, Rows, Columns, Grayval)
    19 
    20 *循环改变灰度值,灰度值高于30的,赋值为255,即白色
    21 for i := 0 to |Grayval|-1 by 1
    22     if (Grayval[i]>30)
    23         Grayval[i]:=255
    24     endif
    25 endfor
    26 
    27 *灰度赋值
    28 set_grayval (ImageResult, Rows, Columns, Grayval)

    效果图:

     

    灰度非线性变换:常用有对数函数、指数函数

    对数函数一般是提高低范围的像素,压缩高范围的像素

    指数函数一般是提高高范围的像素,压缩低范围像素

    1 *图像取对数
    2 log_image (GrayImage, LogImage, 'e')
    3 * set_grayval (LogImage, Rows, Columns, Grayval)
    4 *图像取指数
    5 exp_image (LogImage, ExpImage, 'e')

    效果图:红框内边缘对比度提高了

      

    灰度直方图变换:对图像中的像素灰度做映射变换,但是这种映射是基于灰度直方图的

    1 *图像均衡化
    2 equ_histo_image (GrayImage, ImageEquHisto)

    效果图:使得图像分辨更清晰

     

  • 相关阅读:
    delphi10.3.1不支持.net 5
    FIREDAC返回多结果集
    咏南中间件多种部署方式
    ISAPI多进程设置
    咏南ISAPI中间件
    datasnap isapi程序iis设置
    mormot支持TCP/IP
    咏南中间件支持JWT TOKEN
    基于Token的身份认证 与 基于服务器的身份认证
    delphi开源JWT
  • 原文地址:https://www.cnblogs.com/zxl971213/p/13667455.html
Copyright © 2020-2023  润新知