找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 784|回复: 0

[LISP程序]:导出高程点程序

[复制链接]
发表于 2009-7-31 21:59:39 | 显示全部楼层 |阅读模式

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

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

×
(print "------程序用于从图形中导出高程值-------")
(print "------ 1代表ZDH图层,2代表GCD图层-------")
(print "------键入[DGC]启动程序,谢谢使用-------")
(defun c:fzhu_dgc()
        (print)
        (setq cxz(getint"请选择图层[展点号(ZDH)]<1>/[高程点(GCD)]<2>:"))
        (print)
        (while (and(/= cxz 1)(/= cxz 2))
                (setq cxz(getint"请选择图层[展点号(ZDH)]<1>/[高程点(GCD)]<2>:"))
                (print)
        )
        (setq fpath(getstring"请输入数据存储路径及文件名:<格式如:c:\\chpf1.xyh>"))
        (print)
        (while (= fpath "")
                (setq fpath(getstring"请输入数据存储路径及文件名:<格式如:c:\\chpf1.xyh>"))
                (print)
        )
        (setq fp1(open fpath "a"))
        (if (= cxz 1)
                (setq gc(ssget "X" '((0 . "POINT") (8 . "ZDH"))))
        )
        (if (= cxz 2)
                (setq gc(ssget "X" '((0 . "POINT") (8 . "GCD"))))
        )
        (setq gclen(sslength gc))
        (write-line (itoa (- gclen 1)) fp1)
        (setq blc(getvar "userr1"))
        (setq xyd(getvar "userr2"))
        (setq yyd(getvar "userr3"))
        (setq blxs(/ 1000 blc))
        (setq n 0)
        (repeat gclen
                (setq gcname(ssname gc n))
                (setq gcdata(entget gcname))
                       (setq gcxyh (cdr (assoc 10 gcdata)))
                (setq nn(+ n 1))
                (setq x (car gcxyh))
                (setq y (cadr gcxyh))
                (setq h (caddr gcxyh))
                ;(if (and(/= h 0)(> h 0))
                ;        (progn
                        (setq xx(+ (/ (- x 100) blxs) yyd))
                        (setq yy(+ (/ (- y 100) blxs) xyd))
                        (write-line (itoa nn) fp1)
                        (write-line "" fp1)
                        (write-line (rtos xx 2 3) fp1)
                        (write-line (rtos yy 2 3) fp1)
                        (write-line (rtos h 2 3) fp1)
                ;        )
                ;)
                (setq n(+ n 1))
        )
        (close fp1)
        (alert "数据导出成功!")
        (print)
)
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|申请友链|Archiver|手机版|小黑屋|辽公网安备|晓东CAD家园 ( 辽ICP备15016793号 )

GMT+8, 2024-6-14 22:23 , Processed in 0.323141 second(s), 31 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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