halcon直线延长

已知一条直线,然后把这条直线延长:

gen_image_const (Image, 'byte', 512, 512)
draw_line (200000, Row1, Column1, Row2, Column2)
*直线方程y=k*x+b
get_image_size (Image, Width, Height)
*特殊情况水平线
if (Row2-Row1==0)
    k:=0
    gen_contour_polygon_xld (Contour,[Row2,Row2], [0,Width])
else
    k:=(Column2-Column1) /(Row2-Row1) 
    b:=(Column2-k*Row2)
    row1:=0
    row2:=Height-1
    col1:=k*row1+b
    col2:=k*row2+b
    gen_contour_polygon_xld (Contour,[row1,row2], [col1,col2])
endif

方法二:
已知点(row,col),线长度L,线角度(弧度)angle,求过该点的直线
起始点:row1:=row+L*sin(angle)   col1:=col-L*cos(angle)
终点:row2:=row-L*sin(angle)   col2:=col+L*cos(angle)

在这里插入图片描述原始直线
在这里插入图片描述效果图文章来源地址https://uudwc.com/A/Xkyoe

原文地址:https://blog.csdn.net/qq_43169363/article/details/125065930

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请联系站长进行投诉反馈,一经查实,立即删除!

上一篇 2023年09月15日 04:35
LeetCode-热题100-笔记-day25
下一篇 2023年09月15日 04:39