home *** CD-ROM | disk | FTP | other *** search
- (vmon)
-
- (defun inwerr(s)
- (if (/= s "Function cancelled")
- (princ (strcat "\nError:" s))
- )
- (command)
- (command "layer" "s" "0" "")
- (command "text" "s" "hz")
- (command)
- (setvar "pickbox" pib)
- (setvar "cmdecho" 1)
- (setq *error* oer)
- (princ)
- )
-
- (setq wmes1 "C-1" whgt "900")
-
- (defun C:INSWIN(/ rn wlist oer pib x fg loop lop llp lp lpp p insp p1 p2 p3 p4 p5 p6 p7 p8 int1 int2 pins sp ep sp1 ep1 sp2 ep2 sp3 ep3 sp4 ep4 mp mp1 mp2 sn sn1 sn2 en en1 ename ename1 elay elay1 ang ang1 iang wname insx insy insz insz0
- wlength whight wthick xh one one0 o1 o2 o3 o4 mc wlt l n n0 kword pl a1 a2 d1 d2 bn batt r1 r2 r3 r4 sa1 ea1 dr ma1 ss)
- (setvar "CMDECHO" 0)
- (setq pib (getvar "pickbox"))
- (setq loop t fg t oer *error* *error* inwerr)
- (while loop
- (princ "\n┴╨▒φ?/╫░╚δL/┤µ┼╠S/╘∞▒φM/┤░╠¿╕▀H/═╦│÷X/├┼┤░╨┼╧ó\n╚▒╩í <")
- (princ wmes1)
- (initget "? L S H M X")
- (setq x (strcase (getstring ">:")))
- (if (/= x "") (setq wmes1 x))
- (inswin0)
- )
- (inswin1)
- (command "layer" "s" "0" "")
- (setvar "pickbox" pib)
- (setvar "CMDECHO" 1)
- (setq *error* oer)
- (princ)
- )
-
- (defun inswin0()
- (cond
- ((= wmes1 "H") (princ "\n┤░╠¿╕▀ <")
- (princ whgt)
- (setq x (getstring ">: "))
- (if (/= x "") (setq whgt x)) )
- ((= wmes1 "L") (setq lop t)
- (while lop
- (setq fnm (getstring "\n╬─╝■├√: "))
- (if (findfile (strcat fnm ".mc")) (progn
- (setq mclist nil)
- (setq f (open (strcat fnm ".mc") "r"))
- (while (/= (setq rn (read-line f)) nil)
- (strdv rn)
- (setq mclist (cons wlist mclist))
- )
- (close f)
- (setq lop nil))
- (princ "**╬─╝■├╗╒╥╡╜!**"))
- ))
- ((= wmes1 "S") (setq lop t)
- (while lop
- (setq fnm (getstring "\n╬─╝■├√: "))
- (if (findfile (strcat fnm ".mc")) (progn
- (initget "Y N")
- (setq x (getkword "**╬─╝■╥╤┤µ╘┌, ╓╪╨┤┬≡ <N>**"))
- ) (setq x "Y"))
- (if (= x "Y") (progn
- (setq f (open (strcat fnm ".mc") "w"))
- (setq n 0 l (length mclist))
- (repeat l
- (setq one (nth n mclist))
- (write-line (strcat (nth 0 one) " " (nth 1 one) " " (nth 2 one) " " (nth 3 one)) f)
- (setq n (1+ n))
- )
- (close f)
- (setq lop nil)
- ))
- ) )
- ((= wmes1 "M") (princ "\n├┼┤░╨═║┼ <C-1>:")
- (setq x (strcase (getstring)))
- (if (= x "") (setq xh "C-1") (setq xh x))
- (if (setq one (assoc xh mclist)) (progn
- (setq lop t)
- (while lop
- (princ "\n├┼┤░╩²╛▌ <")
- (setq one0 (cdr one) o1 (nth 0 one0) o2 (nth 1 one0) o3 (nth 2 one0))
- (princ (setq mc (strcat (strcase o1) "=" o2 "*" o3)))
- (setq x (strcase (getstring ">:")))
- (if (= x "") (setq mc mc) (setq mc x))
- (inchkmc mc)
- )
- (setq mclist (subst (cons xh wlt) one mclist))
- )
- (progn ;else
- (setq lop t)
- (while lop
- (while (= (setq x (strcase (getstring "\n├┼┤░╩²╛▌:"))) ""))
- (inchkmc x))
- (setq mclist (cons (cons xh wlt) mclist))
- )
- ) ;endif
- ) ;end cond1
- ((= wmes1 "?") (setq l (length mclist) n 0)
- (setq wmes "N")
- (if (> l 0) (progn
- (princ "\n**╨═║┼ ┐Θ├√ ┐φ╢╚ ╕▀╢╚ **")
- (repeat l
- (setq x (nth n mclist))
- (princ "\n ")
- (setq n0 0)(repeat (length x) (princ (read (nth n0 x))) (princ " ") (setq n0 (1+ n0)))
- (setq n (1+ n))
- ))
- (princ "\n*├┼┤░▒φ╓╨╬▐╩²╛▌*")
- ))
- ((= wmes1 "X") (setq loop nil fg nil))
- (t (if (assoc wmes1 mclist) (setq loop nil) (princ "*├╗╒╥╡╜╕├├┼┤░*")))
- )
- )
-
- (defun inswin1()
- (if fg (progn
- (setq loop t)
- (while loop
- (setq sn (car (entsel "\n╤í╘±═Γ╟╜╧▀╗≥├┼┤░:")))
- (if sn (progn
- (setq en (entget sn) ename (cdr (assoc 0 en)) elay (cdr (assoc 8 en)))
- (if (and (or (= "LINE" ename) (= "ARC" ename)) (= "PWALL" (substr elay 1 5)))
- (progn
- (setq lp t)
- (while lp
- (setq sn1 (car (entsel "\n╤í╘±─┌╟╜╧▀:")))
- (if sn1 (progn
- (setq en1 (entget sn1) ename1 (cdr (assoc 0 en1)) elay1 (cdr (assoc 8 en1)))
- (if (and (or (= "LINE" ename1) (= "ARC" ename1)) (= "PWALLN" elay1))
- (progn
- (if (or (and (= "LINE" ename) (= "LINE" ename1)) (and (= "ARC" ename) (= "ARC" ename1)))
- (if (and (= "LINE" ename) (= "LINE" ename1)) (progn
- (setq one (assoc wmes1 mclist) one0 (cdr one))
- (setq wname (nth 0 one0) wlength (atoi (nth 1 one0)) whight (nth 2 one0))
- (setq insx (/ wlength 100.0))
- (setq p1 (cdr (assoc 10 en)) p2 (cdr (assoc 11 en)))
- (setq ang (angle p1 p2) iang (/ (* 180 ang) pi))
- (setq p3 (cdr (assoc 10 en1)) p4 (cdr (assoc 11 en1)))
- (setq ang1 (angle p3 p4) p5 (polar p3 ang1 (/ (distance p3 p4) 2.0)) p6 (polar p5 (+ ang1 1.57079) 100) int1 (inters p1 p2 p5 p6 nil) wthick (fix (+ 0.5 (distance p5 int1))))
- (if (= (substr wname 1 2) "CC") (setq insy (/ wthick 10.0)) (setq insy insx whgt "0"))
- (setq kword (strcase (getstring "\n╒█╜╟┤░Z/▓╬┐╝╡πR/<▓σ╚δ╡π>:")))
- (if (or (= kword "") (= kword "R")) (progn
- (if (eq kword "R") (progn
- (setq p (getpoint "\n▓╬┐╝╡π:"))
- (setq insp (polar p ang (/ wlength 2.0)))
- (command "insert" wname insp "xyz" insx insy 0.01 iang 0)
- (setq sn2 (entlast))
- (princ "\n▓σ╚δ╡π:")
- (command "move" sn2 "" p pause)
- ) ;progn
- (progn ;else
- (princ "\n▓σ╚δ╡π:")
- (command "insert" wname "x" insx "y" insy "z" 0.01 "r" iang pause 0)
- (setq sn2 (entlast))
- )) ;endif
- (setq p (cdr (assoc 10 (entget sn2))))
- (setq p5 (polar p (+ ang 1.57079) 50))
- (setq int1 (inters p1 p2 p p5 nil) int2 (inters p3 p4 p p5 nil))
- (setq pins (polar int1 (+ ang 1.57079) (/ wthick 2.0)))
- (entdel sn2)
- (setq p1 (polar int1 ang (/ wlength 2)) p2 (polar int1 (+ ang pi) (/ wlength 2)))
- (setq p3 (polar int2 ang1 (/ wlength 2)) p4 (polar int2 (+ ang1 pi) (/ wlength 2)))
- (command "break" sn p1 p2)
- (command "break" sn1 p3 p4)
- (command "layer" "m" "pwindow" "")
- (command "line" p1 p3 "")
- (command "line" p2 p4 "")
- (command "insert" wname pins "xyz" insx insy 0.01 iang (strcat wmes1 " " (itoa wlength) " " whight " " whgt " " (itoa wthick)))
- (setq lp nil)
- ) ;progn ZHE JIAO
- (progn ;else
- (setq p1 (getpoint "\n┤░╞≡╡π:") pl nil pl (cons p1 pl))
- (while (< (length pl) 4)
- (initget "Undo")
- (setq p2 (getpoint p1 "\n╗╪═╦Undo/<┤░╧┬╥╗╡π>:"))
- (if (= p2 "Undo") (progn
- (if (= (length pl) 1) (princ "*▓╗─▄╘┘╗╪═╦*") (setq pl (cdr pl) p1 (car pl))) )
- (setq pl (cons p2 pl) p1 p2))
- ) ;end while
- (setq p4 (nth 0 pl) p3 (nth 1 pl) p2 (nth 2 pl) p1 (nth 3 pl) d1 (distance p1 p2) d2 (distance p3 p4) a1 (angle p1 p2) a2 (angle p4 p3))
- (setq p5 (polar p1 a1 (/ d1 3.0)) p6 (polar p4 a2 (/ d2 3.0)))
- (setq p7 (polar p2 (+ a1 pi) (/ d1 3.0)) p8 (polar p3 (+ a2 pi) (/ d2 3.0)))
- (setq sn2 nil sn2 (ssadd) insp (inters p1 p3 p2 p4))
- (command "break" sn1 p1 p4)
- (command "break" sn p2 p3)
- (command "layer" "m" "pwindow" "")
- (command "line" p2 p1 "" "line" p3 p4 "")
- (command "color" 2)
- (command "line" p1 p4 "")
- (ssadd (entlast) sn2)
- (command "line" p5 p6 "")
- (ssadd (entlast) sn2)
- (command "line" p7 p8 "")
- (ssadd (entlast) sn2)
- (command "line" p2 p3 "")
- (ssadd (entlast) sn2)
- (command "color" "bylayer")
- (setvar "aflags" 1)
- (command "attdef" "" "x" "" "" "s" "standard" insp (* (getvar "userr1") 3) 0)
- (ssadd (entlast) sn2)
- (command "attdef" "" "x1" "" "" insp (* (getvar "userr1") 3) 0)
- (ssadd (entlast) sn2)
- (setq bn (strcat "CCZ" (rtos (car insp) 2 0) (rtos (cadr insp) 2 0)))
- (command "block" bn insp sn2 "")
- (setq batt (strcat wmes1 " " (rtos (car p1) 2 4) " " (rtos (cadr p1) 2 4) " " (rtos (car p2) 2 4) " " (rtos (cadr p2) 2 4) " " (rtos (car p3) 2 4) " " (rtos (cadr p3) 2 4) " " (rtos (car p4) 2 4) " " (rtos (cadr p4) 2 4)))
- (command "insert" bn insp "xyz" 1 1 1 0 (strcat wmes1 " " (itoa (fix (distance p2 p3))) " " whight " " whgt " " (itoa wthick)) (strcat batt " " (rtos (angle p2 p3) 2 4)))
- (setq lp nil)
- ));endif
- ) ;and "Line"
- (progn ;and "Arc"
- (setq lpp t one (assoc wmes1 mclist) one0 (cdr one))
- (setq wname (nth 0 one0) wlength (atoi (nth 1 one0)) whight (nth 2 one0))
- (while lpp
- (initget "Undo X")
- (setq sp (getpoint "\n╗╪═╦U/═╦│÷X/<├┼┤░╞≡╡π>:"))
- (cond ((= "Undo" sp) (command "undo" "end" "u"))
- ((= "X" sp) (setq lpp nil lp nil))
- (t (setvar "coords" 2)
- (setq ep (getpoint sp "\n├┼┤░╓╒╡π:"))
- (setvar "coords" 0)
- (command "undo" "g")
- (setq insp (cdr (assoc 10 en)) r1 (cdr (assoc 40 en)) r2 (cdr (assoc 40 en1)) wthick (fix (+ 0.5 (- r1 r2))))
- (setq sa1 (angle insp sp) ea1 (angle insp ep) ma1 (- ea1 sa1))
- (if (< ma1 0) (setq ma1 (+ sa1 (/ (+ (* 2 pi) ma1) 2.0))) (setq ma1 (+ sa1 (/ ma1 2.0))))
- (setq sp1 (polar insp sa1 r1) ep1 (polar insp ea1 r1))
- (setq sp2 (polar insp sa1 r2) ep2 (polar insp ea1 r2))
- (setq mp1 (polar insp ma1 r1) mp2 (polar insp ma1 r2))
- (setq mp (polar mp2 (angle mp2 mp1) (/ (- r1 r2) 2.0)))
- (setvar "pickbox" 1)
- (setq sn1 (ssname (ssget mp1) 0))
- (setq sn2 (ssname (ssget mp2) 0))
- (setvar "pickbox" pib)
- (command "break" sn1 sp1 ep1)
- (command "break" sn2 sp2 ep2)
- (command "layer" "m" "pwindow" "")
- (command "line" sp1 sp2 "" "line" ep1 ep2 "")
- (setq dr (/ (- r1 r2) 3.0) r3 (+ r2 dr) r4 (- r1 dr))
- (setq sp3 (polar insp sa1 r3) ep3 (polar insp ea1 r3))
- (setq sp4 (polar insp sa1 r4) ep4 (polar insp ea1 r4))
- (if (= (substr (setq bn (nth 1 one)) 1 2) "CC") (progn
- (setq sn nil sn (ssadd))
- (command "color" 2)
- (command "arc" sp3 "c" insp ep3)
- (ssadd (entlast) sn)
- (command "arc" sp4 "c" insp ep4)
- (ssadd (entlast) sn)
- (command "arc" sp1 "c" insp ep1)
- (ssadd (entlast) sn)
- (command "arc" sp2 "c" insp ep2)
- (ssadd (entlast) sn)
- (command "color" "bylayer")
- (setvar "aflags" 1)
- (command "attdef" "" "x" "" "" "s" "standard" mp1 (* 3 (getvar "userr1")) 0)
- (ssadd (entlast) sn)
- (command "attdef" "" "x1" "" "" mp1 (* 3 (getvar "userr1")) 0)
- (ssadd (entlast) sn)
- (setq bn (strcat "CCA" (rtos (car mp) 2 0) (rtos (cadr mp) 2 0)))
- (command "block" bn mp sn "")
- (setq batt (strcat wmes1 " " (itoa (fix (distance sp1 ep1))) " " whight " " whgt " " (itoa wthick)))
- (command "insert" bn mp "xyz" 1 1 1 0 batt (strcat wmes1 " " (rtos sa1 2 4) " " (rtos ea1 2 4) " " (rtos r1 2 4) " " (rtos r2 2 4) " " whight " " whgt " " (itoa wthick) " " (rtos (angle sp1 ep1) 2 4)))
- ) ;endprogn "CC"
- (progn
- (setq sn (entlast) ss nil ss (ssadd) whgt "0")
- (command "insert" bn mp (/ (distance sp3 ep3) 100.0) "" (/ (* (angle sp3 ep3) 180.0) pi) "")
- (command "explode" (entlast))
- (while (/= (setq sn (entnext sn)) nil) (ssadd sn ss))
- (setvar "aflags" 1)
- (command "attdef" "" "x1" "" "" mp1 (* 3 (getvar "userr1")) 0)
- (ssadd (entlast) ss)
- (setq bn (strcat "CCA" (rtos (car mp) 2 0) (rtos (cadr mp) 2 0)))
- (command "block" bn mp ss "")
- (setq x (strcat wmes1 " " (itoa (fix (distance sp1 ep1))) " " (nth 3 one) " " whgt " " (itoa wthick)))
- (setq x1 (strcat wmes1 " " (rtos sa1 2 4) " " (rtos ea1 2 4) " " (rtos r1 2 4) " " (rtos r2 2 4) " " (nth 3 one) " " whgt " " (itoa wthick) " " (rtos (angle sp1 ep1) 2 4)))
- (command "insert" bn mp "xyz" 1 1 0.01 0 x x1)
- )) ;endif
- )) ;endcond "t"
- ) ;endwhile lpp
- )) ;endif and arc
- (princ "*╦∙╤í╟╜╧▀▓╗╥╗╓┬*")
- ) ;endif and arc line
- )(princ "╤í╘±╡─▓╗╩╟╟╜╧▀!")) ;if "LINE"
- )(setq lp nil loop nil)) ;if sn1
- ) ;end while
- ) ;endprogn if "LINE"
- (progn
- (if (and (= ename "INSERT") (= elay "PWINDOW")) (progn
- (setq pins (cdr (assoc 10 en)) rn (cdr (assoc 1 (setq en1 (entget (setq sn1 (entnext sn)))))) iang (/ (* 180.0 (cdr (assoc 50 en))) pi))
- (strdv rn) (setq insz0 (rtos (+ (atoi (nth 2 wlist)) (atoi (nth 3 wlist))) 2 0))
- (setq one (assoc wmes1 mclist) wname (nth 1 one) whight (nth 3 one))
- (setq wlength (nth 1 wlist) wthick (nth 4 wlist) insx (/ (atoi wlength) 100.0))
- (setq bn (cdr (assoc 2 en)))
- (if (= "CC" (substr bn 1 2)) (setq insy (/ (atoi wthick) 10.0)) (setq insy insx))
- (if (or (= "CCA" (substr bn 1 3)) (= "CCZ" (substr bn 1 3))) (setq insx 1 insy insx wname bn x1 (cdr (assoc 1 (entget (entnext (setq sn1 (entnext sn)))))) en1 (entget sn1) rn (cdr (assoc 1 en1))))
- (setq en1 (subst (cons 1 (strcat rn " " whgt "$")) (assoc 1 en1) en1))
- (entmod en1)
- (command "layer" "m" "pwindow" "")
- (if (or (= "CCA" (substr bn 1 3)) (= "CCZ" (substr bn 1 3)))
- (command "insert" wname pins "xyz" insx insy 0.01 iang (strcat wmes1 " " wlength " " whight " " whgt " " wthick " " insz0 "@") x1)
- (command "insert" wname pins "xyz" insx insy 0.01 iang (strcat wmes1 " " wlength " " whight " " whgt " " wthick " " insz0 "@")) ) ;if
- )
- (princ "\n*╤í╘±╡─▓╗╩╟├┼┤░╗≥╟╜╧▀*")
- )
- )) ;endif "LINE"
- )(setq loop nil)) ;if sn
- ) ;end while
- )) ;endif fg
- )
-
- (defun instr(st s0 s00 / l n loop x n0 l0)
- (setq l (+ (- (strlen s0) st) 1) l0 0 n0 st n 1 loop t)
- (while (and (<= n l) loop)
- (setq x (substr s0 n0 1))
- (if (eq x s00) (setq loop nil l0 n0) (setq n0 (1+ n0) n (1+ n)))
- )
- (eval l0)
- )
-
- (defun inchkmc(c / l0 l1 l2 xh0 wd hgt ch)
- (setq wlt nil)
- (if (and (> (setq l0 (instr 1 c "=")) 0) (> (setq l1 (instr 1 c "*")) 0) (= (setq l2 (instr 1 c "@")) 0) (> l1 l0)) (progn
- (setq xh0 (substr c 1 (- l0 1)) wd (substr c (+ l0 1) (- l1 l0 1)) hgt (substr c (+ l1 1)))
- (if (and (findfile (strcat xh0 ".dwg")) (> (atoi wd) 0) (> (atoi hgt) 0)) (setq lop nil wlt (list xh0 wd hgt)) (princ "*│÷┤φ*"))) (princ "*│÷┤φ*"))
- )
-
- (defun strdv(rn / loop l x)
- (setq wlist nil loop t)
- (while loop
- (setq l (instr 1 rn " "))
- (if (= l 0) (setq wlist (cons rn wlist) loop nil)
- (progn ;else
- (setq x (substr rn 1 (1- l)))
- (setq wlist (cons x wlist))
- (setq rn (substr rn (1+ l) (- (strlen rn) l)))
- (setq loop t)
- )
- )
- )
- (setq wlist (reverse wlist))
- )