找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1578|回复: 12

[LISP函数]:将所选择的line或arc串成多义线

[复制链接]
发表于 2005-8-24 22:54:31 | 显示全部楼层 |阅读模式

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

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

×
串多义线
;将所选择的line或arc串成多义线

(defun c:ddx (/ ssa ssa-ent ent-p i)
  (command "undo" "be");设置返回起始点
  (setq ssa (ssget))
  (setq i 0)
  (while (< i (sslength ssa))
    (setq ssa-ent (ssname ssa i))
    (setq ent-p (cdr(assoc 0 (entget ssa-ent))))
    (if (not (null ent-p));判断原图元是否已串入多义线
      (if (or (= ent-p "LWPOLYLINE") (= ent-p "POLYLINE"));判断原图元属性
         (command "pedit" ssa-ent  "j" ssa "" "")
         (command "pedit" ssa-ent  "y" "j" ssa "" "")
    ))
    (setq i (1+ i))
  )
  (command "undo" "e");设置返回终止点
  (princ)
)
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
发表于 2005-8-25 09:25:01 | 显示全部楼层
辛苦了,用MPEDIT其实就可以了
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2005-8-25 09:33:57 | 显示全部楼层
真的不错,我以前为pline线打断后不知道怎么办,现在有办法了,谢谢,非常感谢
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 2个

财富等级: 恭喜发财

发表于 2005-8-25 13:26:21 | 显示全部楼层
(defun C:vvv (/ s1 n1 n e1 e2 z k a)
  (vl-load-com)
  (princ
    "\n将所选实体及與其相連的實體连成多义线,并判断其是否闭合.   )
  (setq z (getvar "cmdecho"))
  (setvar "cmdecho" 0)
  (command "undo" "be")
  (setq s1 (ssget))
  (setq n1 (sslength s1))
  (setq n 0)
  (while (< n n1)
    (setq e1 (ssname s1 n))
    (setq e2 (entget e1))
    (if        (/= nil e2)
      (progn
        (setq a (cdr (assoc 0 e2)))
        (if (= a "LINE")
          (progn (command "pedit" e1 "y" "j" "all" "" "")
                 (setq k (entlast))

                 (if (/= (vlax-curve-isClosed k) t)

                   (command "change" k "" "p" "c" 7 "")
                   (command "change" k "" "p" "c" 30 "")
                 )
          )
          (if (= a "arc")
            (progn (command "pedit" e1 "y" "j" "all" "" "")
                   (setq k (entlast))

                   (if (/= (vlax-curve-isClosed k) t)

                     (command "change" k "" "p" "c" 7 "")
                     (command "change" k "" "p" "c" 30 "")
                   )
            )
          )
        )
      )
    )

    (setq n (1+ n))
  )
  (setvar "cmdecho" z)
  (command "undo" "e")
  (prin1)
)

(defun c:vv (/ z d c b k)
  (vl-load-com)
  (princ
    "\n将所选层上的实体及與其相連的實體连成多义线,并判断其是否闭合.   )
  (setq z (getvar "cmdecho"))
  (setvar "cmdecho" 0)
  (command "undo" "be")
  (setq c (getstring "\n 输入层名:"))
  (while (setq a (ssget "x" (list (cons lc c) (cons 0 "line"))))
    (setq b (ssname a 0))
    (command "change" B "" "p" "c" 30 "")
    (command "pedit" b "y" "j" "all" "" "")
    (setq k (entlast))

    (if        (/= (vlax-curve-isClosed k) t)

      (command "change" k "" "p" "c" 232 "")
    )
  )
  (while (setq a (ssget "x" (list (cons 8 c) (cons 0 "arc"))))
    (setq b (ssname a 0))
    (command "change" B "" "p" "c" 30 "")
    (command "pedit" b "y" "j" "all" "" "")

    (setq k (entlast))

    (if        (/= (vlax-curve-isClosed k) t)

      (command "change" k "" "p" "c" 232 "")
    )
  )
  (setvar "cmdecho" z)

  (command "undo" "e")
  (princ)
)
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2005-8-25 13:55:20 | 显示全部楼层
  1. [FONT=courier new]
  2. (defun c:test ()
  3.   (setq        ss    (ssget '((0 . "LINE,ARC,*POLYLINE")))
  4.         etype (cdr (assoc 0 (entget (ssname ss 0))))
  5.   )
  6.   (if (or (= etype "LINE")
  7.           (= etype "ARC")
  8.       )
  9.     (command "pedit" "M" ss "" "Y" "j" "" "")
  10.     (command "pedit" "M" ss "" "j" "" "")
  11.   )
  12.   (princ)
  13. )[/FONT]
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 2个

财富等级: 恭喜发财

发表于 2005-8-26 08:55:41 | 显示全部楼层
5樓班竹,能否再完善一下:
1.所選擇的全部是聚合線時的,直接退出程序
2.希望將判斷連接後線是否爲閉合,以不同顔色區分即可.
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2005-8-29 14:55:59 | 显示全部楼层
所选的LINE、ARC、LWPOLYLINE不是连在一起的怎么办,虽然从视觉上判断是接在一起的,但LWPOLYLINE宽度不为0时很难判断,是否在一判断代码.
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 111个

财富等级: 日进斗金

发表于 2005-8-29 16:29:49 | 显示全部楼层
用下面的程序:
(defun c:test ()
  (setq        ss (ssget '((0 . "LINE,ARC,*POLYLINE"))))
  (command "pedit" "M" ss "" "Y" "j" "" "")
  (princ)
)

出现以下问题,请5楼楼主给帮忙解释一下:
Command: test
Select objects: Specify opposite corner: 8 found

Select objects:
pedit Select polyline: M

*Invalid selection*
Expects a point or Window/Last/Crossing/BOX/ALL/Fence/WPolygon/CPolygon
; error: Function cancelled
Select polyline:
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 2个

财富等级: 恭喜发财

发表于 2005-9-3 08:32:03 | 显示全部楼层
5樓班竹,能否再完善一下:
1.希望將判斷連接後線是否爲閉合,以不同顔色區分即可.
謝謝!
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2005-9-3 09:38:06 | 显示全部楼层
  1. [FONT=courier new](defun c:test ()
  2.   (setq        ss    (ssget '((0 . "LINE,ARC,*POLYLINE")))
  3.         etype (cdr (assoc 0 (entget (ssname ss 0))))
  4.   )
  5.   (if (or (= etype "LINE")
  6.           (= etype "ARC")
  7.       )
  8.     (command "pedit" "M" ss "" "Y" "j" "" "")
  9.     (command "pedit" "M" ss "" "j" "" "")
  10.   )
  11.   (setq ename (entlast))
  12.   (if (equal (vlax-curve-getstartPoint ename)
  13.          (vlax-curve-getEndPoint ename)
  14.       )
  15.     (command "change" ename "" "p" "c" "1" "")
  16.   )
  17.   (princ)
  18. )[/FONT]
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 2个

财富等级: 恭喜发财

发表于 2005-9-7 09:33:02 | 显示全部楼层
樓上的程序只能對最後生成的實體進行判斷。如果一次生成很多封閉與不封閉的多義線呢?
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2005-11-29 13:22:42 | 显示全部楼层
1楼和斑主的程序在某些情况下均失效, 是否要考虑Z轴和UCS的问题?
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 2个

财富等级: 恭喜发财

发表于 2005-11-29 14:06:04 | 显示全部楼层
http://www.xdcad.net/forum/showthread.php?threadid=476152
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-9-28 20:47 , Processed in 0.193723 second(s), 56 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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