明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 1735|回复: 7

[LISP] 求助 meflying

[复制链接]
发表于 2005-9-14 15:17 | 显示全部楼层 |阅读模式

您曾经帮我编过标注边长的程序:

(defun c:Dimline( / dir gap ss i ent ents pts)
  (vl-load-com)
  (setq dir (getstring "\n选择方向[(A)顺时针外部/(B)顺时针内部](逆时针则相反)<A>:"))
  (setq gap (getreal "\n输入标注文字到边边距离:"))
  (if (= (strcase dir) "B")
    (setq dir 0)
    (setq dir pi)
  )
  (setq ss (ssget '((0 . "LWPOLYLINE"))))
  (setq i 0)
  (setvar "cmdecho" 0)
  (if ss
    (progn
      (repeat (sslength ss)
 (setq ent (ssname ss i))
 (setq ents (entget ent))
 (setq pts (mapcar 'cdr (vl-remove-if-not '(lambda (e) (= (car e) 10)) ents)))
 (mapcar '(lambda(e1 e2) (command "_.dimaligned" e1 e2 (polar e1 (+ dir (angle e1 e2) (/ pi 2.0)) gap)))
   pts (append (cdr pts) (list (car pts))))
 (setq i (1+ i))
      )
    );progn
  );if
  (princ)
)

这个程序每次标注必需要先选多义线,如果图形中有很多个多义线就会很麻烦。

求助meflying能不能在此程序的基础上改编一下,使其在由多个LINE线组成的

多边形区域内点击,可以自动生成边界并能够根据边界自动标注边长,最后删除边界线。

小弟先向大哥道声谢了!!!!!


 

发表于 2005-9-14 16:33 | 显示全部楼层
版主忙,我改一下:(程序未经调试)
  1. (defun c:Dimline( / dir gap ss i ent ents pts)
  2.   (vl-load-com)
  3.   (setq dir (getstring "\n选择方向[(A)顺时针外部/(B)顺时针内部](逆时针则相反)<A>:"))
  4.   (setq gap (getreal "\n输入标注文字到边边距离:"))
  5.   (if (= (strcase dir) "B")
  6.     (setq dir 0)
  7.     (setq dir pi)
  8.   )
  9.   (INITGET 1)
  10.   (setq pt (getpoint "\n请点取要标注的范围内一点:"))
  11.   (command "-boundary" pt "")
  12.   (setvar "cmdecho" 0)
  13.   (if  (SETQ SS (ENTLAST)) (progn
  14.    (setq ents (entget SS))
  15. (setq pts (mapcar 'cdr (vl-remove-if-not '(lambda (e) (= (car e) 10)) ents)))
  16. (mapcar '(lambda(e1 e2) (command "_.dimaligned" e1 e2 (polar e1 (+ dir (angle e1 e2) (/ pi 2.0)) gap)))
  17.    pts (append (cdr pts) (list (car pts))))
  18.     );progn
  19.   );if
  20.   (princ)
  21. )
 楼主| 发表于 2005-9-15 08:28 | 显示全部楼层

很好用。

非常感谢!!!!

经典的教材!

发表于 2005-9-15 08:42 | 显示全部楼层

在);progn前应该再加上一行(entdel ss)。

 楼主| 发表于 2005-9-15 11:08 | 显示全部楼层

谢谢!

 楼主| 发表于 2005-9-15 11:10 | 显示全部楼层
请问(INITGET 1)
是什么意思呀!
发表于 2005-9-15 14:51 | 显示全部楼层
zhongguola发表于2005-9-15 11:10:00请问(INITGET 1)是什么意思呀!

非空。其后的GETPOINT不能空输入。
 楼主| 发表于 2005-9-15 15:17 | 显示全部楼层

高!实在是高!

谢!

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

本版积分规则

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

GMT+8, 2024-5-6 22:19 , Processed in 0.208092 second(s), 25 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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