找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 424|回复: 2

[原创]:求两直线交点

[复制链接]
发表于 2004-9-26 23:10:27 | 显示全部楼层 |阅读模式

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

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

×
(defun c:int()
  (setq s1(entsel"请选择第一条直线:"))
  (setq s2(cadr s1))
  (setq s1(entsel"请选择第二条直线:"))
  (setq s3(cadr s1))
  (setq s4(osnap s2 "endp"))
  (setq s5(osnap s2 "midp"))
  (setq s6(osnap s3 "endp"))
  (setq s7(osnap s3 "midp"))
  (setq s41(nth 0 s4))
  (setq s42(nth 1 s4))
  (setq s51(nth 0 s5))
  (setq s52(nth 1 s5))
  (setq s61(nth 0 s6))
  (setq s62(nth 1 s6))
  (setq s71(nth 0 s7))
  (setq s72(nth 1 s7))
  (setq xs4(list s41 s42))
  (setq xs5(list s51 s52))
  (setq xs6(list s61 s62))
  (setq xs7(list s71 s72))
  (setq lname(getvar "clayer"))
  (command"layer" "m" "_aid" "c" "4" "" "")
  (setvar "osmode" 0)
  (setq s1(inters xs4 xs5 xs6 xs7 nil))
  (command "insert" "int" s1 "" "" "")
  (command "layer" "s" lname "")
  (setvar "osmode" 64)
  )
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
发表于 2004-9-27 09:02:19 | 显示全部楼层
楼主是不是可以写的再详细一点
光给段源代码不知道怎么用啊
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2004-9-27 17:42:39 | 显示全部楼层

Re: [原创]:求两直线交点

最初由 cqxt00 发布
[B](defun c:int()
  (setq s1(entsel"请选择第一条直线:"))
  (setq s2(cadr s1))
  (setq s1(entsel"请选择第二条直线:"))
  (setq s3(cadr s1))
  (setq s4(osnap s2 "endp"))
  (setq s5(osnap s2 "midp"))
... [/B]

楼主的思路的确很特别,不过学Lisp还是要学习用下面的方法。

  1. (defun c:int (/ ln1 ln2 l1sp l1ep l2sp l2ep intpt lname oldos)
  2.   (if (and (setq ln1 (entsel "请选择第一条直线:"))
  3.            (setq ln2 (entsel "请选择第二条直线:"))
  4.       )
  5.     (progn
  6.       (setq l1sp (cdr (assoc 10 (setq el1 (entget (car ln1)))));Line1 startpoint
  7.             l1ep (cdr (assoc 11 el1));line1 endpoint
  8.             l2sp (cdr (assoc 10 (setq el2 (entget (car ln2)))));line2 startpoint
  9.             l2ep (cdr (assoc 11 el2));line2 endpoint
  10.       )
  11.       (setq intpt (inters l1sp l1ep l2sp l2ep nil));inters point
  12.       (setq lname (getvar "clayer");crruct layer
  13.             oldos (getvar "osmode");crruct osnap
  14.       )
  15.       (command "layer" "m" "_aid" "c" "4" "" "")
  16.       (setvar "osmode" 0)
  17.       (command "insert" "int" intpt "" "" "")
  18.       (setvar "clayer" lname);restore layer
  19.       (setvar "osmode" oldos);restore osnap
  20.     )
  21.   )
  22.   (princ)
  23. )
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-24 20:35 , Processed in 0.284613 second(s), 36 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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