图像区域计算(Halcon)

 


一、图像区域方向计算

代码如下:

read_image (Test, 'D:/Pycharm/test.jpg')
dev_close_window()
get_image_size(Test,Width,Height)
dev_open_window(0,0,Height,Width,'white',WindowID)
*输入线段开始点与结束点坐标
RowA1 := 300
ColumnA1 := 10
RowA2 := 300
ColumnA2 := 501
dev_set_color('yellow')
disp_line(WindowID,RowA1,ColumnA1,RowA2,ColumnA2)
RowB1 := 300
ColumnB1 := 300
for i := 1 to 360 by 1
    RowB2 := 300 + sin(rad(i)) * 200
    ColumnB2 := 300 + cos(rad(i)) * 200
    disp_line(WindowID,RowB1,ColumnB1,RowB2,ColumnB2)
    *生成直线
    gen_region_line(RegionLines1,RowB1,ColumnB1,RowB2,ColumnB2)
    *计算区域的方向
    orientation_region(RegionLines1,Phi1)
    *计算直线的方向
    line_orientation(RowB1,ColumnB1,RowB2,ColumnB2,Phi2)
    *计算线段
    line_position(RowB1,ColumnB1,RowB2,ColumnB2,RowCenter,ColCenter,Length1,Phi3)
    *计算两直线夹角
    angle_ll(RowA1,ColumnA1,RowB2,ColumnB2,RowB1,ColumnB1,RowB2,ColumnB2,Angle)
endfor
stop()
threshold(Test,Dark,0,70)
connection(Dark,Single)
dev_clear_window()
select_shape(Single,Selected,'area','and',5000,10000)
orientation_region(Selected,Phi)
area_center(Selected,Area,Row,Column)
dev_set_color('red')
dev_set_draw('margin')
dev_set_line_width(7)
Length := 8
disp_arrow(WindowID,Row,Column,Row + cos(Phi + 1.5708) * Length,Column + sin(Phi +1.5708 )* Length,3)


图1. 区域方向计算结果图
图2. 区域分割结果图

 


总结

以上就是今天要讲的内容,本文介绍了区域方向的计算,下一节介绍XLD轮廓。


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值