明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 2426|回复: 18

[LISP]求学 这样的程序该怎样编写

  [复制链接]
发表于 2006-3-8 16:14 | 显示全部楼层 |阅读模式

我在实际工作中常常会遇到提取图形坐标值并生成表格插入到图形中的难道。比如说按顺序提取公路桩的坐标值.该公路的路路边是由多条pl线连接,由pe命令合并为一条.该公路的边缘有许多公路桩与公路边相交.(注意:该公路桩的点位并不一定是在pl连接线的每个连接点上)

恳请高手编写一个能够按顺序提取桩位坐标值,并能将坐标值已队列的形式插入到图形的程序.(如图)

先谢谢大家了!

本帖子中包含更多资源

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

x
发表于 2006-3-8 20:21 | 显示全部楼层

不知道是不是这样的,还不够完善,只出了一个大概

本帖子中包含更多资源

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

x
 楼主| 发表于 2006-3-8 21:20 | 显示全部楼层

是这个意思

但是有一点我要请您注意了:该公路的路路边是由多条pl线连接,由pe命令合并为一条.该公路的边缘有许多公路桩与公路边相交.(注意:该公路桩的点位并不一定是在pl连接线的每个连接点上)

也就是说当我们点取pl时提取的坐标往往是多条pl线端点的坐标而不是我所要求的与公路桩相交的坐标值。

该图形是这样完成的:公路是有许多条直线画的,然后用pe命令合并成一条pl线

最后把公路桩做成块,嵌套在这条pl线上。

我所需要的就是嵌套在pl线上的公路桩与pl线交点的坐标。

谢谢!

发表于 2006-3-8 21:23 | 显示全部楼层
其实我刚才演示的那个程序并不没有求pl连接线的连接点,而是直接求一个个块的插入点。
 楼主| 发表于 2006-3-8 21:58 | 显示全部楼层

我想请求高手直接点击pl线就可以顺序批量求出块插入点的坐标值,最中实现图中的上述功能  

行吗???

发表于 2006-3-8 22:44 | 显示全部楼层
下面这段程序不太完善,对求值顺序有些刚好相反
  1. (defun c:test ()
  2.   (setvar "cmdecho" 0)
  3.   (setq ent (car (entsel "\n选择一条多义线")))
  4.   (if (= (setq str (getstring "\n输入起始的桩号<J1>:")) "")
  5.     (setq str "J1")
  6.   )
  7.   (command "zoom" "all")
  8.   (command "zoom" "0.5x")
  9.   (setq obj (vlax-ename->vla-object ent))
  10.   (vla-offset obj -1)
  11.   (setq ent1 (entlast))
  12.   (vla-offset obj 1)
  13.   (setq ent2 (entlast))
  14.   (setq lst1 (point-lst ent1)
  15. lst2 (reverse (point-lst ent2))
  16. lst  (append lst1 lst2)
  17. k    0
  18.   )
  19.   (command "select" "cp")
  20.   (while (setq point (nth (setq K (1+ k)) lst))
  21.     (command point)
  22.   )
  23.   (command "" "")
  24.   (setq
  25.     ss (ssget "p"
  26.        '((0 . "INSERT"))
  27.        )
  28.   )
  29.   (entdel ent1)
  30.   (entdel ent2)
  31.   (setq j    -1
  32. lst3 '()
  33.   )
  34.   (while (setq ent4 (ssname ss (setq j (1+ j))))
  35.     (setq lst3 (append (list (cdr (assoc 10 (entget ent4)))) lst3))
  36.   )
  37.   (setq
  38.     lst3 (vl-sort
  39.     lst3
  40.     '(lambda (a b)
  41.        (> (vlax-curve-getParamAtPoint obj a)
  42.    (vlax-curve-getParamAtPoint obj b)
  43.        )
  44.      )
  45.   )
  46.   )
  47.   (setq k -1)
  48.   (setq text-point (getpoint "\n输入一个起点:"))
  49.   (setq num  (atoi (substr str 2))
  50. loop T
  51.   )
  52.   (setvar "TEXTSTYLE" "WMF-宋体0")
  53.   (while (setq point (nth (setq k (1+ k)) lst3))
  54.     (setq x (car point)
  55.    y (cadr point)
  56.     )
  57.     (setq tex (strcat "J"
  58.         (rtos (+ num k))
  59.         "       "
  60.         (rtos x)
  61.         "   "
  62.         (rtos y)
  63.        )
  64.     )
  65.     (if loop
  66.       (progn
  67. (command "text" text-point 5.5 "" tex)
  68. (setq loop nil)
  69.       )
  70.       (command "text" "" tex)
  71.     )
  72.   )
  73. (setvar "cmdecho" 1)
  74.   (princ)
  75. )
  76. ;;;子函数
  77. (defun point-lst (ent00 / obj00 lst00 lst01 i)
  78.   (setq obj00 (vlax-ename->vla-object ent00))
  79.   (setq lst00 (vlax-get obj00 'Coordinates))
  80.   (setq i 0
  81. lst01 '()
  82.   )
  83.   (repeat (/ (length lst00) 2)
  84.     (setq
  85.       lst01 (cons (list (nth i lst00) (nth (1+ i) lst00)) lst01)
  86.     )
  87.     (setq i (+ i 2))
  88.   )
  89.   lst01
  90. )
 楼主| 发表于 2006-3-9 18:28 | 显示全部楼层

首先谢谢您的程序。

但是该程序在运行时还有些问题:

命令:test

选择一条多义线

输入起始的桩号<J1>:J1

;错误:no function difintion :Vlax-Ename->Vla-object

 

 楼主| 发表于 2006-3-9 18:32 | 显示全部楼层

问题已经解决了!!!

再次感谢您了!!!!!

 楼主| 发表于 2006-3-14 15:13 | 显示全部楼层
请问ljpnb兄:您的程序为啥在这个图形中就不行了呢?

本帖子中包含更多资源

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

x
发表于 2006-3-14 15:36 | 显示全部楼层

那你需要求什么,没有那些路桩当然不行了?

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

本版积分规则

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

GMT+8, 2024-5-19 14:25 , Processed in 0.169795 second(s), 27 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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