明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
楼主: hastan

[提问] 點選多段線生成5m或10m dtmpoint點至txt檔

[复制链接]
发表于 2015-10-4 23:37 | 显示全部楼层
hastan 发表于 2015-10-4 12:27
做的到就可以

现学了下 G 版的 RxApi

需要G版的 API 库
尚需优化,输出自己增加

  1. (defun c:tt (/ ss dis ps box ss v pb sss m n p0 pls pts _pi2 trilst)
  2.   (if (and (setq dis (getdist "\nDistance of Axis: "))
  3.            (setq ps (ssget "+.:S" '((0 . "*Polyline"))))
  4.            (setq pl (ssname ps 0))
  5.            (setq pls (xlrx-curve-getstretchpoints pl))
  6.            (setq ss (ssget "x" '((0 . "insert") (2 . "99"))))
  7.            (setq sss (XLRX-TriAngle ss ps nil t))
  8.       )
  9.     (progn
  10.       (setq box           (list (apply 'mapcar (cons 'min pls))
  11.                          (apply 'mapcar (cons 'max pls))
  12.                    )
  13.             v           (mapcar 'abs (apply 'mapcar (cons '- box)))
  14.             pb           (car box)
  15.             m           (fix (/ (car v) dis))
  16.             n           (fix (/ (cadr v) dis))
  17.             p0           pb
  18.             trilst (mapcar 'xlrx-curve-getstretchpoints
  19.                            (xlrx-pickset->list sss)
  20.                    )
  21.       )
  22.       (repeat m
  23.         (setq pts (cons (setq p0 (polar p0 0.0 dis)) pts))
  24.       )
  25.       (setq pts         (cons pb (reverse pts))
  26.             _pi2 (/ pi 2)
  27.       )
  28.       (mapcar
  29.         '(lambda (b / stri)
  30.            (if (setq stri
  31.                       (vl-member-if
  32.                         '(lambda (c)
  33.                            (apply 'xlrx-point-getTriIntersElev (cons b c))
  34.                          )
  35.                         trilst
  36.                       )
  37.                )
  38.              (apply 'xlrx-point-getTriIntersElev (cons b (car stri)));_能计算高程的点
  39.              (entmake (list '(0 . "point") (cons 10 b)));_三角网外部的点
  40.            )
  41.          )
  42.         (apply
  43.           'append
  44.           (mapcar '(lambda (x / p ptl)
  45.                      (setq p x)
  46.                      (repeat n
  47.                        (setq ptl (cons (setq p (polar p _pi2 dis)) ptl))
  48.                      )
  49.                      (vl-remove-if
  50.                        '(lambda        (a)
  51.                           (not (XLRX-Point-IsInPoly1 a pls))
  52.                         )
  53.                        (cons x (reverse ptl))
  54.                      )
  55.                    )
  56.                   pts
  57.           )
  58.         )
  59.       )
  60.     )
  61.   )
  62.   (princ)
  63. )
 楼主| 发表于 2015-10-5 19:15 | 显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽
发表于 2015-10-5 19:56 来自手机 | 显示全部楼层
置顶帖子
XLRX_API for CAD2004~2014函数库 2015.08.27更新
http://bbs.mjtd.com/forum.php?mod=viewthread&tid=113010&mobile=yes
 楼主| 发表于 2015-10-5 21:33 | 显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽
 楼主| 发表于 2015-10-5 21:38 | 显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽
发表于 2015-10-5 22:13 | 显示全部楼层
(apply 'xlrx-point-getTriIntersElev (cons b (car stri)));_能计算高程的点

这部分点就可以输出了
 楼主| 发表于 2015-10-6 19:27 | 显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽
发表于 2015-10-6 21:54 来自手机 | 显示全部楼层
已经算出来了
 楼主| 发表于 2015-10-6 22:45 | 显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽
发表于 2015-10-7 11:25 | 显示全部楼层
好东西啊   真神奇
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-4-19 16:09 , Processed in 0.197401 second(s), 19 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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