明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
楼主: wgij007

[提问] 求一关于文本的代码

[复制链接]
发表于 2021-10-5 09:26 | 显示全部楼层
其他的自己想办法,你其他的想法的变动,我感觉都在预料之中,说不定还会一直有新的想法想要添加,所以开头说过了,仅限开始说明的情况,自己还是要学会动点脑筋,然后逐渐自己调整
回复

使用道具 举报

发表于 2021-10-5 09:39 | 显示全部楼层
还是再帮你调一次吧,后面再有啥想法,自己想想办法了哦,代码如下:


(defun c:nm (/ ss lst i en ent pt en1 en2 en3 txt1 p1 zg p2 p3 )
        (if        (setq ss (ssget (list '(0 . "text,mtext")'(62 . 1))))
                (progn
                        ;; 1、?取点位表
                       
                        (setq lst '()
                                i   0
                        )
                        (repeat (sslength ss)
                                (setq en  (ssname ss i)
                                        ent (entget en)
                                        pt  (cdr (assoc 10 ent))
                                        lst (append lst (list (list  pt en)))
                                        i          (1+ i)
                                )
                        )
                        ;; 2、排序
                        (setq
                                lst (vl-sort
                                                        lst
                                                        (function
                                                                (lambda (e1  e2)
                                                                        (if (equal (cadar e1) (cadar e2) 1e1)
                                                                                (< (caar e1) (caar e2))
                                                                                (< (cadar e1) (cadar e2))
                                                                        )
                                                                )
                                                        )
                                                )
                        )
                )
        )
        ; 3、文字
        (setq en1 (cadadr lst) en2 (cadr(last lst)) en3 (cadar lst))
        (setq txt1(strcat (cdr(assoc 1 (entget en3)))"kli"))  ;命名加了后?的文字  "kli" ?里自定?需要增加的那个文字的后?
        (setq zg(cdr (assoc 40 (entget en1))))
        (setq p1 (getpoint "\n?指定插入点:"))
        (setq p2 (polar p1 (* 1.5 pi)  (* 2.2 zg)))
        (setq p3 (polar p2 (* 1.5 pi)  (* 2.2 zg)))
        (setq pt1(cdr  (assoc 10 (entget en2))))
        (command "COPY" ss "" "non" pt1 "non" pt1)
        (entmod(subst(cons 10  p1)(assoc 10 (entget en2))(entget en2))) ;更新插入点
        (entmod(subst(cons 10  p2)(assoc 10 (entget en3))(entget en3))) ;更新插入点
        (entmod(subst(cons 10  p3)(assoc 10 (entget en1))(entget en1))) ;更新插入点
        (entmod(subst(cons 1  txt1)(assoc 1 (entget en3))(entget en3))) ;更新需要加了后?的文字
        (princ)
)
回复

使用道具 举报

 楼主| 发表于 2021-10-6 07:46 | 显示全部楼层
xj6019 发表于 2021-10-5 09:39
还是再帮你调一次吧,后面再有啥想法,自己想想办法了哦,代码如下:

好的,感谢!!!!!!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-10 14:03 , Processed in 0.133045 second(s), 18 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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