CAD设计论坛

 找回密码
 立即注册
论坛新手常用操作帮助系统等待验证的用户请看获取社区币方法的说明新注册会员必读(必修)
查看: 1522|回复: 2

[求助] AutoCADLISP使用中的问题

[复制链接]
发表于 2010-5-13 18:22 | 显示全部楼层 |阅读模式
本人制作一路桥专业使用的lisp函数,功能:依据输入的路线交点参数算要求点的坐标,并在绘图区绘出图形。
0 ~% t8 R5 r1 r$ t+ W' e1 h但是在使用中发现多次发现,适合一次调用,多次调用时就出现计算坐标结果正确,但是就是部分点绘到一块去了(如图):
; a3 ?* p9 x# K问题出在使用自动序列时,第一次计算,计算的X、Y、方位角值均正确,绘出的图形也没有错误,可若是不重新启动CAD的话,再调用dqx命令就可能出现计算的坐标及方位角均正确,绘出的图形重叠显示。我试验三次的桩号间距分别为5、2.5、1,到桩号为1的时候就出现重叠了,再继续下去也是结果正确绘图重叠。特点好似桩号间距递增(如5、10、15、20……)不出现问题,但桩号间距递减(如10、5、2.5、1)就出现问题了。不能像CAD命令那样在不重启CAD的情况下多次使用。
6 E( L  y% A. U% [4 h$ d6 x2 A1 i, B# V0 @
: O" C. _$ H: a0 A, \4 M% o( l
函数代码如下:(参数区我已经赋值)+ N) |" f) T$ u# Y. J: m
(defun c:dqx( / qs qz qszb qs_a qsr qzr k ls ma mi dzh dzh1 jl j n )+ A& D2 @9 A2 {
  (setvar "cmdecho" 0)
* G4 }  o: T; Q2 F' V( N, E  (princ "\n-------------------------------------------------------------")
  y; p& d; j: e) F) G  (princ "\n    (^_^) 于森制作,欢迎使用。[email protected] (^_^) ")
