明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
12
返回列表 发新帖

[已解答] 两条线之间画等分线的代码需修正

[复制链接]
发表于 2018-9-28 16:44 | 显示全部楼层
bai2000 发表于 2014-12-16 21:28
怎么改改,可以输入等分的个数?

要是能实现这个功能,那就太完美了
发表于 2018-9-29 09:15 | 显示全部楼层
;;两曲线等分
(defun c:tt (/ dis L1 L2 P1 P2 A1 D1 P3 P4 A2 D2 PL1 PL2 PTS)
        (princ "\n两曲线等分:")
  (while (and
                                         (setq l1 (car (entsel "\r选择曲线1:")))
                                         (setq l2 (car (entsel "\r选择曲线2:")))
                                         (setq dis (getint "\r请输入等分份数(≥1):"))
                                 )
    (setq
                        p1  (vlax-curve-getStartPoint l1)
                        p2  (vlax-curve-getEndPoint l1)
                        d1 (* (/ 1.0 dis) (vlax-curve-getDistAtParam l1 (vlax-curve-getEndParam l1)))
                        p3  (vlax-curve-getStartPoint l2)
                        p4  (vlax-curve-getEndPoint l2)
                        d2 (* (/ 1.0 dis)  (vlax-curve-getDistAtParam l2 (vlax-curve-getEndParam l2)))
                        pl1 (list p1)
                        pl2 (list p3)
                        i 0
                )
    (repeat dis
      (setq i (1+ i)
                                pl1 (cons (vlax-curve-getpointatdist l1 (* d1 i)) pl1)
                                pl2 (cons (vlax-curve-getpointatdist l2 (* d2 i)) pl2)
                        )
                )
    (setq pl1 (cons p2 pl1)
                        pl2 (cons p4 pl2)
                )
    (if (inters (car pl1) (car pl2) (last pl1) (last pl2))
      (setq pl2 (reverse pl2))
                )
    (setq pts (mapcar 'list pl1 pl2))
    (mapcar
      '(lambda (x)
         (entmake
           (list '(0 . "line") (cons 10 (car x)) (cons 11 (cadr x)))
                                 )
                         )
      pts
                )
        )
  (princ)
)
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-4-23 19:56 , Processed in 0.425263 second(s), 19 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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