找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 480|回复: 0

[LISP程序]:超级文本格式刷,欢迎大家使用及测试!

[复制链接]
发表于 2005-11-1 09:17:26 | 显示全部楼层 |阅读模式

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

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

×
(Defun C:Mt (/ Oldblp Oldech Key I Ent1        En Ss Nel Val_List J List_Len
             Val El N)
   (Initget "N G Q T Y X C A")
  (Setq
    Key
     (Getkword
       "\N/内容(N)/高度(G)/图层(C)/样式(Y)/倾斜角(Q)/旋转角(X)/高宽比(W)/全部(A)/(默认A): "
     )
  )
  (Cond
    ((= Key "N") (Setq I 1))
    ((= Key "G") (Setq I 40))
    ((= Key "C") (Setq I 8))
    ((= Key "Y") (Setq I 7))
    ((= Key "Q") (Setq I 51))
    ((= Key "X") (Setq I 50))
    ((= Key "W") (Setq I 41))
    ((= Key "A") (Setq I 0))
    (T (Setq I 0))
  )
  (Setq Ent1 (Car (Entsel "\N先点选源文本:")))
  (While (= Ent1 Nil)
    (Princ "\N没有选中文本对象!")
    (Setq Ent1 (Car (Entsel "\先点选源文本:")))
    )
  (Setq En (Entget Ent1))
  (While (/= "Text" (Cdr (Assoc 0 En)))
    (Progn
      (Princ "对象不是文本,重新选择!")
      (Setq Ent1 (Car (Entsel "\N先点选源文本:")))
      (Setq En (Entget Ent1))
    )
  )
  (Princ "\N再选择目标文本:")
  (If (Setq Ss (Ssget '((0 . "Text"))))
    (Progn
      (Setq N 0)
      (While (< N (Sslength Ss))
        (Setq El (Entget (Ssname Ss N)))
        (If (= I 0)
          (Progn
            (Setq J 0)
            (Setq Val_List (List 1 40 8 7 50 51 41))
            (Setq List_Len (Length Val_List))
            (While (< J List_Len)
              (Setq Val (Nth J Val_List))
              (Setq El
                     (Entmod (Subst
                               (Cons Val (Cdr (Assoc Val En)))
                               (Assoc Val El)
                               El
                             )
                     )
              )
              (Setq J (1+ J))
            )
          )
          (Progn
            (Setq Val I)
            (Setq El
                   (Entmod (Subst
                             (Cons Val (Cdr (Assoc Val En)))
                             (Assoc Val El)
                             El
                           )
                   )
            )
          )
        )
        (Setq N (1+ N))
      )
    )
  )
    (Princ)
)
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

GMT+8, 2025-9-28 18:37 , Processed in 0.161770 second(s), 30 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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