明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 4302|回复: 9

批量提取图案填充高程点高程坐标

[复制链接]
发表于 2014-9-19 18:28:50 | 显示全部楼层 |阅读模式
本帖最后由 树櫴希德 于 2014-9-19 18:33 编辑

由于在有些地形图中,软件生成高程点时点位不像CASS那样是个INSERT,也不像SCS那样是个POINT,有些是HATCH 有些是圆弧 园 多段线等等,提取圆弧坐标已经被zzxxoo大神解决,提取图案填充中心坐标由SKG123大神程序+[q3_2006]q2大神代码合并而成,在此感谢2位大神!
(defun c:TQWZZB()
   (princ "\n选择所需输出的点(point):")
   (setq ss (ssget '((0 . "hatch")) ));;选取坐标点
   (setq n (sslength ss ));计算坐标点数量
        (setq ff (open (getfiled "文件保存为" "f:/" "dat" 1) "w"));保存路径
   (setq i 0)
   (repeat n
  (setq spt (ssname ss i ))
    ;(setq ept (entget spt))


;(setq pzx (mapcar 'cdr (vl-remove-if-not '(lambda (x) (= (car x) 10))(entget (car (entsel))))))
     (setq pzx (mapcar 'cdr (vl-remove-if-not '(lambda (x) (= (car x) 10))(entget spt))))
(setq lxyz (list (nth 0 (cadr pzx)) (nth 1 (cadr pzx)) (nth 2 (car pzx))        ))

(setq sx (rtos (nth 1 lxyz)));将坐标值实数转换成字符
       (setq sy (rtos (nth 0 lxyz)))
       (setq sz (rtos (nth 2 lxyz)))
                                        (setq i1 (+ i 1));计算点序号
                                        (setq sn (rtos i1 2 0));将序号实数转换成字符
       (setq sxyz (strcat sn",,"  sy ","  sx  ","  sz))
       (write-line sxyz ff)



    (setq i (+ i 1))
   );repeat
  (close ff)

)
(prompt "*只适合HATCH << 命令:TQWZZB >> *输出格式(点号,, Y,X,Z)**")
(prin1)





;(if (= (cdr (assoc 0 ept)) "TEXT")
    ; (progn
                                    (setq lxyz (cdr (assoc 10  ept)))
       ;(setq sx (rtos (nth 1 lxyz)));将坐标值实数转换成字符
       ;(setq sy (rtos (nth 0 lxyz)))
       ;(setq sz (rtos (nth 2 lxyz)))
                                      ;  (setq i1 (+ i 1));计算点序号
                                       ; (setq sn (rtos i1 2 0));将序号实数转换成字符
       ;(setq sxyz (strcat sn",,"  sy ","  sx  ","  sz))
      ; (write-line sxyz ff)
  ;  )
   ; )

 楼主| 发表于 2014-9-19 18:32:45 | 显示全部楼层
