找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 774|回复: 3

[每日一码] 展点程序

[复制链接]

已领礼包: 568个

财富等级: 财运亨通

发表于 2016-10-31 14:59:36 | 显示全部楼层 |阅读模式

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

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

×
(defun c:zd ()
  (setq os (getvar "osmode"))
  (setq od (getvar "cmdecho"))
  (setvar "osmode" 0)
  (setvar "cmdecho" 0)
  (setq filename1 (getfiled "请打开展点文件名::::" "" "" 2))
  (setq bilichi (getreal "\n展点图比例尺分母<1000>=     "))
  (if (not bilichi)
    (setq bilichi 1000)
  )
  (setq bilichi (/ bilichi 1000))
  (if (not (tblsearch "layer" "999"))
    (vl-cmdf "layer" "m" "999" "")
  )
  (vl-cmdf "layer" "s" "0" "")
  (COMMAND "STYLE"
    "wygzd2"
    "fsdb_e,fsdb"
    (* 2.0 bilichi)
    "0.75"
    "0.0"
    "N"
    "N"
    "N"
  )
;;;  (vl-cmdf "pline")
  (setq fil1 (open filename1 "r"))
  (setq ii 0)
  (while (setq sth (read-line fil1))
    (progn
;;;(setq pth(read (strcat "(" sth ")" )))
;;;(setq pn1(nth 0 pth))
;;;(setq sth (read-line fil1))
      (setq pth (read (strcat "(" sth ")")))
;;;(setq pty1(nth 2 pth))
;;;(setq ptx1(NTH 1 pth))
      (setq pn1 (vl-princ-to-string (nth 0 pth)))
      (setq ptx1 (nth 1 pth))
      (setq pty1 (NTH 2 pth))
      (setq pth1 (nth 3 pth))      
      (if (= pth1 0)
(setq pt1 (list ptx1 pty1))
(setq pt1 (list ptx1 pty1 pth1))
      )
;;;(setq pn2 (rtos pn1 2 0))
      (setq pn2 pn1)
;;;      (vl-cmdf "_circle" pt1 (* 0.2 bilichi))
      (vl-cmdf "_insert"
;;;        "1.7"
        "g:/mtools/gc200.dwg"
        pt1
        (* 0.5 bilichi)
        (* 0.5 bilichi)
        "0"
      )
;;;      注记点及高程
      (if pth1
(progn
   (setq pth2 (RTOS pth1 2 2))
   (setq zjd1 (list (+ (+ ptx1 2) (* bilichi 2))
      (+ pty1 (* 3.0 bilichi))
       )
   )
   (setq zjd2 (list (+ (+ ptx1 2) (* bilichi 2))
      (+ pty1 (* 0 bilichi))
       )
   )
   (setq hxd1 (list (+ (+ ptx1 1) (* bilichi 0))
      (+ pty1 (* 1.5 bilichi))
       )
   )
   (setq hxd2 (list (+ (+ ptx1 5) (* bilichi 2))
      (+ pty1 (* 1.5 bilichi))
       )
   )
   (command "_line" hxd1 hxd2 "")
   (setq ent1 (entlast))
   (vl-cmdf "change" ent1 "" "p" "la" "999" "")
   (command "_text" "j" "mc" zjd1 "0" pn2)
   (setq ent1 (entlast))
   (vl-cmdf "change" ent1 "" "p" "la" "999" "")
   (command "_text" "j" "mc" zjd2 "0" pth2)
)
(progn
   (setq zjd1 (list (+ (+ ptx1 1) (* bilichi 2))
      (+ pty1 (* 0 bilichi))
       )
   )
   (command "_text" "j" "mc" zjd1 "0" pn2)
)
      )
    )
;;;end progn
    (setq ii (+ ii 1))
    (princ
      (strcat "\n正在展第" (itoa ii) "个点,请稍候.........:")
    )
;;;    (vl-cmdf "pline" Pt1)
  )
;;;  (vl-cmdf "pline" "")
;;;end while
  (CLOSE FIL1)
  (setvar "osmode" os)
  (setvar "cmdecho" od)
  (princ (strcat "\n共" (itoa ii) "个点已展点成功!"))
  (princ "\n OK!")
  (princ)
)

评分

参与人数 1D豆 +5 收起 理由
newer + 5 很给力!经验;技术要点;资料分享奖!

查看全部评分

论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!

已领礼包: 40个

财富等级: 招财进宝

发表于 2016-10-31 16:26:31 | 显示全部楼层
楼主,能否把展点需要的数据文件弄个简单的例子传到论坛?
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 8734个

财富等级: 富甲天下

发表于 2016-11-1 06:38:01 | 显示全部楼层
感谢 王子 分享程序!!!!
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 1094个

财富等级: 财源广进

发表于 2021-10-24 00:01:34 | 显示全部楼层
感谢分享展点程序
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

GMT+8, 2024-5-12 23:21 , Processed in 0.370610 second(s), 39 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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