明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 1834|回复: 9

[提问] 两直线端点闭合成多段线

[复制链接]
发表于 2019-7-13 23:34:48 来自手机 | 显示全部楼层 |阅读模式
有没有将两条直线端点连接成闭合的多段线插件
"觉得好,就打赏"
还没有人打赏,支持一下
发表于 2019-7-14 09:42:48 | 显示全部楼层
 楼主| 发表于 2019-7-14 11:48:30 来自手机 | 显示全部楼层
不好意思,我没表达清楚,是将两条平行的直线的两瑞相连并闭合成四边形或矩形矩形
发表于 2019-7-14 12:07:59 | 显示全部楼层
发表于 2019-7-14 12:13:53 | 显示全部楼层
本帖最后由 taoyi0727 于 2019-7-14 12:16 编辑

点表要怎么排序搞不定   下面这个面出来的矩形有可能要交叉
(defun c:tt (/ dxf lst name ss)
        (if (and
                                (setq ss (ssget '((0 . "line"))))
                                (= (sslength ss) 2)
                        )
                (progn
                        (while (setq name (ssname ss 0))
                                (setq dxf (entget name))
                                (setq lst (append lst (list
                                                                                                                                (cdr (assoc 10 dxf))
                                                                                                                                (cdr (assoc 11 dxf))
                                                                                                                        )
                                                                        )
                                )
                                (ssdel name ss)
                                (entdel name)
                        )
                        (entmake (append
                                                                 (list
                                                                         '(0 . "LWPOLYLINE")
                                                                         '(100 . "AcDbEntity")
                                                                         '(100 . "AcDbPolyline")
                                                                         (cons 90 (length lst))
                                                                         (cons 70 1)
                                                                 )
                                                                 (mapcar '(lambda (pt) (cons 10 pt)) lst)
                                                                 (list (cons 210 (trans '(0.0 0.0 1.0) 1 0)))
                                                         )
                        )
                )
        )
)

本帖子中包含更多资源

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

x
发表于 2019-7-14 13:16:39 | 显示全部楼层
(defun c:tt (/ dxf lst lst2 name name-lst ss)
        (if (and
                                (setq ss (ssget '((0 . "line"))))
                                (= (sslength ss) 2)
                        )
                (progn
                        (setq lst nil)
                        (setq lst2 nil)
                        (setq name-lst nil)
                        (while (setq name (ssname ss 0))
                                (setq dxf (entget name))
                                (setq lst (append lst (list
                                                                                                                                (cdr (assoc 10 dxf))
                                                                                                                                (cdr (assoc 11 dxf))
                                                                                                                        )
                                                                        )
                                )
                                (ssdel name ss)
                                (entdel name)
                        )
                        (setq lst2 (list (nth 0 lst) (nth 2 lst) (nth 1 lst) (nth 3 lst)))
                        (setq lst3 (list (nth 1 lst) (nth 0 lst) (nth 2 lst) (nth 3 lst)))
                        (foreach x (list lst lst2 lst3)
                                (setq name-lst (append
                                                                                                 name-lst
                                                                                                 (list (progn
                                                                                                                                 (entmake (append
                                                                                                                                                                                (list
                                                                                                                                                                                        '(0 . "LWPOLYLINE")
                                                                                                                                                                                        '(100 . "AcDbEntity")
                                                                                                                                                                                        '(100 . "AcDbPolyline")
                                                                                                                                                                                        (cons 90 (length x))
                                                                                                                                                                                        (cons 70 1)
                                                                                                                                                                                )
                                                                                                                                                                                (mapcar '(lambda (pt) (cons 10 pt)) x)
                                                                                                                                                                                (list (cons 210 (trans '(0.0 0.0 1.0) 1 0)))
                                                                                                                                                                        )
                                                                                                                                 )
                                                                                                                                 (entlast)
                                                                                                                         )
                                                                                                 )
                                                                                         )
                                )
                        )
                        (if (>
                                                (Vlax-Get (vlax-ename->vla-object (car name-lst)) 'Area);1
                                                (Vlax-Get (vlax-ename->vla-object (cadr name-lst)) 'Area);2
                                        )
                                (if (>
                                                        (Vlax-Get (vlax-ename->vla-object (car name-lst)) 'Area);1
                                                        (Vlax-Get (vlax-ename->vla-object (caddr name-lst)) 'Area);3
                                                )
                                        (progn
                                                (entdel (cadr name-lst))
                                                (entdel (caddr name-lst))
                                        )
                                        (progn
                                                (entdel (car name-lst))
                                                (entdel (cadr name-lst))
                                        )
                                )
                                (if (>
                                                        (Vlax-Get (vlax-ename->vla-object (cadr name-lst)) 'Area);2
                                                        (Vlax-Get (vlax-ename->vla-object (cadr name-lst)) 'Area);3
                                                )
                                        (progn
                                                (entdel (car name-lst))
                                                (entdel (caddr name-lst))
                                        )
                                        (progn
                                                (entdel (car name-lst))
                                                (entdel (cadr name-lst))
                                        )
                                )
                        )
                )
        )
)
发表于 2019-9-7 20:20:40 | 显示全部楼层
楼上的改的非常好!
发表于 2021-1-12 11:05:19 | 显示全部楼层
taoyi0727 发表于 2019-7-14 13:16
(defun c:tt (/ dxf lst lst2 name name-lst ss)
        (if (and
                                (setq ss (ssget '((0 . "line"))))

楼上的改的非常好!
发表于 2021-1-18 15:23:26 | 显示全部楼层
taoyi0727 发表于 2019-7-14 13:16
(defun c:tt (/ dxf lst lst2 name name-lst ss)
        (if (and
                                (setq ss (ssget '((0 . "line"))))

楼上的改的非常好!
发表于 2023-5-3 11:18:11 | 显示全部楼层
谢谢,很有用
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-11-16 16:27 , Processed in 0.169859 second(s), 28 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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