找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 818|回复: 3

[讨论]:两圆的外公切线

[复制链接]

已领礼包: 111个

财富等级: 日进斗金

发表于 2005-11-9 17:24:34 | 显示全部楼层 |阅读模式

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

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

×
;两圆的外公切线
(defun c:cc()
   (setq xtblm '("cmdecho" "osmode")
         xtblz (mapcar 'getvar xtblm)
   )
   (mapcar 'setvar xtblm '(0 0))
   (while (progn (setq en1 (entsel "\n请选取第一个圆:"))
                 (not (if (= en1 nil)
                         nil
                         (= (cdr (assoc 0 (entget (car en1)))) "CIRCLE"))
                 )
          )
          (princ "\n你选取的不是圆或者未选取任何图元,请重新选取第一个圆!")
   )
   (while (progn (setq en2 (entsel "\n请选择第二个圆:"))
                 (not (if (= en2 nil)
                         nil
                         (= (cdr (assoc 0 (entget (car en2)))) "CIRCLE"))
                 )
          )
          (princ "\n你选取的不是圆或者未选取任何图元,请重新选取第二个圆!")
   )
   (setq db1 (entget (car en1))
         o1 (cdr (assoc 10 db1))
         r1 (cdr (assoc 40 db1))
         db2 (entget (car en2))
         o2 (cdr (assoc 10 db2))
         r2 (cdr (assoc 40 db2))
   )
   (if (< r1 r2)
       (progn
          (setq oc o1  o1 o2  o2 oc
                oc r1  r1 r2  r2 oc
          )
       )
   )
   (setq dr (- r1 r2)  ang (angle o1 o2)  dd (distance o1 o2)
         b  (- (* 0.5 pi) (atan (/ dr (sqrt (- (* dd dd) (* dr dr))))))
   )
   (command "_line" (polar o1 (+ ang b) r1) (polar o2 (+ ang b) r2) ""
            "_line" (polar o1 (- ang b) r1) (polar o2 (- ang b) r2) ""
   )
   (mapcar 'setvar xtblm xtblz)(princ)
)
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
发表于 2005-11-19 23:29:13 | 显示全部楼层
编得真好,我也编了个,不过是有acos来算的,不如atan好用。
向你学习!
建议斑竹加MONEY
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2005-11-20 00:48:41 | 显示全部楼层
非计算法:
  1. [FONT=courier new]
  2. (load "xyp_lib.vlx")
  3. ;|加载通用函数(可在签名栏直接下载)
  4. 如果已经下载xyp_lib并放到搜索路径下可以不再下载!
  5. 利用以下任何一种方式(首选第一种)即可加载和运行通用函数内的所有子程序:
  6. ★1·在acad.lsp中增加(load"xyp_lib")
  7. ■2·在每个程序内增加(load"xyp_lib")
  8. ■3·在command下,输入(load"xyp_lib")
  9. ■4·在菜单.mnl中增加(load"xyp_lib")
  10. ■5·将xyp_lib.vlx文件直接拽到cad屏幕
  11. [COLOR=red] ★通用函数下载地址:[/COLOR]
  12. [url]http://www.xdcad.net/forum/attachment.php?s=&postid=1606661[/url]
  13. |;

  14. ;;两圆的外公切线
  15. (defun c:test ()
  16.   (cmdla0)
  17.   (setvar "osmode" 0)
  18.   (setq        e1   (entget (car (usel1 0 "CIRCLE" "圆")))
  19.         e2   (entget (car (usel1 0 "CIRCLE" "圆")))
  20.         o1   (cdr (assoc 10 e1))
  21.         r1   (cdr (assoc 40 e1))
  22.         o2   (cdr (assoc 10 e2))
  23.         r2   (cdr (assoc 40 e2))
  24.         ang  (angle o1 o2)
  25.         pt11 (polar o1 (+ ang (* pi 0.5)) r1)
  26.         pt12 (polar o1 (- ang (* pi 0.5)) r1)
  27.         pt21 (polar o2 (+ ang (* pi 0.5)) r2)
  28.         pt22 (polar o2 (- ang (* pi 0.5)) r2)
  29.   )
  30.   (if (not (equal o1 o2))
  31.     (progn
  32.       (command "line" "tan" pt11 "tan" pt21 "")
  33.       (command "line" "tan" pt12 "tan" pt22 "")
  34.     )
  35.     (princ "\n两圆同心!")
  36.   )
  37.   (cmdla1)
  38. )[/FONT]
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-9-28 20:01 , Processed in 0.358685 second(s), 38 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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