声振论坛

 找回密码
 我要加入

QQ登录

只需一步,快速开始

查看: 2884|回复: 5

[AutoCAD] 三种曲线的画法,LISP语言

[复制链接]
发表于 2007-6-5 08:33 | 显示全部楼层 |阅读模式

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

您需要 登录 才可以下载或查看,没有账号?我要加入

x
  1. ;画正弦曲:x=a , y=sin a ;

  2. (defun c:zxqx(/ da bp Ai lpt bp1 bp2)

  3. (initget 1)

  4. (setq bp (getpoint "\n 起始点?:"))

  5. (initget 7)

  6. (setq da (getangle "\n 角度增量?:"))

  7. (setq Ai 0 Ae (* pi 2.0) bp1 (car bp) bp2 (car (cdr bp)))

  8. (while (< Ai Ae)

  9. (setq lpt (append lpt (list (list (+ bp1 Ai) (+ bp2 (sin Ai))))))

  10. (setq Ai (+ Ai da))

  11. )

  12. (setq lpt (append lpt (list (list (+ bp1 Ae) (+ bp2 (sin Ae))))))

  13. (setvar "cmdecho" 0)

  14. (command "pline")

  15. (foreach pt lpt (command pt))

  16. (command ^c)

  17. (command "pedit" "l" "f")

  18. (command ^c)

  19. (setvar "cmdecho" 1)

  20. )
复制代码

评分

1

查看全部评分

回复
分享到:

使用道具 举报

 楼主| 发表于 2007-6-5 08:34 | 显示全部楼层
  1. ;渐开线画法x=br*(cos(a)+a*sin(a))

  2. y=br*(sin(a)-a*cos(a));

  3. (defun c:jkx(/ ti lpt ae pt bp1 bp2)

  4. (initget 1)

  5. (setq bp (getpoint "\n 起始点?:"))

  6. (initget 7)

  7. (setq br (getreal "\n 基圆半径?:"))

  8. (initget 5)

  9. (setq ai (getangle "\n 起始角度?:"))

  10. (initget 7)

  11. (setq ae (getangle "\n 终止角度?:"))

  12. (initget 7)

  13. (setq da (getangle "\n 角度增量?:"))

  14. (setq bp1 (car bp) bp2 (car (cdr bp)))

  15. (while (< ai ae)

  16. (setq lpt (append lpt (list (list (+ bp1 (* br (+ (cos ai) (* ai (sin ai))))) (+ bp2 (* br (- (sin ai) (* ai (cos ai)))))))))

  17. (setq ai (+ ai da))

  18. )

  19. (setq lpt (append lpt (list (list (+ bp1 (* br (+ (cos ae) (* ae (sin ae))))) (+ bp2 (* br (- (sin ae) (* ae (cos ae)))))))))

  20. (setvar "cmdecho" 0)

  21. (command "pline")

  22. (foreach pt lpt (command pt))

  23. (command ^c)

  24. (command "pedit" "l" "f")

  25. (command ^c)

  26. (setvar "cmdecho" 1)

  27. )
复制代码
 楼主| 发表于 2007-6-5 08:35 | 显示全部楼层
螺旋线画法:x=r*cos(2pi/k) , y=r*sin(2pi/k) , z=(+/-)s/k .
  1. ; s:导程(+=右旋,-=左旋),k:每圈等分数。

  2. (defun c:yzlxx(/ bp r a s k n bp1 bp2 bp3 dmax di da pt lpt)

  3. (initget 1)

  4. (setq bp (getpoint "\n 螺旋线中心:"))

  5. (initget 7)

  6. (setq r (getdist bp "\n 螺旋线半径:"))

  7. (initget 3)

  8. (setq s (getreal "\n 导程:(+/右旋,-/左旋)"))

  9. (initget 7)

  10. (setq n (getreal "\n 圈数:"))

  11. (initget 6)

  12. (setq k (getint "\n 每圈等分数<36>:(宜取36的整倍数)"))

  13. (if (not k) (setq k 36))

  14. (setq bp1 (car bp) bp2 (cadr bp) bp3 (caddr bp))

  15. (setq dmax (fix(* k n)))

  16. (setq da (/(* 2 pi) k))

  17. (setq a 0)

  18. (setq di 0)

  19. (while (<= di dmax)

  20. (setq lpt (append lpt (list (list (+ bp1 (* r (cos a))) (+ bp2 (* r (sin a))) (+ bp3 (* (/ s k) di))))))

  21. (setq di (+ di 1))

  22. (setq a (+ da a))

  23. )

  24. (setvar "cmdecho" 0)

  25. (command "3dpoly")

  26. (foreach pt lpt (command pt))

  27. (command ^c)

  28. (setvar "cmdecho" 1)

  29. )
复制代码
发表于 2007-6-16 14:22 | 显示全部楼层
楼主~您这贴确实值得顶一下~
发表于 2007-7-16 16:51 | 显示全部楼层
好东西!!
发表于 2009-6-21 17:06 | 显示全部楼层
请教楼主一个问题,如何将一张图中所有直线的端点坐标导出到EXCEL中呢
您需要登录后才可以回帖 登录 | 我要加入

本版积分规则

QQ|小黑屋|Archiver|手机版|联系我们|声振论坛

GMT+8, 2024-12-1 13:11 , Processed in 0.066262 second(s), 21 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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