! `) f( E4 R2 W3 H. E  (princ "\n-------------------------------------------------------------")7 z' j. M' E) W+ p8 |: ]
  ;(setq qs (getreal "\n输入曲线始点桩号:"))
7 M7 v+ G- Q9 N7 p+ h  (setq qs 25650.926)
- U( L" U- [7 }, P, D8 @7 C  ;(setq qz (getreal "\n输入曲线终点桩号:"))  X) D: [/ P- q' M. F" t. N3 F# o
  (setq qz 25900.926)
1 T6 a; P3 }: L! U  ;(setq qszb (getpoint "\n输入或拾取曲线始点坐标:"))
9 s  E; y2 i9 u. E, a2 U5 ^$ a% H  (setq qszb '( 3252647.051 381399.471))
. ?9 y3 z! Q0 k& e  ;(setq qs_a (getreal "\n输入曲线始点顺曲线桩号递增方向的计算方位角(弧度):")), b. f% q# `' s! p4 y4 I
  (setq qs_a 2.907134)& L" V0 }  |5 x) p( H: Z  |
  (if (> qs qz) (setq qs_a (+ qs_a pi)))0 J: ]: S+ D4 P$ o: ^" s
  ;(setq qsr (getreal "\n输入曲线始点半径(半径=∞时为0):"))2 ?1 N5 {3 J" @* M5 v- d
  (setq qsr 3650)
0 ?4 b& p' _1 ^& g2 x# l  N  `* U  (if (= qsr 0) (setq qs_ql (/ 1 10000000)) (setq qs_ql (/ 1 qsr)))
# d; g( u% |! J0 E" g: p  _9 |  ;(setq qzr (getreal "\n输入曲线终点半径(半径=∞时为0):"))
# b) D+ @+ A! h( n1 }1 c  (setq qzr 1295.3)
* Q; B/ `$ G9 R" _: E% d* j& ~  (if (= qzr 0) (setq qz_ql (/ 1 10000000)) (setq qz_ql (/ 1 qzr)))* d/ o' c3 w/ j
  ;(setq k (getreal "\n选择顺曲线桩号递增方向的转向[左(-1)\\右(1)]:"))2 f- g2 I2 c* w4 p5 X' |
  (setq k -1)
3 X0 w5 Z8 G& v. U6 o  (setq ls (- qz qs))
7 R# [5 f- _! u- a9 {  (setq dzh qs)
+ y' P5 i! T+ K. A$ J5 j# x+ ]) n5 h  (setq ma (max qs qz) mi (min qs qz))
' h! y. m: G6 L5 z! W+ h8 w# g  (princ "\n-------------------------------------------------------------"), ]4 B# f2 J0 ^6 \1 J7 i1 b- Y
  (princ "\n       开始桩号坐标计算,请输入曲线始点至终点间的桩号!  ")! f/ A& H; e6 ?; H+ Q' P4 ?  A
  (princ "\n-------------------------------------------------------------")
6 Q4 m3 Q. U; Y0 s+ z  (setq dzh (getreal "\n输入桩号[自动序列(-2)]:"))
. |+ q' I+ J1 m6 ~; I  (if (= dzh -2)) K- B1 ]7 G3 h  Q: z
    (progn0 T% Q+ v9 @" i! t. ?$ m
      (setq jl (getreal "\n输入自动序列的桩号间距:"))2 @0 S5 A# j7 K1 B
      (setq j 0)" D7 W2 t! Y7 C' M  G
      (setq dzh (+ 10 (* 10 (fix (/ mi 10)))))
/ a. F( }5 m3 R+ f' @      (zbjs dzh)& q/ g  v, r) M
      (setq n (- (fix (/ (- (fix ma) dzh) jl)) 1))* }1 Y4 i, T5 M1 C! W
      (while (<= j n)
8 f( ^% a% n0 X2 z; D. J (setq dzh1 (+ dzh (* j jl))). U- i/ u: M) N7 T
(setq j (+ 1 j))
" e. g9 x/ p; B/ Z$ ~* ?  t (zbjs dzh1)) e. T: y4 D: k
). V9 U$ N, ]* H6 s7 p
      )
! R; {( h; M% @    (setq dzh ma)
& x3 S  z. H! ?0 v+ `4 o+ J6 |  L    )* x7 y1 T7 f4 |& y% @( b$ e
  (while (/= dzh -1)
3 p9 t5 L/ w8 o8 w, A    (if (or (> dzh ma) (< dzh mi))
( U& u  h5 C/ B1 K7 z+ |5 `9 v" `8 C      (princ "\n提示:输入桩号不在曲线始点至终点间,请重新输入!")/ F5 d* G1 |) D4 H1 F7 C* `
      (zbjs dzh), o9 R+ e3 \6 k2 J- a
      )
, Q; V, r' \' G* H4 m5 x! L  d# t    (setq dzh (getreal "\n输入下一个桩号[放弃(-1)]:"))
, |' j0 ~2 J7 y' ]1 S6 @$ y  ): A  I5 a: Q1 ~, J6 W
  (command "zoom" "e")" T2 x; t9 ~( z. {1 Y. e# R/ T
  (setvar "cmdecho" 1)
) {4 b5 [; w' Z" x  (princ)8 Y% a2 W5 h6 m& f* K9 l- M5 D+ @
  )7 b4 s) p9 D3 y# }% E3 X2 Q7 F( r
(defun zbjs(zh / l a i ac as p a_f x y x1 y1 xy zh0 zh1 zh2 a5 a6 a7 ), v/ D* C! \- }* J& C( V
  (setq l (- zh qs))
( u( q) Y7 T/ Q4 O) B  (setq a (list 1 2 3 4))
& }( Q$ \' ~* a0 x$ Q  (setq i 1 ac 0 as 0)
: ~1 R6 B3 U3 r9 p8 ~  (setq xy (list "" ""))0 Q9 B0 a' i& b5 ?
  (while (<= i 4); b- |1 n& c0 b# M
    (setq p (+ qs_ql (* (/ (* (/ l 4) i) ls) (- qz_ql qs_ql))))
1 n. h" c7 A  z' C2 ?    (setq a_f (+ qs_a (* k (/ (* (+ p qs_ql) (* (/ l 4) i)) 2))))
& N# f0 l5 q7 C& {    (if (= i 2) (setq ac (+ ac (* 2 (cos a_f))) as (+ as (* 2 (sin a_f)))))
$ ~# _" `; }6 H: W' |+ [7 E    (if (= (rem i 2) 1) (setq ac (+ ac (* 4 (cos a_f))) as (+ as (* 4 (sin a_f)))))0 @. `& Q. y- N, U& A' T1 _7 t
    (setq i (1+ i))
5 h* m3 c- ?4 U* M- g: a1 R    )
; Y$ `/ `8 P4 l5 |% b( N; c  (setq ac (+ ac (cos qs_a) (cos a_f)) as (+ as (sin qs_a) (sin a_f)))2 C8 c/ m. M4 _7 X/ f% O- I3 Y. ]9 {. ~
  (setq x  (+ (car qszb) (* (/ (abs l) 12) ac)))
: L% P  m. G/ Z% C7 N  (setq y (+ (cadr qszb) (* (/ (abs l) 12) as)))
8 ~9 Y9 s7 b  I, b! p3 ~; I" ^7 j  ;(setq x1 (rtos x 2 5) y1 (rtos y 2 5))$ z+ Q1 }- T+ v, i* |# |5 `
  (setq xy (list x y))4 \9 m) i* t. u' [& x) a/ a
  (command "point" xy)
# u7 ^( I* N8 N' F0 ~  (setq zh0 (rtos (fix (/ zh 1000)) 2 0))
1 e3 r4 L+ B. \2 M5 A4 H9 H  (setq zh1 (rtos(- zh (* 1000 (fix (/ zh 1000)))) 2 3))
3 [) ~) K) s2 U9 f: b  (setq zh2 zh1)% w3 \6 X8 r  {) n; C; J
  (setq a5 a_f)
