明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 10668|回复: 43

表格内文字居中

  [复制链接]
发表于 2017-8-4 10:47:56 | 显示全部楼层 |阅读模式
(vl-load-com)
(defun c:JZ(/ err)
(defun algion (msg /       ss      lst     i       vlalst  boxlst  x
               cor1    cor2    findboxpt       newboxpt               en1
               en      enlst   y       y2
              )
  (princ msg)
  (setq ss (ssget '((0 . "text"))))
  (setq lst nil)
  (setq i 0)
  (repeat (sslength ss)
    (setq lst (cons (ssname ss i) lst))
    (setq i (1+ i))
  )
  (setq vlalst (mapcar 'vlax-ename->vla-object lst))
  (setq        boxlst (mapcar '(lambda        (x / cor1 cor2)
                          (vla-GetBoundingBox x 'cor1 'cor2)
                          (list        (vlax-safearray->list cor1)
                                (vlax-safearray->list cor2)
                          )
                        )
                       vlalst
               )
  )
  (setq
    findboxpt (mapcar '(lambda (x)
                         (polar        (car x)
                                (angle (car x) (cadr x))
                                (/ (DISTANCE (car x) (cadr x)) 2.0)
                         )
                       )
                      boxlst
              )
  )
  (setq        newboxpt (mapcar '(lambda (x)
                            (setq en1 (entlast))
                            (vl-cmdf "_boundary" x "")
                            (setq en (entlast))
                            (if        (not (equal en1 en))
                              (progn
                                (setq enlst (entget en))
                                (setq lst (vl-remove-if-not
                                            '(lambda (y) (= (car y) 10))
                                            enlst
                                          )
                                )
                                (setq cor1 (vl-remove 10 (car lst))
                                      cor2 (vl-remove 10 (nth 2 lst))
                                )
                                (entdel en)
                                (polar cor1
                                       (angle cor1 cor2)
                                       (/ (DISTANCE cor1 cor2) 2.0)
                                )
                              )
                            )
                          )
                         findboxpt
                 )
  )

  (mapcar '(lambda (x y y2)
             (vla-move x (vlax-3d-point y) (vlax-3d-point y2))
           )
          vlalst
          findboxpt
          newboxpt
  )

)
(setq err(VL-CATCH-ALL-APPLY 'algion (list "\n 请选择单行文字: ")))
  (princ)
  )


评分

参与人数 1明经币 +1 收起 理由
USER2128 + 1 赞一个!

查看全部评分

发表于 2023-1-18 13:55:15 | 显示全部楼层
;对象居中:by zml84 2009-06-15 此基础上修改:by 忘霄
(defun C:EC (/ box en_tmp ent i pt0 pt1 ss tmp)
  (setvar "CMDECHO" 0)
  (vl-load-com)
  (princ "\n选择需要居中的对象:")
  (if (setq ss (ssget))
    (progn
      (defun box (e / ll ur)
        (vla-getboundingbox (vlax-ename->vla-object e) 'll 'ur)
        (mapcar 'vlax-safearray->list (list ll ur))
      )
      (setq i -1)
      (command "undo" "be")
      (while (setq ent (ssname ss (setq i (1+ i))))
        (setq tmp (box ent))
        (setq tmp (mapcar '+ (car tmp) (cadr tmp)))
        (setq pt0 (mapcar '* tmp '(0.5 0.5 0.5)))
        (entdel ent)
        (setq en_tmp (bpoly pt0))
        (entdel ent)
        (setq tmp (box en_tmp))
        (setq tmp (mapcar '+ (car tmp) (cadr tmp)))
        (setq pt1 (mapcar '* tmp '(0.5 0.5 0.5)))
        (command "move" ent "" "non" pt0 "non" pt1)
        (entdel en_tmp)
      )
      (command "undo" "e")
    )
    (princ "\n没有选择对象!")
  )
  (princ)
)
这个还支持实体和多行文字
回复 支持 2 反对 0

使用道具 举报

发表于 2018-8-28 12:31:45 | 显示全部楼层
挺不错的哦
回复 支持 1 反对 0

使用道具 举报

发表于 2017-10-9 16:18:15 | 显示全部楼层
回帖是一种美德!感谢楼主的无私分享 谢谢
发表于 2017-10-14 13:26:06 | 显示全部楼层
感谢楼主分享源码
发表于 2017-10-14 13:43:01 | 显示全部楼层
只支持单行文字,能增加支持所有文字,所有物体吗
发表于 2017-10-14 13:51:51 | 显示全部楼层
支持,顶顶顶
发表于 2017-11-2 16:13:29 | 显示全部楼层

回帖是一种美德!感谢楼主的无私分享
发表于 2018-5-8 10:49:50 | 显示全部楼层
不错,感谢分享
发表于 2018-8-28 11:31:50 | 显示全部楼层
感谢分享,先存起来
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-11-25 02:57 , Processed in 0.176342 second(s), 25 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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