明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 1349|回复: 5

[讨论] 两线不平行时,画角平分线

[复制链接]
发表于 2013-11-18 10:08 | 显示全部楼层 |阅读模式
本帖最后由 自贡黄明儒 于 2013-11-18 14:13 编辑

  1. ;两线不平行时,画角平分线
  2. (defun HH:Bisect (en1 en2 / E1EN E1ST E2EN E2ST P0 P1E P1S P2E P2S PT1 PT2 PT3 X Y)
  3.   (setq e1st (vlax-curve-getStartPoint en1))
  4.   (setq e1en (vlax-curve-getendPoint en1))
  5.   (setq e2st (vlax-curve-getStartPoint en2))
  6.   (setq e2en (vlax-curve-getendPoint en2))
  7.   (setq p0 (inters e1st e1en e2st e2en nil))
  8.   (if (> (distance p0 e1st) (distance p0 e1en))
  9.     (setq p1s e1st p1e e1en)
  10.     (setq p1s e1en p1e e1st)
  11.   )
  12.   (if (> (distance p0 e2st) (distance p0 e2en))
  13.     (setq p2s e2st p2e e2en)
  14.     (setq p2s e2en p2e e2en)
  15.   )
  16.   (setq PT1 (polar p0 (angle p0 p1s) 10))  
  17.   (setq PT2 (polar p0 (angle p0 p2s) 10))  
  18.   (setq PT3 (mapcar '(lambda (X Y) (/ (+ X Y) 2.0)) PT1 PT2))
  19.   
  20.   (setq PT3 (inters p0 PT3 p1s p2s nil))
  21.   (entmake (list (cons 0 "LINE") (cons 10 P0) (cons 11 PT3)))
  22. )
  23. (defun C:W1 (/ EN1 EN2)
  24.   (setq en1 (car (entsel)))
  25.   (setq en2 (car (entsel)))
  26.   (HH:Bisect en1 en2)
  27.   (princ)
  28. )
"觉得好,就打赏"
还没有人打赏,支持一下

本帖被以下淘专辑推荐:

发表于 2013-11-18 12:07 | 显示全部楼层
算法上还可以优化一下,求两直线交点,求两直线以交点为起点的方向角,以交点为基点,两直线方向角的均值为方向画线
 楼主| 发表于 2013-11-18 12:10 | 显示全部楼层
NJZX05 发表于 2013-11-18 12:07
算法上还可以优化一下,求两直线交点,求两直线以交点为起点的方向角,以交点为基点,两直线方向角的均值为 ...

如果是这样,这条线画多长合适呢?
发表于 2013-11-18 13:23 | 显示全部楼层
本帖最后由 xyp1964 于 2013-11-18 13:28 编辑

需要综合考虑两直线的方向和是否相交,否则可能出错。

本帖子中包含更多资源

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

x
 楼主| 发表于 2013-11-18 14:14 | 显示全部楼层
xyp1964 发表于 2013-11-18 13:23
需要综合考虑两直线的方向和是否相交,否则可能出错。


现改为取交点到离交点最远处两的交点,出错情况就少了

点评

出错情况就少了——还属于出错!  发表于 2013-11-18 22:32
发表于 2014-5-2 14:42 | 显示全部楼层
8错,感谢分享!
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-5-19 23:58 , Processed in 0.443623 second(s), 30 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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