找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 667|回复: 7

[求助] [求助]:找出最长与最短线段

[复制链接]
发表于 2008-5-29 18:58:20 | 显示全部楼层 |阅读模式

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

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

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

已领礼包: 2个

财富等级: 恭喜发财

发表于 2008-5-29 19:55:46 | 显示全部楼层
获取每一个的长度,然后 min  max
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

 楼主| 发表于 2008-5-30 08:12:09 | 显示全部楼层
谢谢zml84 的回答,但我刚学,不会写,能否帮我写一下呢?谢谢 ~
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 2个

财富等级: 恭喜发财

发表于 2008-5-30 11:30:43 | 显示全部楼层
[php]
(defun C:TT (/ SS LST_LEN I EN ENT PT0 PT1 LEN A B)
    (if        (setq SS (ssget '((0 . "LINE"))))
        (progn
            ;;获取全部长度
            (setq LST_LEN '()
                  I 0
            )
            (repeat (sslength SS)
                (setq EN  (ssname SS I)
                      ENT (entget EN)
                      PT0 (cdr (assoc 10 ENT))
                      PT1 (cdr (assoc 11 ENT))
                )
                (setq LEN     (distance PT0 PT1)
                      LST_LEN (cons LEN LST_LEN)
                )
                (setq I (1+ I))
            )
            ;;找最大最小
            (setq A (apply 'max LST_LEN)
                  B (apply 'min LST_LEN)
            )
            ;;显示输出
            (princ "\n最长: ")
            (princ A)
            (princ "\n最短: ")
            (princ B)
        )
    )
    (princ)
)
[/php]
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

 楼主| 发表于 2008-5-30 12:19:15 | 显示全部楼层
实在万分感谢zml84,嘻,能否加个要求,把最长与最短用颜色区分一下呢?我也试一下,呵!
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 2个

财富等级: 恭喜发财

发表于 2008-5-30 13:01:07 | 显示全部楼层
[php]
(defun C:TT (/ SS LST I ENT ENT0 ENT1)
    (if        (and (setq SS (ssget '((0 . "LINE"))))
             (>= (sslength SS) 2)
        )
        (progn
            ;;获取全部对象组码
            (setq LST '()
                  I   0
            )
            (repeat (sslength SS)
                (setq ENT (entget (ssname SS I))
                      LST
                          (cons ENT LST)
                )
                (setq I (1+ I))
            )
            ;;按照长度排序
            (setq LST (vl-sort LST
                               '(lambda        (ENT0 ENT1)
                                    (< (distance (cdr (assoc 10 ENT0))
                                                 (cdr (assoc 11 ENT0))
                                       )
                                       (distance (cdr (assoc 10 ENT1))
                                                 (cdr (assoc 11 ENT1))
                                       )
                                    )
                                )
                      )
            )
            ;;挑出最大最小
            (setq ENT0 (car LST)
                  ENT1 (last LST)
            )
            ;;变色
            (if        (assoc 62 ENT0)
                (setq ENT0 (subst (cons 62 1) (assoc 62 ENT0) ENT0))
                (setq ENT0 (cons (cons 62 1) ENT0))
            )
            (entmod ENT0)
            (if        (assoc 62 ENT1)
                (setq ENT1 (subst (cons 62 2) (assoc 62 ENT1) ENT1))
                (setq ENT1 (cons (cons 62 2) ENT1))
            )
            (entmod ENT1)
            ;;显示输出
            (princ "\n最短: ")
            (princ (distance (cdr (assoc 10 ENT0))
                             (cdr (assoc 11 ENT0))
                   )
            )
            (princ "\n最长: ")
            (princ (distance (cdr (assoc 10 ENT1))
                             (cdr (assoc 11 ENT1))
                   )
            )
        )
    )
    (princ)
)
[/php]
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

 楼主| 发表于 2008-5-30 17:59:53 | 显示全部楼层
哇,实在强~~原以为加一点点,谁知加这么多,实在佩服,万万分感谢!
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2008-5-31 20:34:07 | 显示全部楼层
  1. [FONT=courier new];; 最长最短线变色
  2. (defun c:test778 ()
  3.   (CMDLA0)
  4.   (if (setq ss (ssget '((0 . "LINE"))))
  5.     (progn
  6.       (setq slst (xyp-SS2List ss)
  7.             slst (vl-sort slst
  8.                           '(lambda (s1 s2)
  9.                              (< (xyp-get-CurveLength s1) (xyp-get-CurveLength s2))
  10.                            )
  11.                  )
  12.       )
  13.       (xyp-put "color" (car slst) 1)
  14.       (xyp-put "color" (last slst) 2)
  15.     )
  16.   )
  17.   (CMDLA1)
  18. )[/FONT]
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-6-19 14:32 , Processed in 0.229613 second(s), 45 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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