找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 426|回复: 3

[求助] [求助]:分析源代码

[复制链接]
发表于 2006-5-27 23:56:02 | 显示全部楼层 |阅读模式

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

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

×
  1. (defun c: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豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!

已领礼包: 593个

财富等级: 财运亨通

发表于 2006-5-28 00:48:24 | 显示全部楼层

  1. (setq intlst (vla-intersectwith
  2.                (vlax-ename->vla-object first-object)
  3.                (vlax-ename->vla-object next-object)
  4.                k
  5.              )
  6. )
  7. (if intlst

改为

  1. (setq intlst (safearray-value
  2.                (variant-value
  3.                  (vla-intersectwith
  4.                    (vla-intersectwith
  5.                      (vlax-ename->vla-object first-object)
  6.                      (vlax-ename->vla-object next-object)
  7.                      k
  8.                    )
  9.                  )
  10.                )
  11.              )
  12. )
  13. (if intlst
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

使用道具 举报

发表于 2006-5-28 02:13:06 | 显示全部楼层
改的都不够爽,我来帮你真正精简一下

  1. (defun c:get2entinters (fst nxt k / intlst pntlst);;k=0,1,2,3
  2.     (setq intlst (vlax-invoke (vlax-ename->vla-object fst) 'intersectwith (vlax-ename->vla-object nxt) k))
  3.    (while  intlst
  4.      (setq pntlst (cons (list (car intlst) (cadr intlst) (caddr intlst)) pntlst)
  5.             intlst (cdddr intlst)
  6.       )
  7.     )
  8.   (reverse pntlst)
  9. )
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-18 22:37 , Processed in 0.165431 second(s), 38 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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