求助:如何获取普通图块内直线与文字的组码
请问老师们如何获取普通图块内直线与文字的组码?(defun c:tt8 ( / ss en x)
(setq ss (ssget '((0 . "insert"))))
(foreach en
(vl-remove-if
'(lambda(x)(/= (type x) 'ENAME))
(mapcar 'cadr (ssnamex ss));栏选只要这句即可
);图元名列表
(setblk en)
)
)
;修改块内文字、直线颜色(setblk)
(defun setblk (en / e)
(setq e (TBLOBJNAME "block" (cdr(assoc 2(entget en)))))
(while(setq e (entnext e))
(cond
((= (cdr(assoc 0(entget e))) "TEXT")
(setdxf e (cons 62 3));修改颜色为绿色
)
((= (cdr(assoc 0(entget e))) "LINE")
(setdxf e (cons 62 1));修改颜色为红色
)
(t nil)
)
)
(entupd en);更新显示
)
;按新的点对表修改组码表更新图元
;(setdxf (car(entsel)) (cons 62 1))
(defun setdxf(en xin / enb)
(if(assoc (car xin) (setq enb (entget en)))
(entmod(subst xin (assoc (car xin) enb)enb))
(entmod (cons xin enb))
)
) nentselnentselp wzg356 发表于 2020-10-7 20:26
;修改块内文字、直线颜色(setblk)
(defun setblk ( / en e)
(setq en(car(entsel)));确保选块
谢谢老师,测试了一下,还有一点问题就是1不能批量2文字的颜色要变成绿色。我把自己找的源码给老师看看。祝近安!
(defun c:tt ()
(if (setq ssa (ssget '((0 . "insert")))) ;批量框选
(progn
(setq i 0)
(setq n (sslength ssa))
(repeat n
(setq s1 (ssname ssa i))
(foreach a (xyp-Block-OnameList (vlax-ename->vla-object s1))
(cond ((xyp-Etype (vlax-vla-object->ename a) "line")
(vla-put-color a 1);修改直线为红色
)
((xyp-Etype (vlax-vla-object->ename a) "*text")
(vla-put-color a 3);修改文字为绿色
)
)
)
(setq i (1+ i))
)
(command "REGEN" )
)
)
(princ)
) (while (and(setq e (entnext e))
(/= (cdr (assoc 0 (setq es (entget e)))) "SEQEND")
)
e是块 wzg356 发表于 2020-10-2 21:13
(while (and(setq e (entnext e))
(/= (cdr (assoc 0 (setq es (entget e)))) "SEQEND") ...
已经收到我研究研究,有进展了在汇报上传源码,谢谢老师给予指导 wzg356 发表于 2020-10-2 21:13
(while (and(setq e (entnext e))
(/= (cdr (assoc 0 (setq es (entget e)))) "SEQEND") ...
组码是得到了,问题的得到的组码太多了,如何一个一个去替换那要替换到什么时候 zhangcan0515 发表于 2020-10-7 15:44
组码是得到了,问题的得到的组码太多了,如何一个一个去替换那要替换到什么时候
你到底要干啥,while循环着的 wzg356 发表于 2020-10-7 16:11
你到底要干啥,while循环着的
得到普通块内部组码去修改块的颜色,因为块内有直线和文字 ;修改块内文字、直线颜色(setblk)
(defun setblk ( / en e)
(setq en(car(entsel)));确保选块
(setq e (TBLOBJNAME "block" (cdr(assoc 2(entget en)))))
(while(setq e (entnext e))
(if(or (= (cdr(assoc 0(entget e))) "TEXT")
(= (cdr(assoc 0(entget e))) "LINE")
)
(setdxf e (cons 62 1));修改颜色为红色
)
)
(entupd en);更新显示
)
;按新的点对表修改组码表更新图元
;(setdxf (car(entsel)) (cons 62 1))
(defun setdxf(en xin / enb)
(if(assoc (car xin) (setq enb (entget en)))
(entmod(subst xin (assoc (car xin) enb)enb))
(entmod (cons xin enb))
)
) 获取普通图块内部信息组码,需要学习的可以拿走学习
(defun c:tt ()
(setq ss (ssget (list '(0 . "INSERT"))))
(getblockent ss))
;获取块内对象
(defun getblockent (ss / sslen ename enlast)
(repeat (setq sslen (sslength ss))
(setq ename (ssname ss (setq sslen (1- sslen))))
(setq enlast (tblobjname "block" (cdr (assoc 2 (entget ename)))))
(while (setq enlast (entnext enlast))
(princ (entget enlast))
)
)
(princ)
)
页:
[1]
2