找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1040|回复: 9

[转贴]:3D多义线转化2D多义线

[复制链接]
发表于 2004-6-21 05:11:08 | 显示全部楼层 |阅读模式

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

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

×
3D多义线转化2D多义线
[PHP]
;;CADALYST 09/03 AutoLISP Solutions
;;; PLINE-3D-2D.LSP - a program to convert
;;; 3D polylines to 2D
;;; Program by Tony Hotchkiss

(defun pline-3d-2d ()
  (vl-load-com)
  (setq        *thisdrawing* (vla-get-activedocument
                        (vlax-get-acad-object)
                      ) ;_ end of vla-get-activedocument
        *modelspace*  (vla-get-ModelSpace *thisdrawing*)
  ) ;_ end of setq
  (setq        3d-pl-list
         (get-3D-pline)
  ) ;_ end of setq
  (if 3d-pl-list
    (progn
      (setq vert-array-list (make-list 3d-pl-list))
      (setq n (- 1))
      (repeat (length vert-array-list)
        (setq vert-array (nth (setq n (1+ n)) vert-array-list))
        (setq lyr (vlax-get-property (nth n 3d-pl-list) 'Layer))
        (setq obj (vla-AddPolyline *modelspace* vert-array))
        (vlax-put-property obj 'Layer lyr)
      ) ;_ end of repeat
      (foreach obj 3d-pl-list (vla-delete obj))
    ) ;_ end of progn
  ) ;_ end of if
) ;_ end of pline-3d-2d

(defun get-3D-pline ()
  (setq        pl3dobj-list nil
        obj             nil
        3d             "AcDb3dPolyline"
  ) ;_ end of setq
  (setq selsets (vla-get-selectionsets *thisdrawing*))
  (setq ss1 (vlax-make-variant "ss1"))
  (if (= (vla-get-count selsets) 0)
    (setq ssobj (vla-add selsets ss1))
  ) ;_ end of if
  (vla-clear ssobj)
  (setq Filterdata (vlax-make-variant "POLYLINE"))
  (setq no-ent 1)
  (while no-ent
    (vla-Selectonscreen ssobj)
    (if        (> (vla-get-count ssobj) 0)
      (progn
        (setq no-ent nil)
        (setq i (- 1))
        (repeat        (vla-get-count ssobj)
          (setq
            obj        (vla-item ssobj
                          (vlax-make-variant (setq i (1+ i)))
                ) ;_ end of vla-item
          ) ;_ end of setq
          (cond
            ((= (vlax-get-property obj "ObjectName") 3d)
             (setq pl3dobj-list
                    (append pl3dobj-list (list obj))
             ) ;_ end of setq
            )
          ) ;_ end-of cond
        ) ;_ end of repeat
      ) ;_ end of progn
      (prompt "\nNo entities selected, try again.")
    ) ;_ end of if
    (if        (and (= nil no-ent) (= nil pl3dobj-list))
      (progn
        (setq no-ent 1)
        (prompt "\nNo 3D-polylines selected.")
        (quit)
      ) ;_ end of progn
    ) ;_ end of if
  ) ;_ end of while  
  (vla-delete (vla-item selsets 0))
  pl3dobj-list
) ;_ end of get-3D-pline


(defun get-3D-pline-old ()
  (setq no-ent 1)
  (setq        filter '((-4 . "<AND")
                 (0 . "POLYLINE")
                 (70 . 8)
                 (-4 . "AND>")
                )
  ) ;_ end of setq
  (while no-ent
    (setq ss               (ssget filter)
          k               (- 1)
          pl3dobj-list nil
          obj               nil
          3d               "AcDb3dPolyline"
    ) ;_ end-of setq
    (if        ss
      (progn
        (setq no-ent nil)
        (repeat        (sslength ss)
          (setq        ent (ssname ss (setq k (1+ k)))
                obj (vlax-ename->vla-object ent)
          ) ;_ end-of setq
          (cond
            ((= (vlax-get-property obj "ObjectName") 3d)
             (setq pl3dobj-list
                    (append pl3dobj-list (list obj))
             ) ;_ end of setq
            )
          ) ;_ end-of cond
        ) ;_ end-of repeat
      ) ;_ end-of progn
      (prompt "\nNo 3D-polylines selected, try again.")
    ) ;_ end-of if
  ) ;_ end-of while
  pl3dobj-list
) ;_ end of get-3D-pline-old

(defun make-list (p-list)
  (setq        i (- 1)
        vlist nil
        calist nil
  ) ;_ end of setq
  (repeat (length p-list)
    (setq obj         (nth (setq i (1+ i)) p-list)
          coords (vlax-get-property obj "coordinates")
          ca         (vlax-variant-value coords)
    ) ;_ end-of setq
    (setq calist (append calist (list ca)))
  ) ;_ end-of repeat
) ;_ end-of make-list

(defun c:pl32 ()
  (pline-3d-2d)
  (princ)
) ;_ end of pl32

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

已领礼包: 6530个

财富等级: 富甲天下

发表于 2004-6-21 08:29:53 | 显示全部楼层
首先,程序贴的不全,以后请使用php代码贴包含“< ”的程序。我给你补上:
[php];;CADALYST 09/03 AutoLISP Solutions
;;; PLINE-3D-2D.LSP - a program to convert
;;; 3D polylines to 2D
;;; Program by Tony Hotchkiss

(defun pline-3d-2d ()
  (vl-load-com)
  (setq        *thisdrawing* (vla-get-activedocument
                        (vlax-get-acad-object)
                      ) ;_ end of vla-get-activedocument
        *modelspace*  (vla-get-ModelSpace *thisdrawing*)
  ) ;_ end of setq
  (setq        3d-pl-list
         (get-3D-pline)
  ) ;_ end of setq
  (if 3d-pl-list
    (progn
      (setq vert-array-list (make-list 3d-pl-list))
      (setq n (- 1))
      (repeat (length vert-array-list)
        (setq vert-array (nth (setq n (1+ n)) vert-array-list))
        (setq lyr (vlax-get-property (nth n 3d-pl-list) 'Layer))
        (setq obj (vla-AddPolyline *modelspace* vert-array))
        (vlax-put-property obj 'Layer lyr)
      ) ;_ end of repeat
      (foreach obj 3d-pl-list (vla-delete obj))
    ) ;_ end of progn
  ) ;_ end of if
) ;_ end of pline-3d-2d

(defun get-3D-pline ()
  (setq        pl3dobj-list nil
        obj             nil
        3d             "AcDb3dPolyline"
  ) ;_ end of setq
  (setq selsets (vla-get-selectionsets *thisdrawing*))
  (setq ss1 (vlax-make-variant "ss1"))
  (if (= (vla-get-count selsets) 0)
    (setq ssobj (vla-add selsets ss1))
  ) ;_ end of if
  (vla-clear ssobj)
  (setq Filterdata (vlax-make-variant "POLYLINE"))
  (setq no-ent 1)
  (while no-ent
    (vla-Selectonscreen ssobj)
    (if        (> (vla-get-count ssobj) 0)
      (progn
        (setq no-ent nil)
        (setq i (- 1))
        (repeat        (vla-get-count ssobj)
          (setq
            obj        (vla-item ssobj
                          (vlax-make-variant (setq i (1+ i)))
                ) ;_ end of vla-item
          ) ;_ end of setq
          (cond
            ((= (vlax-get-property obj "ObjectName") 3d)
             (setq pl3dobj-list
                    (append pl3dobj-list (list obj))
             ) ;_ end of setq
            )
          ) ;_ end-of cond
        ) ;_ end of repeat
      ) ;_ end of progn
      (prompt "\nNo entities selected, try again.")
    ) ;_ end of if
    (if        (and (= nil no-ent) (= nil pl3dobj-list))
      (progn
        (setq no-ent 1)
        (prompt "\nNo 3D-polylines selected.")
        (quit)
      ) ;_ end of progn
    ) ;_ end of if
  ) ;_ end of while
  (vla-delete (vla-item selsets 0))
  pl3dobj-list
) ;_ end of get-3D-pline


(defun get-3D-pline-old        ()
  (setq no-ent 1)
  (setq        filter '((-4 . "<AND")
                 (0 . "POLYLINE")
                 (70 . 8)
                 (-4 . "AND>")
                )
  ) ;_ end of setq
  (while no-ent
    (setq ss               (ssget filter)
          k               (- 1)
          pl3dobj-list nil
          obj               nil
          3d               "AcDb3dPolyline"
    ) ;_ end-of setq
    (if        ss
      (progn
        (setq no-ent nil)
        (repeat        (sslength ss)
          (setq        ent (ssname ss (setq k (1+ k)))
                obj (vlax-ename->vla-object ent)
          ) ;_ end-of setq
          (cond
            ((= (vlax-get-property obj "ObjectName") 3d)
             (setq pl3dobj-list
                    (append pl3dobj-list (list obj))
             ) ;_ end of setq
            )
          ) ;_ end-of cond
        ) ;_ end-of repeat
      ) ;_ end-of progn
      (prompt "\nNo 3D-polylines selected, try again.")
    ) ;_ end-of if
  ) ;_ end-of while
  pl3dobj-list
) ;_ end of get-3D-pline-old

(defun make-list (p-list)
  (setq        i (- 1)
        vlist nil
        calist nil
  ) ;_ end of setq
  (repeat (length p-list)
    (setq obj         (nth (setq i (1+ i)) p-list)
          coords (vlax-get-property obj "coordinates")
          ca         (vlax-variant-value coords)
    ) ;_ end-of setq
    (setq calist (append calist (list ca)))
  ) ;_ end-of repeat
) ;_ end-of make-list

(defun c:pl32 ()
  (pline-3d-2d)
  (princ)
) ;_ end of pl32

(prompt "Enter PL32 to start: ")
[/php]

说正题,这个程序没有什么意义,你这是将3Dpline投影到世界坐标,得到2Dpline,已经失去了3D的意义。直接使用Flatten可以达到同样效果。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

 楼主| 发表于 2004-6-21 15:20:32 | 显示全部楼层
最初由 ll_j 发布
[B]首先,程序贴的不全,以后请使用php代码贴包含“< ”的程序。我给你补上:... 说正题,这个程序没有什么意义...[/B]

1. 怎么贴的不全, 没看出你贴的多出什么呀?!
2. 转贴此程序的目的只是给出一种思路或方法, 供大家参考. 这本身就是有意义的...
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 6530个

财富等级: 富甲天下

发表于 2004-6-21 16:49:50 | 显示全部楼层
不全的代码:
(defun get-3D-pline-old ()
(setq no-ent 1)
(setq filter '((-4 . " (0 . "POLYLINE")
(70 . 8)
(-4 . "AND>")
)
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

 楼主| 发表于 2004-6-22 04:23:18 | 显示全部楼层
最初由 ll_j 发布
[B]不全的代码:
(defun get-3D-pline-old ()
(setq no-ent 1)
(setq filter '((-4 . " (0 . "POLYLINE")
(70 . 8)
(-4 . "AND>")
) [/B]


这一段在我转贴的程序里真的都有呀! 请再zixi看看?
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 6530个

财富等级: 富甲天下

发表于 2004-6-22 09:15:42 | 显示全部楼层
有是有,不过是错误的,应该是:
[php]  (setq    filter '((-4 . "[B]<AND") [/B] (0 . "POLYLINE")
[/php]
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

 楼主| 发表于 2004-6-22 11:43:53 | 显示全部楼层
转贴前调试过此程序, 程序本身和运行无误, 怎么一贴就丢几个字符呢?
另: 当编辑我1楼的程序时发现并没有丢那几个字符? 论坛显示有问题吧?!
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 6530个

财富等级: 富甲天下

发表于 2004-6-22 12:09:29 | 显示全部楼层
不是论坛显示有问题,我想这是论坛默认“允许”使用html代码造成的,当有“<”时,会认为是html控制符,在后面加一个空格就可以显示了,不过代码就错误了,现在使用php代码可以完整显示。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 194个

财富等级: 日进斗金

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

使用道具 举报

已领礼包: 35个

财富等级: 招财进宝

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-12-18 20:28 , Processed in 0.448154 second(s), 49 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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