明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
12
返回列表 发新帖
楼主: 77077

[提问] 砸锅卖铁求个道路交叉口处理的源码~~~

[复制链接]
 楼主| 发表于 2014-6-17 15:48 | 显示全部楼层
本帖最后由 77077 于 2014-6-17 15:54 编辑

对,就是院长这个,没源码啊,求真源码~


发个自编道路断面符号标注的源码,为什么采用插入属性块的方式呢,主要是为了后面修改字高的时候,减少计算量~~~
块形式自定即可..
  1. (defun c:xx (/ str h pt1 pt2 ang old old1)
  2. (setq old1 (getvar "blipmode"))
  3. (setvar "blipmode" 0)
  4. (setq lay (getvar "clayer")
  5.       old (getvar "osmode")
  6.       )
  7. (command "color" "bylayer")
  8. (command "layer" "m" "DM-断面符号" "c" "1" "DM-断面符号" "")
  9. (setq str (getstring "\n请输入断面符号<A>"))(if (= str nil) (setq str "A"))
  10. (setq h (getreal "\n设置字高<3.0>"))(if (= h nil) (setq h 3.0))
  11. (progn (while
  12. (setq pt1 (getpoint "\n选择第一点:")
  13.       pt2 (getpoint pt1 "\n选择另一点:")
  14.       ang (angle pt1 pt2)
  15.       )
  16. (setvar "osmode" 0)
  17. (command "-Insert" "断面符号A" pt1 h h (angtos ang) (strcase str))
  18. (command "-Insert" "断面符号B" pt2 h h (angtos ang) (strcase str))
  19. (setvar "osmode" old)
  20. ))
  21. (setvar "osmode" old)
  22. (setvar "blipmode" old1)
  23. (command "layer" "s" lay "")
  24. )

本帖子中包含更多资源

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

x
回复

使用道具 举报

发表于 2014-6-18 10:12 | 显示全部楼层
77077 发表于 2014-6-17 14:49
这个还真没有,有两个是#线剪切的方法1.交点打断,然后删除短线.方法2.将线打断交点之间的部分.
自己修改了 ...

楼主可以把有的这两个发上来么,作为参考用~

点评

论坛里面已经有  发表于 2014-6-18 12:31
回复

使用道具 举报

发表于 2015-6-7 21:01 | 显示全部楼层
看这里:http://bbs.mjtd.com/thread-168329-1-1.html,可以达到你的要求,如果是要倒角直接改下command后面的即可。
回复

使用道具 举报

 楼主| 发表于 2015-6-7 23:20 | 显示全部楼层
荒野孤行 发表于 2015-6-7 21:01
看这里:http://bbs.mjtd.com/thread-168329-1-1.html,可以达到你的要求,如果是要倒角直接改下command后面 ...

你发出来这个和我求的程序,差别太大了~~~
回复

使用道具 举报

发表于 2015-6-22 13:41 | 显示全部楼层
请问楼主解决了吗
回复

使用道具 举报

发表于 2015-6-23 08:58 | 显示全部楼层
本帖最后由 鱼与熊掌 于 2015-6-23 09:05 编辑



命令TT 仅供试玩. 随手写的

本帖子中包含更多资源

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

x
回复

使用道具 举报

发表于 2015-6-23 09:04 | 显示全部楼层
  1. (defun c:tt(/ e1 new_ss p ss ss_pts ss1 ss2)
  2.         (setq ss(ssget))
  3.         (setq ss_pts(mapcar 'cadr(cdr(last(ssnamex ss)))))
  4.         (setq ss1 (ssget "cp" ss_pts '((62 . 1))))
  5.         (cx-break-with ss1 ss1 t)
  6.         (cx-erase (ssget "wp" ss_pts))
  7.         (setq new_ss (ssget "cp" ss_pts '((62 . 1))))
  8.         (setq new_ss(cx-ss2en new_ss))
  9.         (while new_ss
  10.                 (setq e1 (car new_ss))
  11.                 (setq new_ss(cdr new_ss))
  12.                 (vl-some
  13.                         '(lambda(x)
  14.                                 (setq e2 x)
  15.                                 (cx-get-ins e1 x)
  16.                         )
  17.                         new_ss
  18.                 )
  19.                 (setq new_ss (vl-remove e2 new_ss))
  20.                 (command "CHAMFER" "d" 100 100)
  21.                 (command "CHAMFER"  (list e1 (cx-get-9pt e1 5 )) (list e2 (cx-get-9pt e2 5 )))
  22.         )
  23.         ;<<
  24.         (setq ss2 (ssget "cp" ss_pts '((62 . 5))))
  25.         (cx-break-with ss2 ss2 t)
  26.         (cx-erase (ssget "wp" ss_pts '((62 . 5))))
  27.         (setq new_ss (ssget "cp" ss_pts '((62 . 5))))
  28.         (setq new_ss(cx-ss2en new_ss))
  29.         (while new_ss
  30.                 (setq e1 (car new_ss))
  31.                 (setq new_ss(cdr new_ss))
  32.                 (setq p
  33.                         (car
  34.                                 (vl-some
  35.                                         '(lambda(x)
  36.                                                 (setq e2 x)
  37.                                                 (cx-get-ins e1 x)
  38.                                         )
  39.                                         new_ss
  40.                                 )
  41.                         )
  42.                 )
  43.                 (setq new_ss (vl-remove e2 new_ss))
  44.                 (command "FILLET" "r" 80)
  45.                 (command "FILLET"  (list e1 (cx-get-9pt e1 5 )) (list e2 (cx-get-9pt e2 5 )))
  46.         )
  47. )
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-18 20:30 , Processed in 0.221862 second(s), 22 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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