能改为合拼后,上下,左右,都对中(居中)吗
本帖最后由 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)
)
;;;*****文字合并 程序结束****
能改为合拼后,上下,左右,都对中(居中)吗
;;;*****文字合并 程序开始*****
(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:34 编辑
ZZXXQQ 发表于 2019-12-9 10:25
谢谢,感激.....................
页:
[1]