home *** CD-ROM | disk | FTP | other *** search
- (defun SST (/ a pt1 pt2 li lay li lay rn wl loop ll x xx ltlx t11 t12 tw1 tw2 tw3 n n0 sk sk2 sx tl ag ag2 jo hg th bg kw hrl)
- (setq a 0)
- (while (<= a (1- sl))
- (setq sn (ssname sj a) pt1 nil pt2 nil bg 0 ltlx nil)
- (setq s1 (entget sn) li (cdr (assoc 0 s1)) lay (cdr (assoc 8 s1)))
- (if (and (eq li "INSERT") (eq lay "PSTAIR")) (progn
- (redraw sn 3)
- (setq ne (entnext sn) s2 (entget ne))
- (if (= (type s2) 'LIST) (PROGN
- (setq in (cdr (assoc 11 s2)))
- (SETQ rn (cdr (assoc 1 s2)) wl nil loop t)
- (while loop
- (setq ll (instr 1 rn " "))
- (if (= ll 0) (setq wl (cons rn wl) loop nil)
- (setq x (substr rn 1 (1- ll)) wl (cons x wl) rn (substr rn (1+ ll) (- (strlen rn) ll)) loop t)
- )
- )
- (setq wl (reverse wl))
- (setq ltlx (nth 0 wl))
- (cond ((= ltlx "T1")
- (setq t11 (nth 1 wl) t12 (atoi (nth 2 wl)) tw1 (atoi (nth 3 wl)))
- (setq tw2 (atoi (nth 4 wl)) ag (atof (nth 5 wl)) hg (atoi (nth 6 wl)) th (atoi (nth 7 wl)) hrl (atoi (nth 8 wl)))
- (load "lisp\\sub") (sub11 t11)
- (setq t11 axdl n (length t11) n0 0 sk 0)
- (while (< n0 n)
- (setq sk (+ (nth n0 t11) sk) n0 (1+ n0))
- )
- (setq sk2 (/ sk n))
- (setq tl (+ t12 (* tw1 tw2)))
- (setq ag2 (- ag (/ pi 2.0)))
- (setq pt1 (polar in ag2 tl))
- (setq pt2 (polar pt1 ag sk))
- (setq jo (inters p1 p2 pt1 pt2))
- (if (= (type jo) 'LIST) (progn
- (if (eq fg "Col") (setq pt1 (cadr jo) pt2 (cadr in))
- (setq pt1 (car jo) pt2 (car in))
- )
- (if (and (> n 1) (or
- (and (eq px "L")
- (or (and (> pt2 pt1) (< (abs (- (car jo) (car in))) sk2))
- (and (< pt2 pt1) (> (abs (- (car jo) (car in))) sk2))
- ))
- (and (eq px "R")
- (or (and (> pt2 pt1) (> (abs (- (car jo) (car in))) sk2))
- (and (< pt2 pt1) (< (abs (- (car jo) (car in))) sk2))
- ))
- (and (eq px "U")
- (or (and (> pt2 pt1) (< (abs (- (cadr jo) (cadr in))) sk2))
- (and (< pt2 pt1) (> (abs (- (cadr jo) (cadr in))) sk2))
- ))
- (and (eq px "D")
- (or (and (> pt2 pt1) (> (abs (- (cadr jo) (cadr in))) sk2))
- (and (< pt2 pt1) (< (abs (- (cadr jo) (cadr in))) sk2))
- ))
- )
- )
- (progn (setq bg 1) (princ "\n╕├┬Ñ╠▌╞╩╟╨╬╗╓├▓╗╢╘,╞╩├µ═╝╓╨╬▐╕├┬Ñ╠▌!"))
- )
- (setq sx (+ (car jd) (abs (- pt1 ymin))))
- )
- )
- (if (and (= (type jo) 'LIST) (= bg 0)) (progn
- (if (or (eq px "L") (eq px "U"))
- (if (> pt1 pt2) (setq xx "Left") (setq xx "Right"))
- (if (> pt1 pt2) (setq xx "Right") (setq xx "Left"))
- )
- (load "lisp\\lt1") (lt1)
- ))
- (redraw sn 4)
- )
- ((= ltlx "T2")
- (setq t11 (atoi (nth 1 wl)) tw1 (atoi (nth 2 wl)) tw2 (atoi (nth 3 wl)))
- (setq tw3 (atoi (nth 4 wl)) ag (atof (nth 5 wl)) hg (atoi (nth 6 wl)) th (atoi (nth 7 wl)) hrl (atoi (nth 8 wl)))
- (setq tl (+ t11 (* tw1 tw2)))
- (setq sk (+ t11 t11 (* tw1 tw3)))
- (setq ag2 (- ag (/ pi 2.0)))
- (setq pt1 (polar in ag2 tl))
- (setq pt2 (polar pt1 ag sk))
- (setq jo (inters p1 p2 pt1 pt2))
- (if (= (type jo) 'LIST) (progn
- (if (eq fg "Col") (setq pt1 (cadr jo) pt2 (cadr in))
- (setq pt1 (car jo) pt2 (car in))
- )
- (if (or (and (eq px "L")
- (or (and (> pt2 pt1) (< (abs (- (car jo) (car in))) t11))
- (and (< pt2 pt1) (> (abs (- (car jo) (car in))) t11))
- ))
- (and (eq px "R")
- (or (and (> pt2 pt1) (> (abs (- (car jo) (car in))) t11))
- (and (< pt2 pt1) (< (abs (- (car jo) (car in))) t11))
- ))
- (and (eq px "U")
- (or (and (> pt2 pt1) (< (abs (- (cadr jo) (cadr in))) t11))
- (and (< pt2 pt1) (> (abs (- (cadr jo) (cadr in))) t11))
- ))
- (and (eq px "D")
- (or (and (> pt2 pt1) (> (abs (- (cadr jo) (cadr in))) t11))
- (and (< pt2 pt1) (< (abs (- (cadr jo) (cadr in))) t11))
- ))
- )
- (progn (setq bg 1) (princ "\n╕├┬Ñ╠▌╞╩╟╨╬╗╓├▓╗╢╘,╞╩├µ═╝╓╨╬▐╕├┬Ñ╠▌!"))
- )
- (setq sx (+ (car jd) (abs (- pt1 ymin))))
- )
- )
- (if (and (= (type jo) 'LIST) (= bg 0)) (progn
- (if (or (eq px "L") (eq px "U"))
- (if (> pt1 pt2) (setq xx "Left") (setq xx "Right"))
- (if (> pt1 pt2) (setq xx "Right") (setq xx "Left"))
- )
- (load "lisp\\lt2") (lt2)
- ))
- (redraw sn 4)
- )
- ((= ltlx "T3")
- (setq kw (nth 1 wl) t11 (atoi (nth 2 wl)) t12 (atoi (nth 3 wl)) tw1 (atoi (nth 4 wl)))
- (setq tw2 (atoi (nth 5 wl)) tw3 (atoi (nth 6 wl)) ag (atof (nth 7 wl)) hg (atoi (nth 8 wl)) th (atoi (nth 9 wl)) hrl (atoi (nth 10 wl)))
- (setq tl (+ t12 (* tw1 tw2)))
- (setq ag2 (- ag (/ pi 2.0)))
- (setq pt1 (polar in ag2 tl))
- (setq pt2 (polar pt1 ag t11))
- (if (= kw "Yes") (setq pt1 (polar pt1 (- pi ag) t11)))
- (setq jo (inters p1 p2 pt1 pt2))
- (if (= (type jo) 'LIST) (progn
- (if (eq fg "Col") (setq pt1 (cadr jo) pt2 (cadr in))
- (setq pt1 (car jo) pt2 (car in))
- )
- ; (if (or (and (eq px "L")
- ; (or (and (> pt2 pt1) (< (abs (- (car jo) (car in))) t11))
- ; (and (< pt2 pt1) (> (abs (- (car jo) (car in))) t11))
- ; ))
- ; (and (eq px "R")
- ; (or (and (> pt2 pt1) (> (abs (- (car jo) (car in))) t11))
- ; (and (< pt2 pt1) (< (abs (- (car jo) (car in))) t11))
- ; ))
- ; (and (eq px "U")
- ; (or (and (> pt2 pt1) (< (abs (- (cadr jo) (cadr in))) t11))
- ; (and (< pt2 pt1) (> (abs (- (cadr jo) (cadr in))) t11))
- ; ))
- ; (and (eq px "D")
- ; (or (and (> pt2 pt1) (> (abs (- (cadr jo) (cadr in))) t11))
- ; (and (< pt2 pt1) (< (abs (- (cadr jo) (cadr in))) t11))
- ; ))
- ; )
- ; (progn (setq bg 1) (princ "\n╕├┬Ñ╠▌╞╩╟╨╬╗╓├▓╗╢╘,╞╩├µ═╝╓╨╬▐╕├┬Ñ╠▌!"))
- ; )
- (setq sx (+ (car jd) (abs (- pt1 ymin))))
- )
- )
- (if (and (= (type jo) 'LIST) (= bg 0)) (progn
- (if (or (eq px "L") (eq px "U"))
- (if (> pt1 pt2) (setq xx "Left") (setq xx "Right"))
- (if (> pt1 pt2) (setq xx "Right") (setq xx "Left"))
- )
- (load "lisp\\lt3") (lt3)
- ))
- (redraw sn 4)
- )
- ((= ltlx "T4")
- (setq t11 (atof (nth 1 wl)) tw2 (atoi (nth 2 wl)))
- (if (eq fg "Col") (setq pt1 (cadr in))
- (setq pt1 (car in)))
- (if (or (and (eq fg "Col") (< (abs (- (car p1) (car in))) tw2)
- (< (abs (- (car p2) (car in))) tw2))
- (and (eq fg "Row") (< (abs (- (cadr p1) (cadr in))) tw2)
- (< (abs (- (cadr p2) (cadr in))) tw2)))
- (progn (load "lisp/lt4") (lt4))
- )
- (redraw sn 4)
- )
- )
- )
- )
- )
- )
- (setq a (1+ a))
- )
- )
-
- (defun newpoly (vrtlst / n)
- (setq vrtlst (reverse vrtlst) vrtlst (cons "PLINE" vrtlst))
- (foreach n vrtlst (command n))
- (command)
- )
-