找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1362|回复: 3

[求助] 如何批量标注

[复制链接]

已领礼包: 343个

财富等级: 日进斗金

发表于 2013-12-12 19:35:23 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

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

×
本帖最后由 429014673 于 2013-12-12 19:36 编辑

QQ截图20131212193601.png


求一独立程序源码
如上图,如何批量标注:众多基准点(块)的插入点到一基准线的垂直距离标注
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
发表于 2013-12-12 21:27:40 | 显示全部楼层
为什么要独立程序呢?
  1. (defun c:tt (/ e ss i e1 el ms an an1)
  2.   (vl-load-com)
  3.   (if (and (setq e (car (entsel "\nPick Line: ")))
  4.            (= (cdr (assoc 0 (entget e))) "LINE")
  5.            (setq ss (ssget '((0 . "INSERT"))))
  6.       )
  7.     (progn
  8.       (setq i        -1
  9.             ms        (vla-get-modelspace
  10.                   (vla-get-activedocument (vlax-get-acad-object))
  11.                 )
  12.             an        (angle (vlax-curve-getstartpoint e)
  13.                        (vlax-curve-getendpoint e)
  14.                 )
  15.             an1        (+ an (* pi 0.5))
  16.       )
  17.       (while (setq e1 (ssname ss (setq i (1+ i))))
  18.         (setq el (cons (cdr (assoc 10 (entget e1))) el))
  19.       )
  20.       (mapcar
  21.         '(lambda (x)
  22.            (vla-AddDimRotated
  23.              ms
  24.              (vlax-3d-point (car x))
  25.              (vlax-3d-point (cadr x))
  26.              (vlax-3d-point (polar (cadr x) an 6.))
  27.              an1
  28.            )
  29.          )
  30.         (mapcar
  31.           '(lambda (p)
  32.              (list p
  33.                    (vlax-curve-getclosestpointto e p)
  34.              )
  35.            )
  36.           el
  37.         )
  38.       )
  39.     )
  40.   )
  41.   (princ)
  42. )

评分

参与人数 2D豆 +10 收起 理由
429014673 + 5 非常感觉Free-Lancer大师的作品
1993063 + 5 好利害!

查看全部评分

论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2013-12-12 22:45:06 | 显示全部楼层
本帖最后由 Free-Lancer 于 2013-12-12 22:47 编辑

用 a/vlisp 就这样写,用到的函数在附件中(fas)
  1. (defun c:tt (/ e an an1)
  2.   (vl-load-com)
  3.   (fy:begin)
  4.   (if (and (setq e (car (entsel "\nPick Line: ")))
  5.            (= (cdr (assoc 0 (entget e))) "LINE")
  6.            (ssget '((0 . "INSERT")))
  7.       )
  8.     (progn
  9.       (setq an        (vlax-get (e2o e) 'Angle)
  10.             an1        (+ an _pi2)
  11.       )
  12.       (mapcar
  13.         '(lambda (x)
  14.            (vla-AddDimRotated
  15.              (fy:acms)
  16.              (vlax-3d-point (car x))
  17.              (vlax-3d-point (cadr x))
  18.              (vlax-3d-point (polar (cadr x) an 6.))
  19.              an1
  20.            )
  21.          )
  22.         (mapcar
  23.           '(lambda (x / p)
  24.              (setq p (vlax-get x 'Insertionpoint))
  25.              (list p
  26.                    (vlax-curve-getclosestpointto e p)
  27.              )
  28.            )
  29.           (fy:cset->objs)
  30.         )
  31.       )
  32.     )
  33.   )
  34.   (fy:end)
  35.   (princ)
  36. )

app.rar

5.16 KB, 下载次数: , 下载积分: D豆 -1 , 活跃度 1

论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 1268个

财富等级: 财源广进

发表于 2013-12-13 08:36:33 | 显示全部楼层
不如用用 API,省去中间转换,面向对象,可以随手写
  1. (defun c:tt (/ e ss an an1)
  2.   (if (and (setq e (car (xdrx_entsel "\n选择直线: " '((0 . "Line")))))
  3.            (progn
  4.              (princ "\n选择图块....")
  5.              (setq ss (ssget '((0 . "INSERT"))))
  6.            )
  7.       )
  8.     (progn
  9.       (setq an        (xdrx_getpropertyvalue e "Angle")
  10.             an1        (+ an (* pi 0.5))
  11.       )
  12.       (mapcar
  13.         '(lambda (x)
  14.            (xdrx_dimension_makerotate
  15.              (car x)
  16.              (cadr x)
  17.              (polar (cadr x) an 6.)
  18.              an1
  19.            )
  20.          )
  21.         (mapcar
  22.           '(lambda (e1 / p)
  23.              (setq p (xdrx_getpropertyvalue e1 "Position"))
  24.              (list p
  25.                    (vlax-curve-getclosestpointto e p)
  26.              )
  27.            )
  28.           (xdrx_pickset->ents ss)
  29.         )
  30.       )
  31.     )
  32.   )
  33.   (princ)
  34. )

评分

参与人数 1D豆 +5 收起 理由
429014673 + 5 谢谢你的帮助

查看全部评分

论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

QQ|申请友链|Archiver|手机版|小黑屋|辽公网安备|晓东CAD家园 ( 辽ICP备15016793号 )

GMT+8, 2024-9-25 02:22 , Processed in 0.518074 second(s), 42 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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