wgij007 发表于 2019-12-8 00:36:04

能改为合拼后,上下,左右,都对中(居中)吗

本帖最后由 wgij007 于 2019-12-8 00:45 编辑

;;;*****文字合并 程序开始*****
(defun c:hbh (/ lst)
(setq oldaun (getvar "aunits"))
(setvar "aunits" 3)
(setvar "osmode" 15359)
(setvar "cmdecho" 0)
(command "undo" "be")
(princ "\n★功能:文字合并。\n \n")
(setq ss (ssget '((0 . "MTEXT,TEXT"))))
(setvar "osmode" 0)
(initget "E S A")
(if (not (setq kword
                  (getkword
                  "\n在合并文字之间加:[换行(E)/空格(S)/直接合并(A)]<E>"
                  )
         )
      )
    (setq kword "E")
)
(setvar "osmode" 0)
(setq lst '())
(while (> (sslength ss) 0)
    (setq entnam (ssname ss 0)
          entdat (entget entnam)
    )
    (setq pt(cdr (assoc 10 entdat))      ;读取文字的插入点坐标
          txt (cdr (assoc 1 entdat))      ;读取文字内容
          zg(cdr (assoc 40 entdat))      ;读取文字的字高
          lst (cons (list pt txt zg) lst) ;将点坐标、内容、字高组成表
          ss(ssdel entnam ss)                ;选择集中删除当前的文字对象
    )
    (entdel entnam)                        ;删除文字对象
)
(setq
    lst
   (vl-sort lst
(function
                (lambda      (e1 e2)
                  (if (equal (cadr (car e1)) (cadr (car e2)) 1e-4)
                  (> (car (car e1)) (car (car e2)))
                  (< (cadr (car e1)) (cadr (car e2)))
                  )
                )
            )
   )
)
(setq str "")
(cond      ((= kword "S")
         (foreach e lst
         (setq str (strcat (cadr e) " " str))
         )
      )
      ((= kword "E")
         (foreach e lst
         (setq str (strcat (cadr e) "\n" str))
         )
      )
      ((= kword "A")
         (foreach e lst
         (setq str (strcat (cadr e) str))
         )
      )
)
(command "MTEXT" pt "H" zg "W" 0 str "")
(princ "\n★提示:文字合并完成.\n")
(princ)
(setvar "aunits" oldaun)
(command "undo" "e")
(setvar "osmode" 15359)
(princ)
)
;;;*****文字合并 程序结束****



能改为合拼后,上下,左右,都对中(居中)吗

ZZXXQQ 发表于 2019-12-8 00:36:05



;;;*****文字合并 程序开始*****
(defun c:hbh (/ lst)
(setq oldaun (getvar "aunits"))
(setvar "aunits" 3)
(setvar "osmode" 15359)
(setvar "cmdecho" 0)
(command "undo" "be")
(princ "\n★功能:文字合并。\n \n")
(setq ss (ssget '((0 . "MTEXT,TEXT"))))
(setvar "osmode" 0)
(initget "E S A")
(if (not (setq kword (getkword "\n在合并文字之间加:[换行(E)/空格(S)/直接合并(A)]<E>")))
(setq kword "E")
)
(setq lst '())
(while (> (sslength ss) 0)
(setq entnam (ssname ss 0)
       entdat (entget entnam)
)
(setq pt (cdr (assoc 10 entdat)) ;读取文字的插入点坐标
       txt (cdr (assoc 1 entdat)) ;读取文字内容
       zg (cdr (assoc 40 entdat)) ;读取文字的字高
       lst (cons (list pt txt zg) lst) ;将点坐标、内容、字高组成表
       ss (ssdel entnam ss) ;选择集中删除当前的文字对象
)
(entdel entnam) ;删除文字对象
)
(setq lst
(vl-sort lst
   (function
    (lambda (e1 e2)
   (if (equal (cadar e1) (cadar e2) 1e-4) ;Y坐标
      (> (caar e1) (caar e2)) ;X坐标
      (< (cadar e1) (cadar e2)) ;Y坐标
   )
    )
   )
)
)
(setq str "")
(cond
((= kword "S")
   (foreach e lst (setq str (strcat (cadr e) " " str)))
)
((= kword "E")
   (foreach e lst (setq str (strcat (cadr e) "\n" str)))
)
((= kword "A")
   (foreach e lst (setq str (strcat (cadr e) str)))
)
)
(command "MTEXT" pt "H" zg "J" "MC" "W" 0 str "")
(princ "\n★提示:文字合并完成.\n")
(setvar "aunits" oldaun)
(command "undo" "e")
(setvar "osmode" 15359)
(princ)
)
;;;*****文字合并 程序结束****

wgij007 发表于 2019-12-9 11:31:15

本帖最后由 wgij007 于 2019-12-9 11:34 编辑

ZZXXQQ 发表于 2019-12-9 10:25

谢谢,感激.....................
页: [1]
查看完整版本: 能改为合拼后,上下,左右,都对中(居中)吗