Halcon打开图片:单个图片以及遍历读取文件夹里的所有图片

简介: Halcon打开图片:单个图片以及遍历读取文件夹里的所有图片

Halcon打开单个图片


1、dev_open_file_dialog 打开对话框


2、*获取图像的宽

get_image_size (Image, Width, Height)
3、*创建显示窗口,并设置窗口及绘制参数
dev_open_window_fit_size (0, 0, Width, Height, -1, -1, WindowHandle)
*等价于dev_open_window_fit_image (Image, 0, 0, -1, -1, WindowHandle)


4、*灰度取反

invert_image (Image, ImageInvert)
dev_close_window()
dev_update_off ()
dev_open_file_dialog ('read_image', 'default', 'default', Selection)
read_image (Image, Selection)
get_image_size (Image, Width, Height)
dev_open_window_fit_image (Image, 0, 0, -1, -1, WindowHandle)
dev_display (Image)
*彩色转灰度图
count_channels (Image, Channels)
if (Channels == 3)    
    *将图像进行通道分解,分别转换为三个通道的RGB图像
    decompose3 (Image, Red, Green, Blue)   
    rgb1_to_gray (Image, Image1)
    *真彩色转灰度图
elseif (Channels == 4)
    decompose4 (Image, Red, Green, Blue, Alpha)
    compose3 (Red, Green, Blue, MultiChannelImage)
    rgb1_to_gray (MultiChannelImage, Image1)
else
    Image1 := Image
endif
*取RGB的最小值通道
min_image (Red, Green, ImageMin)
min_image (ImageMin, Blue, ImageMin)
*使用颜色转换将RGB三个通道图像转化为HSV通道的图像
trans_from_rgb (Red, Green, Blue, Hue1, Saturation1, Intensity1, 'hsi')
trans_from_rgb (Red, Green, Blue, Hue2, Saturation2, Value2, 'hsv')
*灰度取反
invert_image (Image1, ImageInvert)
*二值化
*最大类间方差法(otsu)
binary_threshold (Image1, BrightRegion, 'max_separability', 'dark', UsedThreshold)
region_to_bin (BrightRegion, BinImage, 0, 255, Width, Height)



Halcon遍历读取图片


1、通用方法


使用list_files和tuple_regexp_select算子

dev_close_window ()
list_files ('D:/hellowprld/pic', ['files','follow_links','recursive'], ImageFiles)
tuple_regexp_select (ImageFiles, ['\\.(tif|tiff|gif|bmp|jpg|jpeg|jp2|png|pcx|pgm|ppm|pbm|xwd|ima|hobj)$','ignore_case'], ImageFiles)
for Index := 0 to |ImageFiles| - 1 by 1
    read_image (Image, ImageFiles[Index])
    dev_close_window ()
    get_image_size (Image, Width, Height)
    *dev_open_window (0, 0, Width, Height, 'black', WindowHandle)
    dev_open_window_fit_image (Image, 0, 0, -1, -1, WindowHandle)
    dev_display (Image)
    gen_rectangle1 (Rectangle, 482.313, 458.083, 847.963, 1001.78)
    reduce_domain (Image, Rectangle, ImageReduced)
    crop_domain (ImageReduced, ImagePart)
    mean_image (ImagePart, ImageMean, 20, 20)
    auto_threshold (ImageMean, Regions, 2)
    connection (Regions, ConnectedRegions)
    select_shape_std (ConnectedRegions, SelectedRegions, 'max_area', 70)
    area_center (SelectedRegions, Area, Row, Column)
    dev_clear_window ()
    dev_display (ImagePart)
    dev_display (Image)
    if (Area < 100000)
        disp_message (WindowHandle, 'good', 'window', Row, Column, 'black', 'true')
    else
        disp_message (WindowHandle, 'bad', 'window', Row, Column, 'black', 'true')    
    endif
    stop ()
endfor



2、简易方法


直接for循环

dev_close_window()
dev_open_window(0, 0, 512, 512, 'black', WindowHandle)
for i:=1 to 7 by 1
    read_image (Image, 'image/蚕丝检测' + i + '.bmp')
endfor
* Main loop: process different images
for Index1 := 1 to 7 by 1
    read_image (Image, 'image/saw_blade/saw_'+Index1$'02')
endfor



画十字线


read_image (Image1, 'D:/match/AOI/基于halcon的AOI自动光学检测1.bmp')
get_image_size (Image1, Width, Height)
dev_open_window_fit_image (Image1, 0, 0, -1, -1, WindowHandle)
dev_display (Image1)
*画十字线
set_display_font (WindowHandle, 25, 'mono', 'true', 'false')
dev_set_line_width(2)
dev_set_color('green')
gen_rectangle1 (Rectangle0, Height/2, 0, Height/2, Width) //横线
dev_display(Rectangle0)
gen_rectangle1 (Rectangle1, 0, Width/2, Height, Width/2) //竖线
dev_display(Rectangle1)


 


相关文章
|
7月前
|
数据采集 分布式计算 搜索推荐
使用Python实现网页中图片的批量下载和水印添加保存
使用Python实现网页中图片的批量下载和水印添加保存
|
4天前
|
文字识别 数据挖掘 网络安全
Python实现avif图片转jpg格式并识别图片中的文字
在做数据分析的时候有些数据是从图片上去获取的,这就需要去识别图片上的文字。Python有很多库可以很方便的实现OCR识别图片中的文字。这里介绍用EasyOCR库进行图片文字识别。easyocr是一个比较流行的库,支持超过80种语言,识别率高,速度也比较快。
38 2
|
4天前
|
数据可视化
Halcon 学习笔记一:基本操作以及读取与保存图片
Halcon 学习笔记一:基本操作以及读取与保存图片
403 0
|
4天前
|
计算机视觉
OpenCV中读取、显示、保存图像及获取图像属性操作讲解及演示(附源码)
OpenCV中读取、显示、保存图像及获取图像属性操作讲解及演示(附源码)
147 0
|
8月前
|
存储 JavaScript 前端开发
Java实现图片的上传和显示
Java实现图片的上传和显示
297 0
|
10月前
|
编解码 iOS开发
图片,视频上传&视频内容旋转
图片,视频上传&视频内容旋转
|
机器学习/深度学习 计算机视觉
【图片操作】提取GIF的图片帧
gif是我们日常生活中常用的一种图片,它介于视频和图片之间。我们可以用图片的内存体验到一些视频的感觉。但是有时候我们会想把gif的图片全部提取出来,今天我们就来实现一下这个操作。
339 0
|
存储 C语言 计算机视觉
加载美女图片之OpenCV 图像读取与显示
加载美女图片之OpenCV 图像读取与显示
|
计算机视觉 Python
OpenCV学习笔记(一)【图片读入、显示、保存】
OpenCV学习笔记(一)【图片读入、显示、保存】
OpenCV学习笔记(一)【图片读入、显示、保存】
【图片操作】给图片添加滤镜
现在我们都喜欢给图片添加滤镜,现在很多相机也自带了许多滤镜。我们可以在拍照的时候选择需要的滤镜。但是有时候我们需要给大量图片添加同样的滤镜,这个时候手动添加就非常麻烦了。为了方便,我们可以使用程序来帮我们完成添加滤镜的操作。
195 0