明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 543|回复: 11

[提问] 高手帮帮忙

[复制链接]
发表于 2019-12-28 11:51 | 显示全部楼层 |阅读模式
如图,JMD内标注都被移动过了,不规整,现在想要批量把JMD内注记移动到封闭面中间位置,请大神帮忙

本帖子中包含更多资源

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

x
发表于 2019-12-28 20:33 | 显示全部楼层
改成居中
  1. (defun c:test1 (/ ss i en ent pt)
  2.   (setq ss (ssget '((0 . "text"))))
  3.   (command "justifytext" ss "" "m")
  4.   (repeat (setq i (sslength ss))
  5.     (setq en  (ssname ss (setq i (1- i)))
  6.           ent (entget en)
  7.           pt  (cdr (assoc 11 ent))
  8.     )
  9.     (vl-cmdf "_.boundary" pt "")
  10.     (vl-cmdf "region" (entlast) "")
  11.     (setq pt (vlax-safearray->list
  12.                (vlax-variant-value
  13.                  (vlax-get-property
  14.                    (vlax-ename->vla-object (entlast))
  15.                    'Centroid
  16.                  )
  17.                )
  18.              )
  19.     )
  20.     (entdel (entlast))
  21.     (setq ent (subst (cons 11 pt) (assoc 11 ent) ent))
  22.     (entmod ent)
  23.     (entupd en)
  24.   )
  25. )

本帖子中包含更多资源

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

x

评分

参与人数 1金钱 +20 收起 理由
zhangsk19 + 20 很给力!问题解决了,好厉害

查看全部评分

回复 支持 1 反对 0

使用道具 举报

发表于 2019-12-28 21:34 | 显示全部楼层
另一个方法
(defun c:test2 (/ ss i obj p1 p2 pt ptt)
  (setq ss (ssget))
  (repeat (setq i (sslength ss))
    (setq obj (vlax-ename->vla-object (ssname ss (setq i (1- i)))))
    (vla-getboundingbox obj 'p1 'p2)
    (setq pt (mapcar '(lambda (x y) (* 0.5 (+ x y)))
                     (vlax-safearray->list p1)
                     (vlax-safearray->list p2)
             )
    )
    (vl-cmdf "_.boundary" pt "")
    (vl-cmdf "region" (entlast) "")
    (setq ptt (vlax-safearray->list
                (vlax-variant-value
                  (vlax-get-property
                    (vlax-ename->vla-object (entlast))
                    'Centroid
                  )
                )
              )
    )
    (entdel (entlast))
    (vla-move obj (vlax-3d-point pt) (vlax-3d-point ptt))
  )
)
发表于 2019-12-28 12:46 | 显示全部楼层
不一定好使
  1. (defun c:test1 (/ ss i en ent pt)
  2.   (setq ss (ssget '((0 . "text"))))
  3.   (repeat (setq i (sslength ss))
  4.     (setq en  (ssname ss (setq i (1- i)))
  5.           ent (entget en)
  6.           pt  (cdr (assoc 10 ent))
  7.     )
  8.     (vl-cmdf "_.boundary" pt "")
  9.     (vl-cmdf "region" (entlast) "")
  10.     (setq pt (vlax-safearray->list
  11.                (vlax-variant-value
  12.                  (vlax-get-property
  13.                    (vlax-ename->vla-object (entlast))
  14.                    'Centroid
  15.                  )
  16.                )
  17.              )
  18.     )
  19.     (entdel (entlast))
  20.     (setq ent (subst (cons 10 pt) (assoc 10 ent) ent))
  21.     (entmod ent)
  22.     (entupd en)
  23.   )
  24. )
发表于 2019-12-28 13:19 | 显示全部楼层
CASS内,recass命令研究一下,注意备份原图。
 楼主| 发表于 2019-12-28 16:16 | 显示全部楼层

无法运行
 楼主| 发表于 2019-12-28 16:17 | 显示全部楼层
satan421 发表于 2019-12-28 13:19
CASS内,recass命令研究一下,注意备份原图。

重构会很麻烦
发表于 2019-12-28 20:22 | 显示全部楼层

发图测试,我这里是可以的
 楼主| 发表于 2019-12-28 20:45 | 显示全部楼层

加载程序时怎么提示我输入的字串符有缺陷
发表于 2019-12-28 21:35 | 显示全部楼层
zhangsk19 发表于 2019-12-28 20:45
加载程序时怎么提示我输入的字串符有缺陷

拷贝代码没拷贝对吧,自己改一下,也就是个思路
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-5-17 13:45 , Processed in 0.373708 second(s), 32 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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