明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 1462|回复: 0

已知两点(一条直线),做直角三角形.

[复制链接]
发表于 2009-9-10 15:02:00 | 显示全部楼层 |阅读模式
  1. Sub ll()
  2.   Dim p0(2) As Double, p1(2) As Double, Pp(2) As Double
  3.   Dim R, rLen
  4.   p0(0) = -20
  5.   p0(1) = 50
  6.   p1(0) = 0
  7.   p1(1) = 0
  8.   R = 10
  9.   rLen = Sqr((p0(0) - p1(0)) ^ 2 + (p0(1) - p1(1)) ^ 2)
  10.   Dim objLine As AcadLine
  11.   Set objLine = ThisDrawing.ModelSpace.AddLine(p1, p0)
  12.   ThisDrawing.Regen acActiveViewport
  13.   Dim Alfa1, Alfa2
  14.   With objLine
  15.     Alfa1 = .Angle
  16.     Alfa2 = ACos(R / .Length)
  17.     Debug.Print Alfa1 * 180 / 3.1415926, Alfa2 * 180 / 3.1415926
  18.     Pp(0) = R * Cos(Alfa1 + Alfa2)
  19.     Pp(1) = R * Sin(Alfa1 + Alfa2)
  20.   End With
  21.   With ThisDrawing.ModelSpace
  22.     Set objLine = .AddLine(Pp, p0)
  23.     objLine.color = acGreen
  24.     Set objLine = .AddLine(Pp, p1)
  25.     objLine.color = acRed
  26.   End With
  27.   
  28. End Sub
  29. Function ACos(x) As Double
  30.    ACos = Atn(Sqr(1 - x * x) / x) '+ 4 * Atn(1)
  31. End Function

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?注册

x
您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|CAD论坛|CAD教程|CAD下载|联系我们|关于明经|明经通道 ( 粤ICP备05003914号 )  
©2000-2023 明经通道 版权所有 本站代码,在未取得本站及作者授权的情况下,不得用于商业用途

GMT+8, 2024-11-26 00:47 , Processed in 0.172330 second(s), 24 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表