找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 4768|回复: 18

[弹指神通]:消除复线上多余顶点的程序(不是重复顶点)

[复制链接]
发表于 2005-10-6 20:31:36 | 显示全部楼层 |阅读模式

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

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

×
最近一个朋友由于工作原因需要这样一个程序:
取消复线上所有多余的点:
多余点的含义是:比如复线中有两点之间是线段连接或圆弧连接的
而在这两点之间还有一个顶点刚好在这两点之间的顶点或圆弧度上
此程序就是要消除这些点让复线任意两点之间不在有多余的顶点
[php]
(defun hy_mopline(pline / *vlhy-ActiveDocument* *vlhy-ModelSpace* paramlist okey rad1 base
                  ent bu1 bu2 ro objpline number i cenlist numberx u1 u2 p1 p2 dis rad
                  reent);;?耿絬
  (defun count(o num)
    (if (< o 0) (+ num o)
    o
    )
    )
  (defun countce(pa pb bulge / dis gongao mp centerp)
      (setq dis (distance pa pb))
      (setq gongao (abs (* (/ dis 2) bulge)));;?蔼
      (SETQ MP (MAPCAR '(LAMBDA (x y) (/ (+ x y) 2)) pa pb))
      (setq rad (/ (+ (expt gongao 2) (expt (/ dis 2) 2)) (* 2 gongao )));GET THE RADIUS
      (cond ((> 0 bulge)
                  (setq centerp (polar mp (- (angle pa pb) (* 0.5 pi)) (- rad gongao)))
             )
            ((< 0 bulge)
                 (setq centerp (polar mp (+ (angle pa pb) (* 0.5 pi)) (- rad gongao))))
                     
           )
  centerp
  )
  (setq *vlhy-ActiveDocument* (vla-Get-ActiveDocument (vlax-Get-Acad-Object)))
  (setq *vlhy-ModelSpace* (vla-Get-ModelSpace *vlhy-ActiveDocument*))
  (hy_delcfvetex pline 0.00001)
  (setq ent (entget pline))
  (setq objpline (vlax-ename->vla-object pline))
  (IF (and (= (vla-get-closed objpline) :vlax-FALSE)
           (equal (vlax-curve-getstartpoint objpline)
                  (vlax-curve-getendpoint objpline)
                  0.00001)
           )
    (progn
      (vla-put-closed objpline :vlax-true)
      (setq ent (entget pline))
      (setq reent (reverse ent))
      (setq ent (reverse
    (append (list (car reent)) (cdr (member (assoc 10 reent) reent)))
    ))
      (entmod ent)
    )
    )
  (setq number (length (massoc 10 ent)))
  (setq o 0 paramlist nil)
  (repeat number (setq paramlist (cons o paramlist) o (1+ o)))
  (setq okey t)
  (if (setq base (osnap (vlax-curve-getpointatparam objpline 0.5) "cen"))
    (progn (setq rad1 (distance base (vlax-curve-getpointatparam objpline 0.5)))
           (if (and (not (vl-some '(lambda(x) (not(equal base
                             (osnap (vlax-curve-getpointatparam objpline (+ x 0.5)) "cen")
                               0.00001)
                               )
                  ) (reverse (cdr paramlist))))
                   (= (vla-get-closed objpline) :vlax-true))
          (progn (vla-delete objpline)
                 (vla-addcircle *vlhy-ModelSpace* (vlax-3D-Point base) rad1)
                 (setq okey nil))
             )
      )
    )
  (if okey (progn
  (setq cenlist nil)
  (if (= (vla-get-closed objpline) :vlax-true) (setq numberx  number  i 0)
    (setq numberx (- number 2) i 1))
  (repeat numberx
    (cond ((and (/= 0 (setq bu1 (vla-getbulge objpline (count (1- i) number))))
                (/= 0 (setq bu2 (vla-getbulge objpline i)))
                (equal (setq ro (countce (vlax-curve-getpointatparam objpline (count (1- i) number))
                         (vlax-curve-getpointatparam objpline i) bu1))
                        (countce (vlax-curve-getpointatparam objpline i)
                         (vlax-curve-getpointatparam objpline (1+ i)) bu2)
                       0.00001)
                )
           (setq ent (vl-remove (list 10
                                       (car (vlax-curve-getpointatparam objpline i))
                                       (cadr (vlax-curve-getpointatparam objpline i))
                                       )
                       ent)
                cenlist (cons
                          (list
                            (vlax-curve-getpointatparam objpline (count (1- i) number))
                            ro
                            (if (minusp (vla-getbulge objpline i)) -1 1)
                            )
                            cenlist)
                 )
             )
          ((and (= 0 (vla-getbulge objpline (count (1- i) number)))
                (= 0 (vla-getbulge objpline i))
                (equal (angle (vlax-curve-getpointatparam objpline (count (1- i) number))
                          (vlax-curve-getpointatparam objpline i))
                   (angle (vlax-curve-getpointatparam objpline i)
                          (vlax-curve-getpointatparam objpline (1+ i))
                          )
                   0.00001)
                )
           (setq ent (vl-remove (list 10
                                       (car (vlax-curve-getpointatparam objpline i))
                                       (cadr (vlax-curve-getpointatparam objpline i))
                                       )
                       ent))
                       )
          )
    (setq i (1+ i))
    )
  (setq cenlist (reverse cenlist))
  (entmod ent)
  (if cenlist
  (foreach item cenlist
    (if (and (setq u1 (vlax-curve-getparamatpoint objpline (car item)))
             (equal (fix u1) u1 0.000001))
      (progn
      (setq u2 (+ u1 1))
      (setq p1 (vlax-curve-getpointatparam objpline u1))
      (setq p2 (vlax-curve-getpointatparam objpline u2))
      (setq dis (distance p1 p2))(setq rad (distance (cadr item) p1))
      (cond ((and (= 1 (caddr item))
               (or (and (> (- (angle (cadr item) p2) (angle (cadr item) p1)) 0)
                        (< (- (angle (cadr item) p2) (angle (cadr item) p1)) pi)
                        )
                   (and (< (- (angle (cadr item) p2) (angle (cadr item) p1)) (- 0 pi))
                        (> (- (angle (cadr item) p2) (angle (cadr item) p1)) (- 0 pi pi))
                        )
                   )
               )
             (setq bulge (/ (- rad (expt (- (expt rad 2) (expt (* dis 0.5) 2)) 0.5)) (* dis 0.5)))
             )
            ((and (= 1 (caddr item))
               (or (and (> (- (angle (cadr item) p2) (angle (cadr item) p1)) pi)
                        (< (- (angle (cadr item) p2) (angle (cadr item) p1)) (* 2 pi))
                        )
                   (and (< (- (angle (cadr item) p2) (angle (cadr item) p1)) 0)
                        (> (- (angle (cadr item) p2) (angle (cadr item) p1)) (- 0 pi))
                        )
                   )
               )
             (setq bulge (/ (+ rad (expt (- (expt rad 2) (expt (* dis 0.5) 2)) 0.5)) (* dis 0.5)))
             )
            ((and (= -1 (caddr item))
               (or (and (> (- (angle (cadr item) p2) (angle (cadr item) p1)) 0)
                        (< (- (angle (cadr item) p2) (angle (cadr item) p1)) pi)
                        )
                   (and (< (- (angle (cadr item) p2) (angle (cadr item) p1)) (- 0 pi))
                        (> (- (angle (cadr item) p2) (angle (cadr item) p1)) (- 0 pi pi))
                        )
                   )
               )
             (setq bulge (/ (+ rad (expt (- (expt rad 2) (expt (* dis 0.5) 2)) 0.5)) (* dis 0.5)))
             )
            ((and (= -1 (caddr item))
               (or (and (> (- (angle (cadr item) p2) (angle (cadr item) p1)) pi)
                        (< (- (angle (cadr item) p2) (angle (cadr item) p1)) (* 2 pi))
                        )
                   (and (< (- (angle (cadr item) p2) (angle (cadr item) p1)) 0)
                        (> (- (angle (cadr item) p2) (angle (cadr item) p1)) (- 0 pi))
                        )
                   )
               )
             (setq bulge (/ (- rad (expt (- (expt rad 2) (expt (* dis 0.5) 2)) 0.5)) (* dis 0.5)))
             )
            )
      (vla-setbulge objpline u1 (* bulge (caddr item)))
      )
      )
    )
    )
      )
    )
  )
