Halcon 仿射变换(旋转、平移、缩放、斜切、刚性、xld轮廓)
创作时间:
作者:
@小白创作中心
Halcon 仿射变换(旋转、平移、缩放、斜切、刚性、xld轮廓)
引用
CSDN
1.
https://m.blog.csdn.net/qq_51810680/article/details/136913104
Halcon是一种广泛应用于机器视觉和图像处理领域的软件,它提供了丰富的图像处理函数和工具。仿射变换是图像处理中常用的一种几何变换,可以实现图像的旋转、平移、缩放等操作。本文将详细介绍如何在Halcon中使用仿射变换对图像进行各种操作。
1. 旋转矩阵
read_image (Image, 'fabrik')
get_image_size (Image, Width, Height)
* 生成单位矩阵(一个不进行任何变换的仿射矩阵)
hom_mat2d_identity (HomMat2DIdentity)
* 如何获得图像中心点坐标
Row:=Height/2
Col:=Width/2
a:=rad(90)
* 已知弧度求角度
angle:=deg(a)
* 创建一个旋转仿射矩阵
* 参数一:输入的单位仿射矩阵
* 参数二:旋转角度(单位:弧度)
* 参数三、四:旋转中心的行和列坐标
* 参数五:输出的放射矩阵
hom_mat2d_rotate (HomMat2DIdentity, 0.78, Col, Row, HomMat2DRotate)
* 对图像进行仿射变换
* 参数一:输入图像(原始图像)
* 参数二:输出图像
* 参数三:放射矩阵
* 参数四:插值方法,'constant'表示超出边界的像素值将被设置为常数值。
* 参数五:是否进行归一化。设置为'false'表示不对输出图像进行归一化处理。
affine_trans_image (Image, ImageAffineTrans, HomMat2DRotate, 'constant', 'false')
旋转后的图像
2. 平移矩阵
read_image (Image, 'fabrik')
dev_display (Image)
hom_mat2d_identity (HomMat2DIdentity)
* 创建一个平移变换矩阵
* 参数二、三:指定了沿水平和垂直方向的平移的单位
hom_mat2d_translate (HomMat2DIdentity, 200, 200, HomMat2DTranslate)
affine_trans_image (Image, ImageAffineTrans, HomMat2DTranslate, 'constant', 'false')
3. 缩放矩阵
read_image (Image, 'fabrik')
dev_display (Image)
hom_mat2d_identity (HomMat2DIdentity)
* 创建一个缩放的仿射矩阵
* 参数二、三:水平和垂直方向缩放的倍数
* 参数四、五:缩放中心的列和行的坐标,在这里是图像左上角作为原点
* 参数六:输出仿射矩阵
hom_mat2d_scale (HomMat2DIdentity, 0.5, 0.5, 0, 0, HomMat2DScale)
affine_trans_image (Image, ImageAffineTrans, HomMat2DScale, 'constant', 'false')
4. 斜切矩阵
read_image (Image, 'fabrik')
dev_display (Image)
hom_mat2d_identity (HomMat2DIdentity)
* 创建一个倾斜的仿射矩阵
* 参数二:倾斜角度(单位:弧度)
* 参数三:倾斜方向
* 参数四、五:倾斜中心的列和行的坐标,在这里是图像的左上角作为原点
hom_mat2d_slant (HomMat2DIdentity, 0.78, 'x', 0, 0, HomMat2DSlant)
affine_trans_image (Image, ImageAffineTrans, HomMat2DSlant, 'constant', 'false')
5. 刚性矩阵
read_image (Image, 'fabrik')
threshold (Image, Region, 128, 255)
connection (Region, ConnectedRegions)
select_shape (ConnectedRegions, SelectedRegions, 'area', 'and', 8000, 8400)
fill_up_shape (SelectedRegions, RegionFillUp, 'area', 1, 100)
area_center (RegionFillUp, Area, Row, Column)
* 获取选择区域的角度
orientation_region (RegionFillUp, Phi)
* 生成刚性矩阵,刚性矩阵只支持平移和旋转
* 参数一、二、三:平移的XY距离和旋转的角度
* 参数四、五:输出图像的中心位置的行和列坐标
* 参数六:旋转之后的额外角度,通常用于对齐图像。在这里是0度。
* 参数七:输出的刚性变换矩阵,表示平移和旋转。
vector_angle_to_rigid (Row, Column, Phi, 100, 200, rad(0), HomMat2D)
* 对输入区域应用仿射变换。
* 参数一:输入区域
* 参数二:输出仿射变换后的区域
* 参数三:对输入区域进行的仿射变换
* 参数四:插值方法,这里使用最邻近插值
affine_trans_region (RegionFillUp, RegionAffineTrans, HomMat2D, 'nearest_neighbor')
输出结果
6. 对XLD轮廓进行仿射变换
原图
* xld轮廓进行仿射变换
read_image (Image, 'printer_chip/printer_chip_01')
threshold (Image, Region, 128, 255)
connection (Region, ConnectedRegions)
select_shape (ConnectedRegions, SelectedRegions, 'area', 'and', 25000, 99999)
* 在图标元组中选择某一个图标
select_obj (SelectedRegions, ObjectSelected, 2)
* 获取对应区域的xld(交互式形状模型)轮廓
* 参数三:'border' 表示生成的XLD轮廓将沿着区域的边界生成。
gen_contour_region_xld (ObjectSelected, Contours, 'border')
* 求xld的面积和中心坐标点
area_center_xld (Contours, Area, Row, Column, PointOrder)
* 求xld轮廓的角度
orientation_xld (Contours, Phi)
* 根据输入的信息计算向量的旋转结果,并生成相应的二维齐次变换矩阵
* 参数一、二、三:输入的旋转中心的坐标和当前向量的角度
* 参数四、五:输出的旋转后的向量的终点XY坐标
* 参数六:旋转角度
* 参数七:输出的二维齐次变换矩阵
vector_angle_to_rigid (Row, Column, Phi, Row, Column, rad(90), HomMat2D)
* 对xld轮廓进行仿射变化
affine_trans_contour_xld (Contours, ContoursAffineTrans, HomMat2D)
输出结果:
热门推荐
高考报同一学校能填多个专业组吗?同一学校不同专业组怎样录取?
宠物绝育手术,费用、过程与全方位指南
第三代半导体氮化镓:从原理特性到通信、光电器件应用解析
一吨苜蓿鲜草能出多少干草
如何评估高股息股票的投资价值
装修合同纠纷应该怎么处理
服用氨氯地平时,错误的服药时间,可能会影响降压效果
向外星人发信息,怎样才能假装自己的文明已经很高级的样子?
感光度是做什么的?一篇把感光度说明白
贴门神:中国传统文化中的守护神
A股重回2万亿元成交额,券商最新研判释放哪些信号?
如何判断股票溢价的合理性?这种判断对投资决策有何影响?
Outlook无法接入IMAP服务器怎么办?一文详解解决方案
从"健康体能"到"战斗体能":火箭军某旅战斗体能训练见闻
类风湿性关节炎可以吃天麻吗
环境咨询与环境工程设计
事关退休待遇,请抓紧时间认证!
高烧39度怎么办?退烧三部曲轻松应对
当兵体检如何评估抑郁症的严重程度
10种粉面万能汤底配方,简单快速就能吃上热乎乎的面
净资产和所有者权益是一样的吗?特殊情况下的差异解析
Excel预览是居中怎么打印不来不是
医生提醒:这四类人睡前不宜饮茶
明朝藩王:地位尊崇与权力边界
如何隐藏应用图标?电脑和手机隐藏应用的多种方法
咖啡能消肿?什么时候饮用效果最佳
宇宙微波背景:一场由鸽子粪引发的物理学革命
朱元璋与朱温:家族认同与政治考量的双重解析
健康有约丨冬季“呕吐病”的元凶,如何科学应对诺如病毒?
技术团队集体离职预警?三招破解人才保留困局背后的管理密码