找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1200|回复: 4

[求助] 修改程序

[复制链接]

已领礼包: 106个

财富等级: 日进斗金

发表于 2014-2-24 10:16:37 | 显示全部楼层 |阅读模式

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

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

×
  1. (defun c:cd (/ ss nss en ent cnt st1 st2 )
  2. (setq ss1 (ssadd))
  3.   (if (setq ss (ssget '((0 . "CIRCLE"))))
  4.     (progn
  5.       (repeat (setq nss (sslength ss))
  6.         (setq en  (ssname ss (setq nss (1- nss)))
  7.               ent (entget en)
  8.               cnt (cdr (assoc 10 ent))
  9.               r      (vl-catch-all-apply
  10.                     '(lambda ()
  11.                        (foreach    p st1
  12.                          (if (equal cnt p 1e-6)
  13.                            (exit)
  14.                          )
  15.                        )
  16.                      )
  17.                   )
  18.         )
  19.         (if    (not (vl-catch-all-error-p r))
  20.                 (setq    st1 (cons cnt st1)
  21.                 st2 (cons (cdr (assoc 10 ent)) st2))
  22.                 (ssadd en ss1)
  23.         )
  24.       )
  25.     )

  26.   )
  27. (alert (strcat "已删除" (rtos (- (sslength ss1) nss))"个同心圆"))
  28. (reverse st2)
  29. )

现在的程序是删除小圆保留最大的圆,
请帮忙改成只删除大圆保最小的一个圆.

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

已领礼包: 685个

财富等级: 财运亨通

发表于 2014-2-24 15:36:31 | 显示全部楼层
你这程序没有删除什么东西啊
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 8859个

财富等级: 富甲天下

发表于 2014-3-8 09:34:54 | 显示全部楼层
;;;同心圆删除大圆保留最小的圆 O.K.
(defun c:cd (/ ss nss en ent cnt st1 st2 )
(setq ss1 (ssadd))
  (if (setq ss (ssget '((0 . "CIRCLE"))))
    (progn
      (repeat (setq nss (sslength ss))
        (setq en  (ssname ss (setq nss (1- nss)))
              ent (entget en)
              cnt (cdr (assoc 10 ent))
              r      (vl-catch-all-apply
                    '(lambda ()
                       (foreach    p st1
                         (if (equal cnt p 1e-6)
                           (exit)
                         )
                       )
                     )
                  )
        )
        (if    (not (vl-catch-all-error-p r))
                (setq    st1 (cons cnt st1)
                st2 (cons (cdr (assoc 10 ent)) st2))
               (PROGN
                 (ssadd en ss1)
                 (vla-Delete (vlax-ename->vla-object en))
               )
        )

      )
      
    )

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

使用道具 举报

发表于 2014-3-8 10:25:14 | 显示全部楼层

  1. (defun c:tt (/ lst)
  2.   (fy:begin)
  3.   (princ "\nSelect Circles .....")
  4.   (if (ssget '((0 . "circle")))
  5.     (progn
  6.       (setq lst        (XD::List:GroupByIndex
  7.                   (mapcar '(lambda (x)
  8.                              (list (vlax-get x "Center")
  9.                                    (list (vlax-get x "Radius") x)
  10.                              )
  11.                            )
  12.                           (fy:cset->objs)
  13.                   )
  14.                   1e-3
  15.                 )
  16.             lst        (mapcar        '(lambda (x)
  17.                            (vl-sort x
  18.                                     '(lambda (x1 x2)
  19.                                        (< (car x1) (car x2));_改为 > 保留最大圆
  20.                                      )
  21.                            )
  22.                          )
  23.                         (mapcar 'cdr lst)
  24.                 )
  25.       )
  26.       (mapcar '(lambda (a)
  27.                  (if (> (length a) 1)
  28.                    (mapcar 'vla-delete (cdr a))
  29.                  )
  30.                )
  31.               (mapcar '(lambda (x) (mapcar 'cadr x)) lst)
  32.       )
  33.     )
  34.   )
  35.   (fy:end)
  36. )

评分

参与人数 1D豆 +5 收起 理由
炫翔 + 5 很给力!经验;技术要点;资料分享奖!

查看全部评分

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

使用道具 举报

发表于 2014-3-8 22:55:40 | 显示全部楼层
谢谢各位楼主的分享!很有意思的代码,收藏备用。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-9-25 00:34 , Processed in 0.378390 second(s), 41 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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