博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
已知两条线段端点,判断是否相交及交点
阅读量:6507 次
发布时间:2019-06-24

本文共 1055 字,大约阅读时间需要 3 分钟。

Function TriAreaSize(ByVal ax As Double, ByVal ay As Double, ByVal bx As Double, ByVal by As Double, ByVal cx As Double, ByVal cy As Double) As Double

TriAreaSize = ((ax - cx) * (by - cy) - (ay - cy) * (bx - cx)) * 0.5

End Function

Function GetIfTwoLineIntr(ByVal ax As Double, ByVal ay As Double, ByVal bx As Double, ByVal by As Double, _

ByVal cx As Double, ByVal cy As Double, ByVal dx As Double, ByVal dy As Double, _
ByRef IntrX As Double, ByRef IntrY As Double) As Boolean

Dim area_abc, area_abd As Double

Dim area_cda, area_cdb As Double
Dim t, ddx, ddy As Double
GetIfTwoLineIntr = True
area_abc = Nis_Fun.TriAreaSize(ax, ay, bx, by, cx, cy)
area_abd = Nis_Fun.TriAreaSize(ax, ay, bx, by, dx, dy)
If area_abc * area_abd < 0 Then Exit Function
area_cda = Nis_Fun.TriAreaSize(cx, cy, dx, dy, ax, ay)
area_cdb = Nis_Fun.TriAreaSize(cx, cy, dx, dy, bx, by)
If area_cda * area_cdb < 0 Then Exit Function
GetIfTwoLineIntr = False
t = area_cda / (area_abd - area_abc)
ddx = t * (bx - ax)
ddy = t * (by - ay)
IntrX = ax + ddx
IntrY = ay + ddy

End Function

转载地址:http://vtwfo.baihongyu.com/

你可能感兴趣的文章
图片拼接器
查看>>
C++ TinyXml操作(含源码下载)
查看>>
读取swf里所有类定义
查看>>
DOWNLOAD 文件
查看>>
ogre场景图与场景内容分离
查看>>
中断小笔记
查看>>
C#委托、事件、消息(入门级)
查看>>
通信常用概念
查看>>
FreeBinary 格式说明
查看>>
使用Spring Cloud和Docker构建微服务
查看>>
常用链接
查看>>
NB-IoT的成功商用不是一蹴而就
查看>>
九州云实战人员为您揭秘成功部署OpenStack几大要点
查看>>
1.电子商务支付方式有哪些 2.比较不同支付方式的优势劣势
查看>>
医疗卫生系统被爆漏洞,7亿公民信息泄露……
查看>>
神秘函件引发的4G+与全网通的较量
查看>>
CloudCC:智能CRM究竟能否成为下一个行业风口?
查看>>
高德开放平台推出LBS游戏行业解决方案提供专业地图平台能力支持
查看>>
追求绿色数据中心
查看>>
Web开发初学指南
查看>>