明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 3980|回复: 27

[已解答] 求框选文字和圆,将字高和圆直径统一

[复制链接]
发表于 2013-12-7 21:14 | 显示全部楼层 |阅读模式
2明经币
图中有多种字高的文字(包括多行文字、单行文字),还有多种圆直径,现在希望能框选这些文字和圆,然后文字的字高统一为300,圆直径统一为150,其中包含编组,希望编组不会被分解,圆心位置不被移动,请明经的大侠出手相助!
附件: 您需要 登录 才可以下载或查看,没有账号?注册

最佳答案

查看完整内容

。。。。
发表于 2013-12-7 21:14 | 显示全部楼层
  1. (defun c:ty(/ ss en e txth dr)  
  2.   (prompt "\n请选择需要统一直径与字高的圆、文字:")
  3.   (if (setq ss(ssget '((0 . "*text,circle"))))
  4.     (progn
  5.       (or (setq dr(getreal "\n输入统一圆的直径值<150>:"))(setq dr 150))
  6.       (or (setq txth(getreal "\n输入统一的文字高度值<300>:"))(setq txth 300))
  7.       (while (setq en(ssname ss 0))
  8.         (setq e(entget en))
  9.         (cond
  10.           ((wcmatch (cdr(assoc 0 e)) "*TEXT" )(entmod (subst (cons 40 txth) (assoc 40 e) e)))
  11.           ((wcmatch (cdr(assoc 0 e)) "CIRCLE" )(entmod (subst (cons 40 (* dr 0.5)) (assoc 40 e) e)))
  12.           )
  13.         (setq ss(ssdel en ss))
  14.         )
  15.       )
  16.     (princ "\n Noting !!!")
  17.     )
  18.     (princ)
  19.     )
。。。。
回复

使用道具 举报

发表于 2013-12-7 21:48 | 显示全部楼层
本帖最后由 1993063 于 2013-12-7 03:50 编辑
  1. 这个简单<img src="http://bbs.mjtd.com/static/image/smiley/qq/em34.gif" border="0" smilieid="116" alt="" style="line-height: 1.5;">
复制代码
回复

使用道具 举报

发表于 2013-12-7 21:49 | 显示全部楼层
  1. ;;;字高300,圆半径150 1993063 2013.12.07
  2. (Defun C:tt ( / en i ss ty)
  3.   (setq i -1 ss (ssget '((0 . "*TEXT,CIRCLE"))))
  4.   (progn
  5.     (repeat (setq i (sslength ss ))
  6.      (setq en (ssname ss (setq i (1- i))) ty (cdr (Assoc 0 (Entget en))))
  7.       (cond
  8.        ((= ty "TEXT")     (Entmod (subst(cons 40 300)(Assoc 40(Entget en))(Entget en))))
  9.        ((= ty "MTEXT")    (Entmod (subst(cons 40 300)(Assoc 40(Entget en))(Entget en))))
  10.        ((= ty "CIRCLE")   (Entmod (subst(cons 40 75) (Assoc 40 (Entget en))(Entget en))))
  11.       )
  12.     )
  13.   )
  14. )

评分

参与人数 1明经币 +1 收起 理由
半听可乐 + 1 感谢朋友你热心及时的回复,程序很好用!

查看全部评分

回复

使用道具 举报

发表于 2013-12-7 22:13 | 显示全部楼层
什么叫编组?

点评

这不太像革大侠问的问题哦  发表于 2013-12-7 22:39
回复

使用道具 举报

发表于 2013-12-7 22:31 | 显示全部楼层
;;这个更通用一点的
(Defun C:tt (/ en i ss ty)
  (setq *th* (ureal 1 "" "文字高度" *th*))
  (setq *cr* (ureal 1 "" "圆半径" *cr*))
  (if (setq i  -1 ss (ssget '((0 . "*TEXT,CIRCLE"))))
     (progn
       (repeat (setq i (sslength ss))
         (setq en (ssname ss (setq i (1- i)))
               ty (cdr (Assoc 0 (Entget en)))
         )(setq cr (/ *cr* 2))
         (cond
           ((= ty "TEXT") (Entmod (subst (cons 40 *th*) (Assoc 40 (Entget en)) (Entget en))))
           ((= ty "MTEXT") (Entmod (subst (cons 40 *th*) (Assoc 40 (Entget en)) (Entget en))))
           ((= ty "CIRCLE") (Entmod (subst (cons 40 cr) (Assoc 40 (Entget en)) (Entget en))))
         )
       )
     )
  )(princ)
)
;;  udist 函数地址:http://bbs.mjtd.com/thread-99928-1-1.html
回复

使用道具 举报

 楼主| 发表于 2013-12-7 22:35 | 显示全部楼层
1993063 发表于 2013-12-7 21:49

非常感谢,程序完全满足我的初衷,同时楼下的朋友那个程序似乎要更灵活一些,补充了我的需求,可惜最佳答案只能选一个,非常感谢你第一时间为我解答!
回复

使用道具 举报

 楼主| 发表于 2013-12-7 22:38 | 显示全部楼层
edata 发表于 2013-12-7 21:14
。。。。

万分感谢你和“1993063”这位朋友,你们的程序都完全满足我的需求,你的这个更灵活些,惊喜!
回复

使用道具 举报

发表于 2013-12-7 22:39 | 显示全部楼层
没事儿堆堆码
回复

使用道具 举报

发表于 2013-12-7 22:42 | 显示全部楼层
半听可乐 发表于 2013-12-7 04:38
万分感谢你和“1993063”这位朋友,你们的程序都完全满足我的需求,你的这个更灵活些,惊喜!

楼主要自己学会简单的代码,其实像这样没技术含量
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-4-20 19:43 , Processed in 0.653176 second(s), 26 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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