明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 2689|回复: 6

在地形图缩编1:500变成1:2000的时候,植被符号需要抽稀,

[复制链接]
发表于 2013-3-29 19:56:00 | 显示全部楼层 |阅读模式
1明经币
在地形图缩编1:500变成1:2000的时候,植被符号需要抽稀,(原图是按照2cm填充的,变成2000图间距就很密,需要删减)本人一直用高程点过滤功能,请高人写个程序,一次批选,按照距离自动删减,

附件: 您需要 登录 才可以下载或查看,没有账号?注册
 楼主| 发表于 2013-4-3 20:21:28 | 显示全部楼层
高手快来i,不行再给些
回复

使用道具 举报

发表于 2013-4-6 20:08:40 | 显示全部楼层
本帖最后由 qfkxc 于 2013-4-7 06:59 编辑
  1. (defun c:fhcx ()
  2. (vl-load-com)
  3. (setvar "cmdecho" 0)
  4. (setq v1 (getvar "osmode"))
  5. (setvar "osmode" 0)
  6. (setq blc(getreal "请输入当前图形的比例尺<500>:"))
  7. (if (= blc nil)
  8.     (setq blc 500))
  9. (setq blxs (* 0.001 blc));新插入块的比例系数
  10. (setq xzl (- (* 0.02 blc) 1.5))
  11. (setq yzl (- (* 0.01 blc) 1.5))
  12. (setq s1 (entsel "\n请选择一个植被符号:"))
  13. (command "zoom" "e" "")
  14. (setq tyb (entget(car s1)));图元表
  15. (setq gjz0 (assoc 0 tyb));关键字0
  16. (setq tkm (assoc 2 tyb));图块名
  17. (setq tcm (assoc 8 tyb));图层名
  18. (setq glb (list gjz0 tcm tkm));选择集过滤表
  19. (setq s (ssget "x" glb ));植被选择集
  20. (setq tygs (sslength s));选择集内图元个数
  21. (setq ff (open "d:/坐标表.txt" "w"));新建植被插入点坐标文档
  22. (setq i 0)
  23. (repeat tygs
  24. (setq dgtym (ssname s i))
  25. (setq dgtyb (entget dgtym));单个符号图元表
  26. (setq zbb (cdr (assoc 10 dgtyb)));坐标表
  27. (setq zbx (rtos (car zbb) 2 2))
  28. (setq zby (rtos (cadr zbb) 2 2))
  29. (setq zbzfq (strcat zbx "," zby));坐标字符串
  30. (write-line zbzfq ff);写入坐标字符串
  31. (setq i (1+ i)))
  32. (close ff)
  33. (command  "._erase" s "" );删除植被符号
  34. (setq tcm1 (cdr tcm))
  35. (command "layer" "s" tcm1 "");设置当前层
  36. (setq ff (open "d:/坐标表.txt" "r"));打开植被插入点坐标文档
  37. (setq tkmc (strcat (cdr tkm) ".dwg"))
  38. (setq i 0)
  39. (while (< i tygs)
  40. (setq zbzfq (read-line ff));读出坐标字符串
  41. (setq zfqcd (strlen zbzfq));坐标字符串的长度
  42. (setq dhwz (vl-string-search "," zbzfq));查找,所在位置
  43. (setq xzb (atof (substr zbzfq 1 dhwz)));截取字符串转换为X坐标
  44. (setq yzb (atof (substr zbzfq (+ dhwz 2))));截取字符串转换为y坐标
  45. (setq zbb (list xzb yzb));组合为坐标表
  46. (setq p1 (list (- xzb xzl) (- yzb yzl)));检查是否有植被符号的范围
  47. (setq p2 (list (+ xzb xzl) (+ yzb yzl)))
  48. (setq s (ssget "w" p1 p2 glb ));植被选择集
  49. (if (= s nil)
  50. (progn
  51. (setq p1 (list (- xzb 3) (- yzb 3 (* 0.01 blc))))
  52. (setq p2 (list (+ xzb 3) (+ yzb 3 (* 0.01 blc))))
  53. (setq s (ssget "w" p1 p2 glb ));植被选择集
  54. (if (= s nil)
  55. (command "-insert" tkmc zbb blxs blxs blxs))))
  56. (setq i (1+ i)))
  57. (close ff)
  58. (command "layer" "s" 0 "");设置当前层
  59. )


回复

使用道具 举报

 楼主| 发表于 2013-4-6 20:16:57 | 显示全部楼层
本帖最后由 dwjb 于 2013-4-6 20:37 编辑
qfkxc 发表于 2013-4-6 20:08


功能基本完整,应该输入当前图的比例尺,要按照3厘米间隔插入符号的,
或者可以手工选取抽稀的范围,或者pline线选则的范围,运行速度不是很快,
非常感谢!!!!!!!!!!!如何给你转明镜币呢?
回复

使用道具 举报

 楼主| 发表于 2013-4-6 21:10:38 | 显示全部楼层
dwjb 发表于 2013-4-6 20:16
功能基本完整,应该输入当前图的比例尺,要按照3厘米间隔插入符号的,
或者可以手工选取抽稀的范围,或 ...

在另一个测绘板块已经付了1个明镜币,和50分
回复

使用道具 举报

发表于 2013-4-7 07:02:08 | 显示全部楼层
程序是根据我单位的符号间隔编辑的,看来你的符号比我的间距大一倍,在输入当前比例尺时你把比例尺扩大一倍试试,即2000的比例尺你输入4000试试。
回复

使用道具 举报

 楼主| 发表于 2013-4-8 15:10:31 | 显示全部楼层
qfkxc 发表于 2013-4-7 07:02
程序是根据我单位的符号间隔编辑的,看来你的符号比我的间距大一倍,在输入当前比例尺时你把比例尺扩大一倍 ...

符号旋转了,比例尺输入2000,就旋转2度,4000就旋转4度,----bug???
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-12-23 13:57 , Processed in 0.201301 second(s), 25 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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