找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1743|回复: 3

[LISP函数]:轉貼:兩實體交點集

[复制链接]

已领礼包: 2个

财富等级: 恭喜发财

发表于 2005-12-14 11:22:03 | 显示全部楼层 |阅读模式

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

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

×
Copyright   :   MENZI ENGINEERING GmbH, Switzerland
[PHP]; -- Function MeGetInters
; Returns all intersection points between two objects.
; Arguments [Typ]:
;   Fst = First object [VLA-OBJECT]
;   Nxt = Second object [VLA-OBJECT]
;   Mde = Intersection mode [INT]
;         Constants:
;         - acExtendNone           Does not extend either object.
;         - acExtendThisEntity     Extends the Fst object.
;         - acExtendOtherEntity    Extends the Nxt object.
;         - acExtendBoth           Extends both objects.
; Return [Typ]:
;   > List of points '((1.0 1.0 0.0)... [LIST]
;   > False if no intersection found
; Notes:
;   - None
;
  
(defun MeGetInters (Fst Nxt Mde / IntLst PntLst)

(setq IntLst (vlax-invoke Fst 'IntersectWith Nxt Mde))
(if IntLst
  (progn
   (repeat (/ (length IntLst) 3)
    (setq PntLst (cons
                  (list (car IntLst) (cadr IntLst) (caddr IntLst))
                  PntLst
                 )
          IntLst (cdddr IntLst)
    )
   )
   (reverse PntLst)
  )
)
)[/PHP]
調用格式:
(MeGetInters (vlax-ename->vla-object (car (entsel)))(vlax-ename->vla-object (car (entsel))) acExtendBoth)
修改一下,使調用更簡單.
[PHP](defun th-get2entinters (fst nxt k / intlst pntlst)
(if (= k 0)
    (setq k acextendnone)
  )
  (if (= k 1)
    (setq k acextendthisentity)
  )
  (if (= k 2)
    (setq k acextendotherentity)
  )
  (if (= k 3)
    (setq k acextendboth)
  )
  (setq intlst (vlax-invoke (vlax-ename->vla-object fst)  'intersectwith  (vlax-ename->vla-object  nxt) k))  
  (if intlst
    (progn
      (repeat (/ (length intlst) 3)
        (setq pntlst (cons (list (car intlst) (cadr intlst) (caddr intlst))
                           pntlst
                     )
              intlst (cdddr intlst)
        )
      )
      (reverse pntlst)
    )
  )
)[/PHP]
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
发表于 2006-1-4 12:42:08 | 显示全部楼层
好贴
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2006-1-5 08:34:17 | 显示全部楼层
intlst返回的应该是安全数组吧,(length intlst)好像有问题
稍微改了一下
  1. (defun get2entinters (fst nxt k / mode intlst pntlst)
  2.   (setq  mode '(acextendnone acextendthisentity acextendotherentity acextendboth))
  3.   (setq k (eval(nth k mode)))
  4.   (setq intlst (vla-intersectwith (vlax-ename->vla-object fst) (vlax-ename->vla-object  nxt) k))
  5.    (if intlst     
  6.     (progn
  7.       (setq intlst(vlax-safearray->list(vlax-variant-value intlst)))
  8.       (repeat (/ (length intlst) 3)
  9.       (setq pntlst (cons (list (car intlst) (cadr intlst) (caddr intlst))
  10.                pntlst
  11.              )
  12.           intlst (cdddr intlst)
  13.     )
  14.       )
  15.       (reverse pntlst)
  16.     )
  17.   )
  18. )


如果对相交模式熟悉的话,程序前两行也可以省略
  1.   (defun get2entinters (fst nxt k / mode intlst pntlst);;;k=0,1,2,3
  2.   (setq intlst (vla-intersectwith (vlax-ename->vla-object fst) (vlax-ename->vla-object  nxt) (eval k)))
  3.    (if intlst     
  4.     (progn
  5.       (setq intlst(vlax-safearray->list(vlax-variant-value intlst)))
  6.       (repeat (/ (length intlst) 3)
  7.       (setq pntlst (cons (list (car intlst) (cadr intlst) (caddr intlst))
  8.                pntlst
  9.              )
  10.           intlst (cdddr intlst)
  11.     )
  12.       )
  13.       (reverse pntlst)
  14.     )
  15.   )
  16. )
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 3191个

财富等级: 富可敌国

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-22 06:23 , Processed in 0.197802 second(s), 37 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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