在此奉上zzxxoo大神提取圆弧圆心坐标程序和提取图案填充测试图
(ALERT "明经论坛zzxxoo ")
(defun c:plyxzb(/ wjm fff ptlst i)
(setq wjm (getfiled "请指定要保存的坐标文件" "e:\\" "dat" 1))
(setq fff (open wjm "w"))


(if (setq ss (ssget '((0 . "ARC,CIRCLE")))) (progn
  (setq ptlst (list))
  (repeat (setq i (sslength ss))
   (setq ptlst (cons(cdr(assoc 10 (entget(ssname ss (setq i (1- i)))))) ptlst))
  )
  ptlst
))

(setq i 0)
(repeat (length ptlst)
  (setq ent1 (nth i ptlst))

  (write-line (strcat (itoa i) ",,"(rtos (car ent1) 2 3) "," (rtos (cadr ent1) 2 3) "," (rtos (caddr ent1) 2 3)) fff)
  (setq i (1+ i))

  )
(close fff)



)





本帖子中包含更多资源

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

x
 楼主| 发表于 2014-9-19 18:35:36 | 显示全部楼层
请大家热烈讨论
 楼主| 发表于 2014-9-19 20:08:46 | 显示全部楼层
@[树櫴希德]四川
【话唠】LLSheng_73■■■(275988734) 22:58:25
(defun hatchxyz(e)
  (setq e(vl-remove-if'(lambda(x)(/=(car x)10))(entget e)))
  (list(cadr(cdadr e))(caddr(cdadr e))(last(car e))))
【话唠】LLSheng_73■■■(275988734)  18:51:06
HATCH图元的第一个10组最后一个数值(z)和第二个数值的前两个数值(x y)
合并成了( x y z)


谢谢73哥
发表于 2014-9-19 20:25:57 | 显示全部楼层
支持下,图案填充高程点是啥软件生成的?
 楼主| 发表于 2014-9-19 20:46:16 | 显示全部楼层
73哥版本

(defun hatchxyz(e)  (setq e(vl-remove-if'(lambda(x)(/=(car x)10))(entget e)))
  (list(cadr(cdadr e))(car(cdadr e))(last(car e))))





(defun c:TQWZZB()
   (princ "\n选择所需输出的点(point):")
   (setq ss (ssget '((0 . "hatch")) ));;选取坐标点
   (setq n (sslength ss ));计算坐标点数量
        (setq ff (open (getfiled "文件保存为" "f:/" "dat" 1) "w"));保存路径
   (setq i 0)
   (repeat n
  (setq spt (ssname ss i ))
    ;(setq ept (entget spt))



(setq lxyz (hatchxyz spt))

(setq sx (rtos (nth 1 lxyz)));将坐标值实数转换成字符
       (setq sy (rtos (nth 0 lxyz)))
       (setq sh (rtos (/ (nth 2 lxyz) 1000)))
                                        (setq i1 (+ i 1));计算点序号
                                        (setq sn (rtos i1 2 0));将序号实数转换成字符
       (setq sxyz (strcat sn",,"  sx ","  sy  ","  sh))
       (write-line sxyz ff)



    (setq i (+ i 1))
   );repeat
  (close ff)

)
(prompt "*只适合TEXT点 << 命令:TQWZZB >> *输出格式(点号,, Y,X,Z)**")
(prin1)





;(if (= (cdr (assoc 0 ept)) "TEXT")
    ; (progn
                                    (setq lxyz (cdr (assoc 10  ept)))
       ;(setq sx (rtos (nth 1 lxyz)));将坐标值实数转换成字符
       ;(setq sy (rtos (nth 0 lxyz)))
       ;(setq sz (rtos (nth 2 lxyz)))
                                      ;  (setq i1 (+ i 1));计算点序号
                                       ; (setq sn (rtos i1 2 0));将序号实数转换成字符
       ;(setq sxyz (strcat sn",,"  sy ","  sx  ","  sz))
      ; (write-line sxyz ff)
  ;  )
   ; )

 楼主| 发表于 2014-9-19 21:06:31 | 显示全部楼层
论坛老是跟新浪微博脱钩
发表于 2014-9-20 14:28:12 | 显示全部楼层
树櫴希德 发表于 2014-9-19 20:08
@[树櫴希德]四川
【话唠】LLSheng_73■■■(275988734) 22:58:25
(defun hatchxyz(e)

来个山寨版的:
(defun HATCHxyz(e)
  (setq e(entget e)p(nth 18 e)
        p(list(cadr p)(caddr p)(last(nth 9 e))))
)
 楼主| 发表于 2014-9-20 16:28:39 | 显示全部楼层
热心人就是多啊
发表于 2014-9-21 11:33:46 | 显示全部楼层
搞测量的不多啊  支持了 强烈支持
您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|CAD论坛|CAD教程|CAD下载|联系我们|关于明经|明经通道 ( 粤ICP备05003914号 )  
©2000-2023 明经通道 版权所有 本站代码,在未取得本站及作者授权的情况下,不得用于商业用途

GMT+8, 2024-12-23 13:56 , Processed in 0.200823 second(s), 29 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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