明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 1003|回复: 3

[求助]关于圆弧的程序!!

[复制链接]
发表于 2007-12-28 20:10 | 显示全部楼层 |阅读模式

这代码不知道是那位版主写的,只有内切功能,把外切也能做出来吗?

(defun GetInterPoint (ent1 ent2 / ax_ent_1 ax_ent_2 intpoints points i)
(setq ax_ent_1 (vlax-ename->vla-object ent1)
ax_ent_2 (vlax-ename->vla-object ent2)
)
(setq intpoints (vla-intersectwith ax_ent_1 ax_ent_2 acextendnone))
(setq intpoints (vlax-variant-value intpoints))
(setq i 0)
(if (> (vlax-safearray-get-u-bound intpoints 1) 0)
(repeat (/ (+ 1
(- (vlax-safearray-get-u-bound intpoints 1)
(vlax-safearray-get-l-bound intpoints 1)
)
)
3
)
(setq points (append points (list (list
(vlax-safearray-get-element intpoints i)
(vlax-safearray-get-element intpoints (+ i 1))
(vlax-safearray-get-element intpoints (+ i 2))
)))
)
(setq i (+ 3 i))
)
)
points
)

(defun c:DAC ( / ent pt r entc entl pts i)
(setq ent (car (entsel "\n选择直线或圆弧...")))
(setq pt (getpoint "\n输入通过点:"))
(setq r (getreal "\n输入半径:"))
(setvar "cmdecho" 0)
(command "_.circle" pt r)
(setq entc (entlast))
(command "_.offset" r ent pt "")
(setq entl (entlast))
(setq pts (GetInterpoint entc entl))
(entdel entc)
(entdel entl)
(setq i 0)
(repeat (length pts)
(setq pt (nth i pts))
(command "_.circle" pt r)
(setq entc (entlast))
(if (= (length (GetInterpoint entc ent)) 0) (entdel entc))
(setq i (1+ i))
)
(princ)
)

发表于 2007-12-28 22:16 | 显示全部楼层
本帖最后由 作者 于 2007-12-28 22:19:57 编辑

不用这么复杂吧.LOOK
  1. (defun c:test ()
  2.   (if (and (setq ent (entsel "\nselect circle:"))
  3.     (setq en (car ent))
  4.     (setq pt (getpoint "\npick a point:"))
  5.     (setq r (getreal "\ninput radius:"))
  6.       )
  7.     (progn
  8.       (setq os (getvar "osmode"))
  9.       (setvar "osmode" 0)
  10.       (command ".undo" "be" ".line" (cdr (assoc 10 (entget en))) pt "")
  11.       (setq en1 (entlast) obj-en1 (vlax-ename->vla-object en1))
  12.       (command ".lengthen" "de" r (cdr (assoc 11 (entget en1))) "" ".circle" (cdr (assoc 11 (entget en1))) r)
  13.       (command ".lengthen" "de" (- 0 r r) (cdr (assoc 11 (entget en1))) "" ".circle" (cdr (assoc 11 (entget en1))) r ".undo" "end")
  14.       (entdel en1)
  15.       (setvar "osmode" os)
  16.     )
  17.   )
  18.   (princ)
  19. )
 楼主| 发表于 2007-12-29 07:26 | 显示全部楼层
本帖最后由 作者 于 2007-12-29 7:38:34 编辑

谢谢楼上的回复,但你的程序我没法用,我的意思是过一点作圆弧跟直线.圆弧相切(包括外切,内外)

本帖子中包含更多资源

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

x
 楼主| 发表于 2007-12-30 21:14 | 显示全部楼层
没人能帮我吗?这里的版主呢??
您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|CAD论坛|CAD教程|CAD下载|联系我们|关于明经|明经通道 ( 粤ICP备05003914号 )  
©2000-2023 明经通道 版权所有 本站代码,在未取得本站及作者授权的情况下,不得用于商业用途

GMT+8, 2024-5-12 19:55 , Processed in 0.156079 second(s), 26 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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