找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 778|回复: 5

[LISP函数]:不用donut命令生成钢筋点

[复制链接]
发表于 2009-1-13 23:43:01 | 显示全部楼层 |阅读模式

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

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

×
;不用donut命令生成钢筋点(1:100)
(defun c:ingjd()
(setvar "cmdecho" 0)
(setq pt (reverse (cdr (reverse (getpoint "\n指定插入点:")))))
(setq pt1 (polar pt pi 20))
(setq pt2 (polar pt 0 20))
(command "layer" "m" "钢筋" "c" 1 "钢筋" "")
(setq tab (list '(0 . "LWPOLYLINE")
                '(100 . "AcDbEntity")
                                                 '        (100 . "AcDbPolyline")
                                                 '(90 . 2)
                                                 '(70 . 1)
                                                 (cons 10 pt1)
                                                 '(40 . 40.0)
                                                 '(41 . 40.0)
                                                 '(42 . 1.0)
                                                 (cons 10 pt2)
                                                 '(40 . 40.0)
                                                 '(41 . 40.0)
                                                 '(42 . 1.0)
                                )
)
                (entmake tab)
(setvar "cmdecho" 1)
(princ)
)
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!

已领礼包: 2个

财富等级: 恭喜发财

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

使用道具 举报

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

使用道具 举报

已领礼包: 593个

财富等级: 财运亨通

发表于 2009-1-14 11:35:42 | 显示全部楼层
还可以用 Vla

  1. (defun c:tt (/ p p1 p2 pl)
  2.   (while (setq p (getpoint "\nInsert Point: "))
  3.     (progn
  4.       (setq p1 (polar p 0. 20)
  5.             p2 (polar p pi 20)
  6.       )
  7.       (setq pl (vla-addlightweightpolyline
  8.                  *modelspace*
  9.                  (vlax-make-variant
  10.                    (vlax-safearray-fill
  11.                      (vlax-make-safearray vlax-vbdouble '(0 . 3))
  12.                      (list (car p1) (cadr p1) (car p2) (cadr p2)  )
  13.                    )
  14.                  )
  15.                )
  16.       )
  17.       (vla-put-closed pl :vlax-true)
  18.       (vla-setbulge pl 0 1.)
  19.       (vla-setbulge pl 1 1.)      
  20.       (vla-put-ConstantWidth pl 40.)
  21.     )
  22.   )
  23.   (princ)
  24. )
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2009-1-14 12:45:49 | 显示全部楼层
不介意我做个广告。

[分享]学习CAD二次开发源码
http://www.tstmr.com/display.asp ... &b=7&t=3073

;;;画点钢筋

(defun C:TT1 (/ D)
  (setvar "CMDECHO" 0) ;_关闭回显,针对COMMAND
  (if (setq D (getdist "\n指定点钢筋直径:"))
    (command "._DONUT" 0 D PAUSE)
  )
  (princ) ;_静默退出
)
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2009-1-14 22:14:02 | 显示全部楼层
  1. [FONT=courier new](defun c:test ()
  2.   (cmdla0)
  3.   (SETQ dist (UDIST 7 "" "点钢筋直径<输入或鼠标直接量取>" dist nil))
  4.   (while (setq pt (getpoint "\n位置点: "))
  5.     (command "DONUT" 0 dist pt "")
  6.   )
  7.   (cmdla1)
  8. )[/FONT]
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-16 10:16 , Processed in 0.312256 second(s), 41 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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