(defun massoc (key alist / x nlist)
  (foreach x alist
    (if (eq key (car x))
      (setq nlist (cons (cdr x) nlist))
      )
    )
  (reverse nlist))
(defun hy_delcfvetex (e preci  / a a1 b b1 c c1 en j n new p p1 key)
  (setq en (entget e))
  (while (setq n (car en))
    (if        (= (car n) 90)
      (setq j (cdr n))
    )
    (if        (= (car n) 10)
      (progn
        (mapcar 'set '(p a b c) en)
        (setq en  (cddddr en)
              key t
        ) ;_key??dxf10
        (if (equal p1 p preci)
          (setq j (1- j))
          (if p1
            (setq new (append new (list p1 a1 b1 c1)))
          )
        )
        (mapcar 'set '(p1 a1 b1 c1) (list p a b c))
      ) ;_progn
      (progn (if key
               (setq new (append new (list p1 a1 b1 c1))
                     key nil
               ) ;_dxf10Ч?.
             )
             (setq new (append new (list n))
                   en  (cdr en)
             )
      )
    ) ;_if
  ) ;_while
  (entmod (subst (cons 90 j) (assoc 90 new) new))
)
[/php]
测试
(defun c:tt() (hy_mopline (car(entsel))))
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
发表于 2005-10-6 21:18:10 | 显示全部楼层
函数不全,舟兄,你的程序测试起来咋这麻烦呢?
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

 楼主| 发表于 2005-10-6 22:38:14 | 显示全部楼层
