找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 621|回复: 4

[求助] [求助]:多義線上點集排序問題

[复制链接]

已领礼包: 2个

财富等级: 恭喜发财

发表于 2006-1-22 13:42:23 | 显示全部楼层 |阅读模式

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

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

×
已知一點點集位於多義線上,請教怎樣將點按多義線的起點,點1 點2 點3...... 點n多義線終點的順序排序.
思路:
用(vlax-curve-getDistAtPoint splineObj getPt) 求各點離起點的距離,將點集按與起點的距離從小到排列.
但不知道怎麽實現.請大家指點一下.謝謝!

將EACHY版主的函數改一下:
http://www.xdcad.net/forum/showthread.php?s=&threadid=452597
說實話,eachy版主的這個東東我看得不是很明白.我只是依葫蘆畫瓢.


  1.   [FONT=courier new]
  2. (defun th1-getnearestpt (ename pts / ll p1 p2 d)
  3.   (setq ll (vl-sort (mapcar
  4.                       '(lambda (x)
  5.                          (list (vlax-curve-getdistatpoint ename x) ename x)
  6.                        )
  7.                       pts
  8.                     ) '(lambda (e1 e2)
  9.                          (< (car e1) (car e2))
  10.                        )
  11.            )
  12.   )
  13.   (setq p1 (cdar ll)
  14.         d (caar ll)
  15.         ll (cdr ll)
  16.   )
  17.   (while (equal (car (setq p2 (car ll))) d 1e-5)
  18.     (if (not (vl-position (last p2) p1))
  19.       (setq p1 (append
  20.                  p1
  21.                  (list (last p2))
  22.                )
  23.       )
  24.     )
  25.     (setq ll (cdr ll))
  26.   )
  27.   p1
  28. )
  29. ;;;返回(ename 離起點正方向最近的點)

  30.   [/FONT]

从列表中移去指定的元素子程序:


  1.   [FONT=courier new]  
  2. (defun th-drop (lst item)
  3.   (append
  4.     (reverse (cdr (member item (reverse lst))))
  5.     (cdr (member item lst))
  6.   )
  7. )
  8.   [/FONT]



將點集排序

  1.   [FONT=courier new]
  2. (defun th-getnin2maxpts (ename ptlist / k l nearestpt ptlistmin2max)
  3.   (if (and
  4.         ename
  5.         ptlisti
  6.       )
  7.     (progn
  8.       (setq k -1
  9.             l (1- (length ptlisti))
  10.       )
  11.       (setq ptlistmin2max '())
  12.       (while (< k l)
  13.         (setq nearestpt (cadr (th1-getnearestpt ename ptlisti)))
  14.         (setq ptlisti (th-drop ptlisti nearestpt))
  15.         (setq ptlistmin2max (cons nearestpt ptlistmin2max))
  16.         (setq k (1+ k))
  17.       )
  18.       (setq ptlistmin2max (reverse ptlistmin2max))
  19.     )
  20.   )
  21. )

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

已领礼包: 593个

财富等级: 财运亨通

发表于 2006-1-22 17:31:01 | 显示全部楼层

  1. ;;点集按Pl起点到终点排序,返回(pline实体 排序后的点表)
  2. ;;参数 pl --- pline 实体或Object,pts ---- 点集
  3. ;;其实 pl 可以是任何 Curve
  4. (defun xdl-pts-sortonpl (pl pts)
  5.   (setq        pts (mapcar '(lambda (x)
  6.                        (list (vlax-curve-getparamatpoint
  7.                                pl
  8.                                (vlax-curve-getclosestpointto pl x)
  9.                              )
  10.                              x
  11.                        )
  12.                      )
  13.                     pts
  14.             )
  15.         pts (vl-sort '(lambda (e1 e2) (< (car e1) (car e2))) pts)
  16.   )
  17.   (list pl (mapcar 'cadr pts))
  18. )
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 2个

财富等级: 恭喜发财

 楼主| 发表于 2006-1-22 18:24:48 | 显示全部楼层
測試:
(xdl-pts-sortonpl (car(entsel))ptlistmin2max)

选择对象: ; 错误: 函数错误: 139.743

版主也有不小心的時候!vl-sort搞反了.

  1.   [FONT=courier new]
  2. (defun xdl-pts-sortonpl        (pl pts)
  3.   (setq        pts (mapcar
  4.               '(lambda (x)
  5.                  (list (vlax-curve-getdistatpoint
  6.                          pl
  7.                          (vlax-curve-getclosestpointto pl x)
  8.                        )
  9.                        x
  10.                  )
  11.                )
  12.               pts
  13.             )
  14.         pts (vl-sort pts
  15.                      '(lambda (e1 e2)
  16.                         (< (car e1) (car e2))
  17.                       )
  18.             )
  19.   )
  20.   (list        pl
  21.         (mapcar
  22.           'cadr
  23.           pts
  24.         )
  25.   )
  26. )  [/FONT]
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2006-1-22 22:03:21 | 显示全部楼层
一个类似的函数:xyp-get-CurveIntersLeng  曲线交点表或交点间线长表
  1. [FONT=courier new](load "xyp_lib.vlx");版本 V.20060122 (2003)
  2. ;|下载和加载通用函数(可在签名栏直接下载后放到搜索路径下)
  3. 利用以下任何一种方式(首选第一种)即可加载和运行通用函数内的所有子程序:
  4. ★1·在acad.lsp中增加(load"xyp_lib.vlx")
  5. ■2·在每个程序内增加(load"xyp_lib.vlx")
  6. ■3·在command下,输入(load"xyp_lib.vlx")
  7. ■4·在菜单.mnl中增加(load"xyp_lib.vlx")
  8. ■5·将xyp_lib.vlx文件直接拽到cad屏幕
  9. [COLOR=red] ★通用函数下载地址:[/COLOR]
  10. [url]http://www.xdcad.net/forum/attachment.php?s=&postid=1606661[/url]
  11. |;

  12. ;|★ xyp-get-CurveIntersLeng
  13. 曲线交点表或交点间线长表
  14. (xyp-get-CurveIntersLeng 实体名 mode)
  15. mode:0,交点线长表;1,交点;2,线长
  16. |;

  17. (defun c:test ()
  18.   (CMDLA0)
  19.   (setq        s1 (car (entsel "\n选择曲线 : "))
  20.         l0 (xyp-get-CurveIntersLeng s1 0)
  21.         l1 (xyp-get-CurveIntersLeng s1 1)
  22.         l2 (xyp-get-CurveIntersLeng s1 2)
  23.   )
  24.   (princ "\n交点线长表 = ")
  25.   (princ l0)
  26.   (princ "\n交点表 = ")
  27.   (princ l1)
  28.   (princ "\n线长表 = ")
  29.   (princ l2)
  30.   (CMDLA1)
  31. )[/FONT]
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2006-1-22 23:22:53 | 显示全部楼层
那再请问一下这排序完如果要求出距离最大的第一段,第二段...并在做计算
该怎样作呢?
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-9-23 10:26 , Processed in 0.336625 second(s), 39 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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