明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 3559|回复: 5

[分享]动态圆弧拖拉并显示圆弧半径

[复制链接]
发表于 2005-2-7 06:30:00 | 显示全部楼层 |阅读模式
我参考晓东CAD里的一个动态直线拖拉显直线长度程序,改成了动态圆弧拖拉并显示圆弧半径,这一功能不一定经常会用到,但也值得参考。 (defun c:ad ()
(setvar "CMDECHO" 0)
(setvar "osmode" 0)
(setq pt1 (getpoint "\n请输入圆弧起点: "))
(setq pt3 (getpoint "\n请输入圆弧第二点: "))
(setq pt2 (cadr (grread T 4 0)))
(setq pt2 (mapcar '+ pt2 '(0.0001 -0.0001)))
(command "Arc" pt1 pt3 pt2) (setq ent (entlast))
(setq arc0 (entget ent))
(setq r0 (rtos (cdr (assoc 40 arc0))))
;;求圆弧新的半径值并转化为字符型
(setq ts1 "R=")
(setq ts2 (strcat ts1 r0 "mm"))
(command "text" pt2 "2.5" "" ts2)
(setq tx1 (entlast))
(vla-put-color (vlax-ename->vla-object tx1) 1)
(setq tx2 (entget tx1))
(setq pick nil)
(while (not pick)
(setq p (grread t 4 0))
(princ)
(setq ip (car p))
(setq pt (cadr p))
(if (= ip 5)
;;;;;;;;;;;;;;确定为坐标移动
(progn
(setq p1 (trans pt 1 0))
;;坐标系转换(以防止更新数据表时出错)
(entdel ent)
;;删除旧的圆弧
(command "arc" pt1 pt3 p1)
(setq ent (entlast))
(setq arc0 (entget ent))
(setq r0 (rtos (cdr (assoc 40 arc0))))
;;求圆弧新的半径值并转化为字符型
(setq ts2 (strcat ts1 r0 "mm"))
(setq tx2 (subst (cons 10 p1) (assoc 10 tx2) tx2))
(setq tx2 (subst (cons 1 ts2) (assoc 1 tx2) tx2))
(entmod tx2)
;;更新文字的位置及内容 )
;;progn
)
;;if
(setq pick (= 3 ip))
;;;确定为点取坐标
)
;;while
(setvar "CMDECHO" 1)
(setvar "osmode" 37);;根据自身的需要可设置成相应的值
;;(entdel ent)
;;(entdel tx1)
;;(print ts2)
(princ)
)
"觉得好,就打赏"
    共1人打赏
发表于 2005-2-7 08:27:00 | 显示全部楼层
蛮有创意的. 呵呵. 送朵花花
发表于 2012-5-29 16:32:50 | 显示全部楼层
谢谢楼主,下载试用了
发表于 2013-8-12 15:52:15 | 显示全部楼层
谢谢楼主,下载试用看看
发表于 2022-9-7 21:06:04 | 显示全部楼层
又学了一招,顶一个
发表于 2022-9-8 08:55:20 | 显示全部楼层
这是我想要的功能。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-5-15 11:01 , Processed in 0.172981 second(s), 25 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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