不好意思..呵呵..漏了一个..已经编辑过..请重新测试..
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2005-10-7 00:10:43 | 显示全部楼层
楼主,你真是强人呀!顺便问个菜鸟级问题,objectdcl与vlisp有什么不同?
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 488个

财富等级: 日进斗金

发表于 2005-10-7 00:54:53 | 显示全部楼层
hy_delcfvetex ,这一段基本是我写的:)

举个例子:A到B,线宽是从0到100,B到C,一直是100,那B点去掉吗?
AB,CD都是圆弧呢?
都为同圆心的圆弧呢?
AB线宽从0到50,BC从50到101,又是什么情况呢?
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2005-10-7 01:51:12 | 显示全部楼层
我是这么觉得,有等宽度的多义线,才进行顶点净化;有宽度变换的多义线片断,通常情况是有一定意义的(比如说画箭头),因此建议过滤掉有宽度变换的“段”,不必进行净化处理。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

 楼主| 发表于 2005-10-7 08:07:50 | 显示全部楼层
最初由 dezhang 发布
[B]楼主,你真是强人呀!顺便问个菜鸟级问题,objectdcl与vlisp有什么不同? [/B]

objectdcl与vlisp 的区别..这个问题你倒难倒我了.
我决的OBJECTDCL的原理应该和VLISP差不多吧..都是工具
OBJECTDCL对对话框的部分做了强化使对话框不用写而是用画的..这点应该是仿照VB的..应该说他是VLISP和VB的结合体..但是在使用的过程中(3.0版本)我却发现了不少问题..觉得他还是不很完美
期待有更完美的版本出现
另程序中是用了AEO斑竹的一段程序并表示感谢...
狂刀兄所说的有宽度段不处理.应该可以实现..不过我工作中一般不遇到宽度复线..所以在我的程序中一般不予考虑..如果刀兄有兴趣..等过几天有时间我修正一下...
另回AEO斑竹我程序中并未对线宽做处理..我程序中净化的是多余顶点
A到B段和B到C段都是直线段并且斜率一样那程序就会过滤掉B点
圆弧段也一样可以过滤..如果复线刚好是组成一个整圆的话程序就重新画一个半径一样大小的圆并删除原来的复线..
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 593个

财富等级: 财运亨通

发表于 2005-10-7 08:59:24 | 显示全部楼层
假如Pline中间段有一个“园”,也是顶点重合,但中间那个点是不能去掉的。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2005-10-7 09:47:15 | 显示全部楼层
ea的意思是说不应该去掉吧?
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

 楼主| 发表于 2005-10-7 10:34:56 | 显示全部楼层
最初由 eachy 发布
[B]假如Pline中间段有一个“园”,也是顶点重合,但中间那个点是不能去掉的。 [/B]

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

使用道具 举报

发表于 2005-10-8 12:13:38 | 显示全部楼层
这段程序对于处理SPLINE转成PLINE后节点非常多的线段很实用。修改后可做线段抽稀用。
下来备用!
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

使用道具 举报

发表于 2005-12-16 10:41:30 | 显示全部楼层
图中的点3未能删除。
另外有些多义线,需镜像后才能删除多余点
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

 楼主| 发表于 2005-12-16 11:41:37 | 显示全部楼层
程序是逐段判斷的。。所以對石兄的那種情況是不適用的。。
"另外有些多义线,需镜像后才能删除多余点" 可否附上例子以便于修正。。。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-14 06:36 , Processed in 0.360042 second(s), 60 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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