VB中的atn函数

本文介绍了如何利用VB语言中的Atn函数计算两点连线与水平面之间的夹角,通过实现一个自定义函数来解决实际问题,并对比了不同编程语言在数学问题上的应用效率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Atn函数返回一个double类型,指定一个数的反正切值。

用法就是:Atn(number)。number参数是一个double或者任何有效的数值表达式。

Atn函数的参数值(number)为直角三角形的两条直角边的比值(对边比邻边)。返回以弧度为单位的角。值的范围是-π/2和π/2之间。

Atn是Tan函数的反三角函数,Tan的参数值为角度,返回直角三角形的两边的比值。

下面介绍个例子:

我要判断两个点的位置并求出两个点组成的线段与水平面之间的夹角,用了一个Function函数,它的声明如下:

Public Function getAngel(ByVal x1 As Long, _ ByVal y1 As Long, _ ByVal x2 As Long, _ ByVal y2 As Long) As Long Const PI As Double = 3.1415926 Dim judge As Boolean 'VB中默认boolean值为False,这里如果是默认(即judge=False),结果永远等于0 judge = True Dim Ang As Long Select Case judge Case x1 < x2 And y1 < y2 Ang = Atn((y2 - y1) / (x2 - x1)) * 180 / PI Case x1 < x2 And y1 = y2 Ang = 0 Case x1 < x2 And y2 > y2 Ang = Atn((y2 - y1) / (x2 - x1)) * 180 / PI + 360 Case x1 = x2 And y1 < y2 Ang = 90 Case x1 = x2 And y1 = y2 MsgBox "两个点重复,请从新输入! " Case x1 = x2 And y1 > y2 Ang = 270 Case x1 > x2 And y1 < y2 Ang = Atn((y2 - y1) / (x2 - x1)) * 180 / PI + 180 Case x1 > x2 And y1 = y2 Ang = 180 Case x1 > x2 And y1 > y2 Ang = Atn((y2 - y1) / (x2 - x1)) * 180 / PI + 180 End Select getAngel = Ang 'angel = getAngel(x1, y1, x2, y2) End Function


下面是调用这个函数的代码:

Private Sub Form_click() Text1(4).Text = Format(getAngel(CDbl(Text1(0).Text), CDbl(Text1(1).Text), CDbl(Text1(2).Text), CDbl(Text1(3).Text)), "0.000 ") End Sub


调用过程代码过于简单,调用的时候只有按照代码的格式调用才能够正常运行。有兴趣的同学自己再改吧。

原先,我总感觉数学问题用Matlab解决很合适,了解原理之后编写也非常简单;但是用VB就很复杂,并且算出来也不精确。

但是我偶然间发现VB中也提供了比较全面的数学函数,很有意思。

看来以后数学方面的编程,我也能用VB编程了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值