找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 356|回复: 0

[每日一码] 由三角的三个点返回三角形的角度计算参数

[复制链接]

已领礼包: 267个

财富等级: 日进斗金

发表于 2020-2-24 08:59:53 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

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

×
;;由三角的三个点返回三角形的角度计算参数
(defun c:te()
        (setq fanhui '())
        ;三角
        (setq p_a (getpoint "\np1"))
        (setq p_b (getpoint "\np2"))
        (setq p_c (getpoint "\np3"))
        ;;三边
        (setq l_a (distance p_b p_c))
        (setq l_b (distance p_a p_c))
        (setq l_c (distance p_a p_b))
        ;计算P
        (setq js_p (* (+ l_a l_b l_c) 0.5))
        ;;三角面积
        (setq s_1 (sqrt (* js_p (- js_p l_a) (- js_p l_b) (- js_p l_c))))
        ;;sina\sinb\sinc
        (setq sin_a (/ s_1 (* l_b l_c 0.5)))
        (setq sin_b (/ s_1 (* l_a l_c 0.5)))
        (setq sin_c (/ s_1 (* l_a l_b 0.5)))
        ;;初算cosa\cosb\cosc
        (setq cos_a (sqrt (- 1 (* sin_a sin_a))))
        (setq cos_b (sqrt (- 1 (* sin_b sin_b))))
        (setq cos_c (sqrt (- 1 (* sin_c sin_c))))
        (setq j_a (/ (* 180.0 (atan (/ sin_a cos_a))) PI))
        (setq j_b (/ (* 180.0 (atan (/ sin_b cos_b))) PI))
        (setq j_c (/ (* 180.0 (atan (/ sin_c cos_c))) PI))
        ;;圆周率角度相等测试
        (if (not (equal (+ j_a j_b j_c) 180.0 0.000000001))
                (progn
                        (setq max_l (max l_a l_b l_c))
                        ;;l_a边大
                        (if (= max_l l_a)
                                (progn
                                        (setq cos_a (- 0.0 (sqrt (- 1 (* sin_a sin_a)))))
                                        (setq j_a  (/ (* 180.0 (atan (/ sin_a cos_a))) PI))
                                        (if (< j_a 0.0)
                                                (setq j_a (+ 180.0 j_a))
                                        )
                                )
                        )
                        ;;l_b边大               
                        (if (= max_l l_b)
                                (progn
                                        (setq cos_b (- 0.0 (sqrt (- 1 (* sin_b sin_b)))))
                                        (setq j_b  (/ (* 180.0 (atan (/ sin_b cos_b))) PI))
                                        (if (< j_b 0.0)
                                                (setq j_b (+ 180.0 j_b))
                                        )                                       
                                )
                        )
                        ;;l_c边大                       
                        (if (= max_l l_c)
                                (progn
                                        (setq cos_c (- 0.0 (sqrt (- 1 (* sin_c sin_c)))))
                                        (setq j_c  (/ (* 180.0 (atan (/ sin_c cos_c))) PI ))
                                        (if (< j_c 0.0)
                                                (setq j_c (+ 180.0 j_c))
                                        )                                       
                                )
                        )                       
                )
        )
        ;;a边对应的中线长
        (setq m_a_l (* 0.5 (sqrt (- (* 2.0 (+ (* l_b l_b) (* l_c l_c))) (* l_a l_a)))))
        ;;a边的中点
        (setq m_a_p (list
                                        (+ (/ (- (car p_b) (car p_c)) 2.0) (car p_c))                               
                                        (+ (/ (- (cadr p_b) (cadr p_c)) 2.0) (cadr p_c))
                                        (+ (/ (- (caddr p_b) (caddr p_c)) 2.0) (caddr p_c))                                       
                                )
        )                       
        (command "line" p_a p_b "")
        (command "line" p_b p_c "")       
        (command "line" p_a p_c "")       
        (command "line" p_a m_a_p "")
        (print j_a)
        (print j_b)       
        (print j_c)               
        (setq fanhui
                (list
                        ;;返回三点
                        (list "dian_a" p_a)
                        (list "dian_b" p_b)       
                        (list "dian_c" p_c)       
                        ;;返回三边
                        (list "bian_a" l_a)
                        (list "bian_b" l_b)
                        (list "bian_c" l_c)
                        ;;返回三个角的角度
                        (list "jiao_a" j_a)
                        (list "jiao_b" j_b)
                        (list "jiao_c" j_c)       
                        ;;返回三角形面积
                        (list "mianji" s_1)       
                )
        )
)
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|申请友链|Archiver|手机版|小黑屋|辽公网安备|晓东CAD家园 ( 辽ICP备15016793号 )

GMT+8, 2024-4-28 01:55 , Processed in 0.297877 second(s), 27 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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