home *** CD-ROM | disk | FTP | other *** search
- ;* Version 2.0, Copyright 1988,1989 Edward Riegelmann, All Rights Reserved.*
- (repeat 2 (prompt "\n ")) (prompt "\nLoading CADTOIDR program.....")
- (defun c:cadtoidr ()
- (grtext 0 "********") (grtext 1 "CADTOIDR") (grtext 1 " " 1)
- (grtext 2 "********") (repeat 10 (prompt "\n "))
- (prompt "\n ╔═════════════════════════════════════════════╗")
- (prompt "\n ║ AutoTOOLS ║▐")
- (prompt "\n ╟─────────────────────────────────────────────╢▐")
- (prompt "\n ║ AutoCAD TO IDRISI DATA TRANSFORMATION ║▐")
- (prompt "\n ╟─────────────────────────────────────────────╢▐")
- (prompt "\n ║ Version 2.0 ║▐")
- (prompt "\n ╚═════════════════════════════════════════════╝▐")
- (prompt "\n ▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀")
- (prompt "\n ")
- (prompt "\n Copyright 1988, 1989 Edward Riegelmann")
- (repeat 8 (prompt "\n ")) (textscr) (setvar "luprec" 6) (setvar "flatland" 0)
- (setq fn (getstring "\nEnter new vector file name : "))
- (setq df (open (strcat fn ".vec") "w")) (initget 1 "W A")
- (setq flg (getkword "\nChoose data by (W)indow or choose (A)ll ? : "))
- (if (= flg "W") (progn (graphscr)
- (setq pnt1 (getpoint "\nEnter window corner : "))
- (setq pnt2 (getcorner pnt1 "\nEnter other corner : "))
- (prompt "\n ")) (setq pnt1 (getvar "extmin") pnt2 (getvar "extmax"))
- ) (setq a (ssget "C" pnt1 pnt2)) (textscr)
- (prompt "\nUnadjusted number of ROWS : ")
- (princ (- (nth 1 pnt2) (nth 1 pnt1)))
- (prompt "\nUnadjusted number of COLS : ")
- (princ (- (nth 0 pnt2) (nth 0 pnt1))) (terpri) (initget 1 "Y N")
- (setq flg3 (getkword "\nDo you wish to re-grid your data (Yes/No) ? : "))
- (if (= flg3 "Y") (progn (setq xsub (nth 0 pnt1) ysub (nth 1 pnt1))
- (setq xyfac (getreal "\nMultiply coordinates by what factor ? : ")))
- (setq xsub 0 ysub 0 xyfac 1)
- ) (initget 1 "P S C L")
- (setq ply (getkword "\nAre data (P)olygons, Point(S), (C)ontours or (L)ines ? : "))
- (prompt "\n .................working.................")
- (prompt "\n ") (setq i 0)
- (repeat (sslength a)
- (setq b (entget (ssname a i)) f 1 f1 1)
- (if (= (cdr (assoc 0 b)) "POLYLINE")
- (if (= ply "C") (progn
- (setq subent (entget (entnext (cdr (assoc -1 b)))))
- (while f
- (if (= (nth 3 (assoc 10 subent)) nil) (princ 0 df)
- (princ (rtos (nth 3 (assoc 10 subent))) df)
- ) (write-line " 1" df)
- (princ (rtos (* (- (nth 1 (assoc 10 subent)) xsub) xyfac)) df) (princ " " df)
- (write-line (rtos (* (- (nth 2 (assoc 10 subent)) ysub) xyfac)) df)
- (setq subent (entget (entnext (cdr (assoc -1 subent)))))
- (if (= (cdr (assoc 0 subent)) "SEQEND") (setq f nil))
- ))
- (progn (setq subent (entget (entnext (cdr (assoc -1 b)))) cnt 1)
- (while f1
- (setq cnt (1+ cnt))
- (setq subent (entget (entnext (cdr (assoc -1 subent)))))
- (if (= (cdr (assoc 0 subent)) "SEQEND") (setq f1 nil))
- ) (setq subent (entget (entnext (cdr (assoc -1 b)))) subent1 subent)
- (if (= (nth 3 (assoc 10 subent)) nil) (princ 0 df)
- (princ (rtos (nth 3 (assoc 10 subent))) df)
- ) (if (= ply "L") (setq cnt (1- cnt)))
- (write-line (strcat " " (rtos cnt)) df)
- (while f
- (princ (rtos (* (- (nth 1 (assoc 10 subent)) xsub) xyfac)) df) (princ " " df)
- (write-line (rtos (* (- (nth 2 (assoc 10 subent)) ysub) xyfac)) df)
- (setq subent (entget (entnext (cdr (assoc -1 subent)))))
- (if (= (cdr (assoc 0 subent)) "SEQEND") (setq f nil))
- )
- (if (= ply "P") (progn
- (princ (rtos (* (- (nth 1 (assoc 10 subent1)) xsub) xyfac)) df) (princ " " df)
- (write-line (rtos (* (- (nth 2 (assoc 10 subent1)) ysub) xyfac)) df)))
- )
- )
- (progn
- (if (= (nth 3 (assoc 10 b)) nil) (princ 0 df)
- (princ (rtos (nth 3 (assoc 10 b))) df)) (write-line " 1" df)
- (princ (rtos (* (- (nth 1 (assoc 10 b)) xsub) xyfac)) df) (princ " " df)
- (write-line (rtos (* (- (nth 2 (assoc 10 b)) ysub) xyfac)) df)
- )
- ) (setq i (1+ i))
- )
- (princ 0 df) (write-line " 0" df) (close df)
- (setq rows (- (nth 1 pnt2) (nth 1 pnt1)) cols (- (nth 0 pnt2) (nth 0 pnt1)))
- (setq inf (open (strcat fn ".inf") "w"))
- (write-line (strcat "(" (rtos (nth 0 pnt1)) " " (rtos (nth 1 pnt1)) ")") inf)
- (write-line (strcat "(" (rtos (nth 0 pnt2)) " " (rtos (nth 1 pnt2)) ")") inf)
- (write-line (strcat "(" (rtos (nth 0 pnt1)) " " (rtos (nth 1 pnt2)) ")") inf)
- (write-line (rtos (* rows xyfac)) inf) (write-line (rtos (* cols xyfac)) inf)
- (write-line (rtos xyfac) inf) (close inf) (repeat 15 (prompt "\n "))
- (prompt "\n █████████████████████████████████████████████")
- (prompt "\n █ *************************************** █")
- (prompt "\n █ Please record the following information █")
- (prompt "\n █ as it is required for processing within █")
- (prompt "\n █ the IDRISI software package █")
- (prompt "\n █ *************************************** █")
- (prompt "\n █████████████████████████████████████████████")
- (repeat 5 (prompt "\n "))
- (prompt "\n ROWS in data set : ")
- (princ (fix (1+ (* rows xyfac))))
- (prompt "\n COLS in data set : ")
- (princ (fix (1+ (* cols xyfac)))) (terpri)
- )
-
-