明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 1488|回复: 13

[提问] 求助:如何获取普通图块内直线与文字的组码

[复制链接]
发表于 2020-10-2 13:17 | 显示全部楼层 |阅读模式
请问老师们如何获取普通图块内直线与文字的组码?

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?注册

x
"觉得好,就打赏"
还没有人打赏,支持一下
发表于 2020-10-7 22:14 | 显示全部楼层
(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))
        )
)

评分

参与人数 1明经币 +1 收起 理由
zhangcan0515 + 1 我的图块是0层--文字颜色163号,线可以修改.

查看全部评分

回复 支持 1 反对 0

使用道具 举报

发表于 2020-10-2 14:35 | 显示全部楼层
nentsel  nentselp
回复 支持 1 反对 0

使用道具 举报

 楼主| 发表于 2020-10-7 20:49 | 显示全部楼层
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)
)
发表于 2020-10-2 21:13 | 显示全部楼层
(while (and  (setq e (entnext e))
               (/= (cdr (assoc 0 (setq es (entget e)))) "SEQEND")
         )

e是块
 楼主| 发表于 2020-10-3 10:11 | 显示全部楼层
wzg356 发表于 2020-10-2 21:13
(while (and  (setq e (entnext e))
               (/= (cdr (assoc 0 (setq es (entget e)))) "SEQEND") ...

已经收到我研究研究,有进展了在汇报上传源码,谢谢老师给予指导
 楼主| 发表于 2020-10-7 15:44 | 显示全部楼层
wzg356 发表于 2020-10-2 21:13
(while (and  (setq e (entnext e))
               (/= (cdr (assoc 0 (setq es (entget e)))) "SEQEND") ...

组码是得到了,问题的得到的组码太多了,如何一个一个去替换那要替换到什么时候
发表于 2020-10-7 16:11 | 显示全部楼层
zhangcan0515 发表于 2020-10-7 15:44
组码是得到了,问题的得到的组码太多了,如何一个一个去替换那要替换到什么时候

你到底要干啥,while循环着的
 楼主| 发表于 2020-10-7 16:13 | 显示全部楼层
wzg356 发表于 2020-10-7 16:11
你到底要干啥,while循环着的

得到普通块内部组码去修改块的颜色,因为块内有直线和文字
发表于 2020-10-7 20:26 | 显示全部楼层
;修改块内文字、直线颜色(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))
        )
)

评分

参与人数 1明经币 +1 收起 理由
zhangcan0515 + 1

查看全部评分

 楼主| 发表于 2020-10-7 20:56 | 显示全部楼层
获取普通图块内部信息组码,需要学习的可以拿走学习
(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)
  )
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-4-20 17:47 , Processed in 0.175722 second(s), 29 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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