明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 899|回复: 5

[源码] 多段线相邻点除重,得到点表,请大神看看,怎么写更好

[复制链接]
发表于 2015-5-23 23:02 | 显示全部楼层 |阅读模式
多段线相邻点除重,得到点表,请大神看看,怎么写更好
  1. (defun c:tt()
  2.   (setq en (entget (car (entsel))))
  3.   (setq lst (mapcar 'cdr (vl-remove-if '(lambda (x) (/= 10 (car x))) en)))
  4.   (setq i 0 j 1 pts nil p t)
  5.   (repeat (length lst)
  6.     (setq pt (nth i lst))
  7.     (while p
  8.       (setq pt_1 (nth j lst))
  9.       (if (not (equal pt pt_1))
  10.   (progn
  11.     (setq pts (append pts (list pt)))
  12.     (setq i (1+ i))
  13.     (setq j (1+ j))
  14.     (setq p nil)
  15.   )
  16.   (progn
  17.     (setq i (1+ i))
  18.                (setq j (1+ j))
  19.     (if (> j (length lst))
  20.                  (setq p nil)
  21.                )
  22.   )
  23.       )
  24.     )
  25.     (if (= i (- (length lst) 1))
  26.       (setq j 0)
  27.     )
  28.     (setq p t)
  29.   )
  30.   (setq pts (vl-remove-if '(lambda (x) (= x nil)) pts))
  31.   
  32. )
发表于 2015-5-24 08:13 | 显示全部楼层
本帖最后由 USER2128 于 2015-5-24 15:32 编辑

  1. <div class="blockcode"><blockquote>;;; 多段线相邻点除重,得到点表
  2. ;;; 修改 By USER2128 于 2015-05-24
  3. (defun c:tt (/ en lst fuzz old)
  4.   (setq en (entget (car (entsel))))
  5.   (setq lst (mapcar 'cdr (vl-remove-if '(lambda(x) (/= 10 (car x))) en)))
  6. ;;; (setq lst '((1 2) (3.3 4.4) (3.3 4.4) (3.3001 4.4001) (5 6) (5 6)))
  7.   (setq fuzz 0.001)
  8.   (setq old (last lst))
  9.   (setq lst (mapcar '(lambda(x) (if (equal x old fuzz) nil (setq old x))) lst))
  10.   (setq lst (vl-remove 'nil lst))
  11.   )
发表于 2015-5-24 17:44 | 显示全部楼层
还应该考虑有凸度的pl线吧
 楼主| 发表于 2015-5-24 23:39 | 显示全部楼层
USER2128 发表于 2015-5-24 08:13

非常感谢,太妙了
能否请教下这种情况怎么除重,谢谢:

本帖子中包含更多资源

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

x
 楼主| 发表于 2015-5-24 23:40 | 显示全部楼层
zzyong00 发表于 2015-5-24 17:44
还应该考虑有凸度的pl线吧

额 ,我这边工作倒是不用考虑,因为不会存在有凸度的线的
发表于 2015-5-25 07:43 | 显示全部楼层
重慶崽兒 发表于 2015-5-24 23:39
非常感谢,太妙了
能否请教下这种情况怎么除重,谢谢:

不适合。如要,可先将原始顶点表按顺(或逆)时针排好序后,再执行我修改的程序部分即可
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-5-2 10:15 , Processed in 0.639064 second(s), 26 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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