# C$ ^  K9 \4 B0 b4 M. G* H  (if (> qs qz) (setq a5 (- a5 pi)))- N5 m( b/ Z8 _' f0 n$ {
  (if (> a5 (* 2 pi)) (setq a5 (- a5 (* 2 pi))))2 ?: O; H; @' I0 D5 Y4 q2 X. p
  (if (< a5 0) (setq a5 (+ a5 (* 2 pi)))). s; S8 p# q" W5 p
  (setq a6 (rtos a5 2 6))
5 H% b% E" u/ x: A- G- U  (setq zh1 (strcat " K" zh0 "+" zh1 " A=" a6 "r"))
* X2 S* V2 `: _% J  (setq a7 (rtos (- (* a5 57.295779513) 90) 2 6))- v% W- E) y: v' b9 g
  (command "text" xy "0.25" a7 zh1)
8 z( v# I2 X- t$ Z: X* m$ y2 I4 |  (setq x1 (rtos x 2 4) y1 (rtos y 2 4))! o. d4 c! E7 c
  (setq a5 (* a5 57.295779513))
: A" ]- u2 }3 e+ z/ r4 i  (setq a5 (rtos a5 2 6))6 T! J* z& F# C8 v! a* ^' Z
  (princ (strcat "\n结果:" " K" zh0 "+" zh2 "  X=" x1 "  Y=" y1 "  A=" a5" 度\n" ))2 d) [2 ^+ J1 y( O9 ]
  )

本帖子中包含更多资源

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

x
发表于 2010-5-13 18:28 | 显示全部楼层
您先关闭捕捉再试
 楼主| 发表于 2010-5-13 18:45 | 显示全部楼层

回复 #2 Camello 的帖子

谢谢,我将对象捕捉关掉就可以了。但是不明白这个和捕捉怎么有关系了,我绘图可指定的绝对坐标,怎么还能绘到一块去了?
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关于|免责|隐私|版权|广告|联系|手机版|CAD设计论坛

GMT+8, 2025-2-19 06:17

CAD设计论坛,为工程师增加动力。

© 2005-2025 askcad.com. All rights reserved.

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