明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 3579|回复: 12

如何把选择集内的曲线按照到已知点的距离进行重新排序

  [复制链接]
发表于 2011-8-31 13:43:29 | 显示全部楼层 |阅读模式
(vl-load-com)
(princ "选择辅助线\n")
(setq m_ent1 (car(entsel)))
  (setq ent1_s(vlax-curve-getStartPoint p1))
(print "请选择需要扫描的区域:")
(setq ss  (ssget))
(setq lengss (sslength ss))
(setq bb 0)

(while (< bb lengss)
(setq p1 (ssname ss bb))
(setq ed (entget p1))
下面不知道该如何写了

即把ss内的所有曲线按照到ent-s点的距离有小到大重新排序


望各位高手指教,谢谢
 楼主| 发表于 2011-9-2 07:29:27 | 显示全部楼层
先谢谢楼上的了,再琢磨你的算法
回复 支持 1 反对 0

使用道具 举报

发表于 2023-10-2 10:08:48 | 显示全部楼层
刚看到这个帖子,顶一下
 楼主| 发表于 2011-9-1 20:11:14 | 显示全部楼层
有高手指导指导吗
发表于 2011-9-1 20:45:01 | 显示全部楼层
猜想至今久悬状况,应是没看懂您的需求而当个过客
各行各业,同中有异....
想办法把您的问题叙述至让人家不费力就能懂 ...
发表于 2011-9-2 07:13:58 | 显示全部楼层
花了十分钟,简单的测试了一下,错误处理不够强大,其它的你自已整
(defun c:test (/ m_select ss lengss bb entlst p1)
  (setq m_select (entsel "\n选择辅助线:"))
  (if (and m_select (setq m_ent1 (car m_select))) ;_有效选择
    (progn
      (print "请选择需要扫描的区域:")
      (setq ss (ssget))                        ;选择集
      (if ss ;_选择集有效
        (progn
          (setq lengss (sslength ss))
          (setq bb 0)
          (setq entlst nil)
          (while (< bb lengss)
            (setq p1 (ssname ss bb))
            (setq bb (1+ bb))
            (setq entlst (cons p1 entlst))
          ) ;_循环将选择集加入到表
          (setq pt (cadr m_select)) ;_ent-s点
          (setq        sortentlst;_排序后的表
                 (vl-sort
                   entlst
                   '(lambda (curveA curveB / nearpa nearpb dista distB)
                      (setq nearpA
                             (vlax-curve-getClosestPointTo curveA pt)
                      )
                      (setq nearpB
                             (vlax-curve-getClosestPointTo curveB pt)
                      )
                      (setq distA (DISTANCE (trans nearpA 0 1) pt))
                      (setq distA (DISTANCE (trans nearpB 0 1) pt))
                      (<= distA distB) ;_从小到大
                      ;;(>= distA distB);_从大到小
                    )
                 )
          ) ;_排序
        )
        (princ "\n选择集无效!")
      )
    )
    (princ "\n曲线无效!")
  )
  (princ)
)
   
发表于 2011-9-2 07:49:35 | 显示全部楼层
  1. (defun c:tt ()
  2.   (if (and (setq p1 (getpoint "\n基点<退出>: "))
  3.            (setq ss (ssget '((0 . "*LINE,ARC,CIRCLE,ELLIPSE"))))
  4.       )
  5.     (progn
  6.       (setq i        -1
  7.             lst        '()
  8.       )
  9.       (while (setq s1 (ssname ss (setq i (1+ i))))
  10.         (setq p2   (vlax-curve-getClosestPointTo s1 p1)
  11.               dist (distance p1 p2)
  12.               lst  (cons (list dist s1) lst)
  13.         )
  14.       )
  15.       (if lst
  16.         (progn
  17.           (setq        lst (vl-sort lst '(lambda (a b) (< (car a) (car b))))
  18.                 lst (mapcar 'cadr lst)
  19.           )
  20.           (princ "\n!lst = ")
  21.           (princ lst)
  22.         )
  23.       )
  24.     )
  25.   )
  26.   (princ)
  27. )
 楼主| 发表于 2011-9-2 08:24:06 | 显示全部楼层
caiqs 的程序可以运行,但不是我要的结果,你只是把距离排序了,没有把距离对应的曲线也排序,我要的是曲线按照距离的大小排序,不过还是非常感谢
 楼主| 发表于 2011-9-2 08:26:25 | 显示全部楼层
caiqs 的程序可以运行,但不是我要的结果,你只是把距离排序了,没有把距离对应的曲线也排序,我要的是曲线按照距离的大小排序,不过还是非常感谢
运行结果:
排序前的曲线图元是:(<图元名: 7ef6b1c8> <图元名: 7ef6b1d0> <图元名: 7ef6b1d8> <图元名: 7ef6b270>
<图元名: 7ef6b340> <图元名: 7ef6b378> <图元名: 7ef6b3b0>)
排序后的曲线图元是:(<图元名: 7ef6b1c8> <图元名: 7ef6b1d0> <图元名: 7ef6b1d8> <图元名: 7ef6b270>
<图元名: 7ef6b340> <图元名: 7ef6b378> <图元名: 7ef6b3b0>)
排序前后图元顺序没有变
 楼主| 发表于 2011-9-2 09:46:11 | 显示全部楼层
6楼的程序解决我的难题,感谢,同时非常感谢大家的关注,
 楼主| 发表于 2011-9-2 09:48:42 | 显示全部楼层
问一个弱智问题,知道图元名,如何调用图元名对应的实体
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-11-17 07:44 , Processed in 0.171766 second(s), 26 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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