[Halcon&几何] 直线的垂线与延长线的计算

简介: [Halcon&几何] 直线的垂线与延长线的计算

一、直线垂直线的计算

1、函数源码

dev_close_window ()
dev_open_window (0, 0, 400, 400, 'black', WindowHandle)
draw_line (WindowHandle, Row1, Col1, Row2, Col2)
*获取直线角度
gen_region_line (RegionLines2, Row1, Col1, Row2, Col2)
gen_contour_region_xld (RegionLines2, Contours, 'border')
elliptic_axis_points_xld (Contours, Ra3, Rb3, Phi)
*获取直线中点
area_center_points_xld (Contours, Area4, RowCenter, ColCenter)
*垂线长度
LineLength:=200
*起点
RowStart := RowCenter-cos(Phi)*LineLength
ColStart := ColCenter-sin(Phi)*LineLength
*终点
RowEnd := RowCenter+cos(Phi)*LineLength
ColEnd := ColCenter+sin(Phi)*LineLength
gen_region_line (Line1, RowStart, ColStart, RowEnd, ColEnd)

2、计算效果

 

二、直线延长线的计算

1、函数源码

dev_close_window ()
dev_open_window (0, 0, 700, 700, 'black', WindowHandle)
draw_line (WindowHandle, Row1, Col1, Row2, Col2)
*获取直线角度
gen_region_line (RegionLines2, Row1, Col1, Row2, Col2)
gen_contour_region_xld (RegionLines2, Contours, 'border')
elliptic_axis_points_xld (Contours, Ra3, Rb3, Phi)
*获取直线中点
area_center_points_xld (Contours, Area4, RowCenter, ColCenter)
***********************生成延长线*************************
*延长线长度
LineLength:=1100
*起点
RowStart := RowCenter-cos(Phi+1.5708)*LineLength
ColStart := ColCenter-sin(Phi+1.5708)*LineLength 
*终点
RowEnd := RowCenter-cos(Phi-1.5708)*LineLength
ColEnd := ColCenter-sin(Phi-1.5708)*LineLength
gen_region_line (Line2, RowStart, ColStart, RowEnd, ColEnd)
dev_display (Line2)

2、计算效果

注: elliptic_axis_points_xld获取直线的角度较line_orientation和line_position求直线角度而言,计算出的延长线精度会更高,可以自行验证,其他角度计算方法可以参考我的博文:[Halcon] 直线中点、端点和角度的计算

 


戳戳小手帮忙点个免费的赞和关注吧,嘿嘿。
目录
相关文章
|
9月前
|
算法 计算机视觉
图像处理之距离变换
图像处理之距离变换
185 8
二维坐标系空间变换(详细解读,附MATLAB代码)
二维坐标系空间变换(详细解读,附MATLAB代码)
1107 0
二维坐标系空间变换(详细解读,附MATLAB代码)
|
7月前
|
算法框架/工具 C++ Python
根据相机旋转矩阵求解三个轴的旋转角/欧拉角/姿态角 或 旋转矩阵与欧拉角(Euler Angles)之间的相互转换,以及python和C++代码实现
根据相机旋转矩阵求解三个轴的旋转角/欧拉角/姿态角 或 旋转矩阵与欧拉角(Euler Angles)之间的相互转换,以及python和C++代码实现
523 0
|
9月前
|
计算机视觉
OpencV图像几何形状绘制
OpencV图像几何形状绘制
|
9月前
|
算法 计算机视觉
图像处理之倒角距离变换
图像处理之倒角距离变换
135 1
|
10月前
|
算法 图形学
【计算机图形学】实验四 二维图形的缩放、旋转,平移,组合变换
【计算机图形学】实验四 二维图形的缩放、旋转,平移,组合变换
395 2
|
10月前
|
算法
halcon系列之直线拟合和圆形拟合算子
halcon系列之直线拟合和圆形拟合算子
950 0
|
10月前
|
计算机视觉
OpenCV(三十四):轮廓外接最大、最小矩形和多边形拟合
OpenCV(三十四):轮廓外接最大、最小矩形和多边形拟合
700 0
|
10月前
|
文字识别 Python
Halcon 学习笔记五:几何定位+仿射变换+测量
Halcon 学习笔记五:几何定位+仿射变换+测量
892 0
|
10月前
|
算法
[Halcon&几何] 矩形顶点和对角连线角度计算
[Halcon&几何] 矩形顶点和对角连线角度计算
181 0