明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 2976|回复: 8

[转帖][求助]急,急,急,哪位高手帮忙改一下,改图块颜色和层的。

[复制链接]
发表于 2007-2-8 12:46:00 | 显示全部楼层 |阅读模式

我只想要改图块层的功能,不想改其颜色。

(defun C:ch (/ COL SS CNT IDX BLKNAME DONELIST)
  (defun GRP (GCC EL) (cdr (assoc GCC EL)))
  (defun UPDATE (BNAME COL / ENAME ELIST)
    (setq ENAME (tblobjname "BLOCK" BNAME))
    (if
      (and ENAME
    (zerop (logand 52 (GRP 70 (entget ENAME '("*")))))
      )
       (progn
  (while ENAME
    (if (or (= "INSERT" (GRP 0 (entget ENAME)))
     (= "DIMENSION" (GRP 0 (entget ENAME)))
        )
      (UPDATE (GRP 2 (entget ENAME)) COL)
    )
    (setq ELIST (entget ENAME '("*"))
   ELIST (subst '(8 . "0") (assoc 8 ELIST) ELIST)
   ELIST (if (assoc 62 ELIST)
    (subst (cons 62 COL) (assoc 62 ELIST) ELIST)
    (append ELIST (list (cons 62 COL)))
         )
    )
    (entmod ELIST)
    (setq ENAME (entnext ENAME))
  )
  't
       )
    )
  )
  (if (> (logand (GRP 70 (tblsearch "layer" "0")) 1) 0)
    (princ "\nLayer 0 must be thawed before running FIXBLOCK!\n"
    )
    (progn
      (if
 (progn
   (setq COL (acad_colordlg 7))
   (princ "\nPress  to fix all Blocks New Color\n")
   (setq CNT 0
  SS  (ssget '((0 . "INSERT,DIMENSION")))
   )
 )
  (progn
    (setq IDX (sslength SS))
    (while (>= (setq IDX (1- IDX)) 0)
      (if
        (not
   (member (setq BLKNAME (GRP 2 (entget (ssname SS IDX))))
    DONELIST
   )
        )
  (progn
    (if (UPDATE BLKNAME COL)
      (setq CNT (1+ CNT))
    )
    (setq DONELIST (cons BLKNAME DONELIST))
  )
      )
    )
  )
  (while (setq BLKNAME (GRP 2 (tblnext "BLOCK" (not BLKNAME))))
    (if (UPDATE BLKNAME COL)
      (setq CNT (1+ CNT))
    )
  )
      )
      (princ (strcat "\n"
       (itoa CNT)
       " block"
       (if (= CNT 1)
         ""
         "s"
       )
       " redefined New Color\n"
      )
      )
    )
  )
  (command "_.REGEN")
  (princ)
)

"觉得好,就打赏"
还没有人打赏,支持一下
 楼主| 发表于 2007-2-9 13:01:00 | 显示全部楼层

回复:(userzhl)[转帖][求助]急,急,急,哪位高手帮...

高手都到哪去了呢?
 楼主| 发表于 2007-2-10 13:17:00 | 显示全部楼层
版主都到哪去了?
发表于 2007-2-10 17:07:00 | 显示全部楼层
本帖最后由 作者 于 2007-2-10 17:43:51 编辑

  1. (defun C:cc (/ *DOC blocks ss)
  2.   (vl-load-com)
  3.   (setq *DOC (vla-get-activeDocument (vlax-get-acad-object)))
  4.   (setq blocks (vla-get-blocks *Doc))    ;得到文件的块集合
  5.   (prompt "\n请选择块: ")
  6.   (if (setq ss (ssget '((0 . "INSERT"))));得到块的选择集
  7.     (change-block-layer ss)              ;全部改层
  8.   )
  9.   ;;(vla-regen *DOC acActiveViewPort)         
  10.   (princ)
  11. )
  12. ;;;改层函数
  13. (defun change-block-layer (ss / i l ename elist bname blist Layer)
  14.   (setq i 0 l (sslength ss))            ;计数器清零
  15.   (while (< i l)
  16.     (setq EName (ssname ss i))          ;得到插入块图元名
  17.     (setq EList (entget EName))         ;得到插入块图元表
  18.     (setq Layer (cdr (assoc 8 Elist)))  ;得到插入块图层
  19.     (setq BName (cdr (assoc 2 EList)))  ;得到插入块块名
  20.     (setq BList (vla-item blocks BName));得到块内实体集合
  21.     (vlax-for n Blist
  22.       (vla-put-layer n Layer)           ;对块内每个实体改变图层
  23.     )
  24.     (entupd EName)                      ;更新插入块图元数据
  25.     (setq i (1+ i))                     ;计数器加一
  26.   )
  27. )
不知道是不是你想要的?

评分

参与人数 1明经币 +1 收起 理由
flytoday + 1 大师两个图层的图元组成块无法一次改层

查看全部评分

发表于 2007-2-10 17:19:00 | 显示全部楼层
  1. ;我只想要改图块层的功能,不想改其颜色。
  2. (defun C:ch (/ COL SS CNT IDX BLKNAME DONELIST)
  3. (defun GRP (GCC EL) (cdr (assoc GCC EL)))
  4. (defun UPDATE (BNAME COL / ENAME ELIST)
  5.   (setq ENAME (tblobjname "BLOCK" BNAME))
  6.   (if (and ENAME (zerop (logand 52 (GRP 70 (entget ENAME '("*")))))) (progn
  7.    (while ENAME
  8.     (if (or (= "INSERT" (GRP 0 (entget ENAME)))
  9.      (= "DIMENSION" (GRP 0 (entget ENAME)))
  10.         )
  11.       (UPDATE (GRP 2 (entget ENAME)) COL)
  12.     )
  13.     (setq ELIST (entget ENAME '("*"))
  14.    ELIST (subst '(8 . "0") (assoc 8 ELIST) ELIST)
  15. ;   ELIST (if (assoc 62 ELIST)
  16. ;     (subst (cons 62 COL) (assoc 62 ELIST) ELIST)
  17. ;     (append ELIST (list (cons 62 COL)))
  18. ;         )
  19.     )
  20.     (entmod ELIST)
  21.     (setq ENAME (entnext ENAME))
  22.    )
  23.    't
  24.    )
  25.   )
  26. )
  27. (if (> (logand (GRP 70 (tblsearch "layer" "0")) 1) 0)
  28.   (princ "\nLayer 0 must be thawed before running FIXBLOCK!\n")
  29. (progn
  30.   (if (progn (setq COL 256); (setq COL (acad_colordlg 7))
  31.    (princ "\nPress  to fix all Blocks New Color\n")
  32.    (setq CNT 0 SS  (ssget '((0 . "INSERT,DIMENSION"))))
  33.       )
  34.   (progn
  35.    (setq IDX (sslength SS))
  36.    (while (>= (setq IDX (1- IDX)) 0)
  37.     (if (not (member (setq BLKNAME (GRP 2 (entget (ssname SS IDX)))) DONELIST)) (progn
  38.      (if (UPDATE BLKNAME COL) (setq CNT (1+ CNT)))
  39.      (setq DONELIST (cons BLKNAME DONELIST))
  40.     ))
  41.    )
  42.   )
  43.   (while (setq BLKNAME (GRP 2 (tblnext "BLOCK" (not BLKNAME))))
  44.    (if (UPDATE BLKNAME COL) (setq CNT (1+ CNT)))
  45.   )
  46. )
  47.   (princ
  48.    (strcat "\n" (itoa CNT) " block" (if (= CNT 1) "" "s") " redefined New Color\n")
  49.   )
  50. )
  51. )
  52. (command "_.REGEN")
  53. (princ)
  54. )
发表于 2008-11-20 17:03:00 | 显示全部楼层

好程序,我也写了两个,改天传上来

发表于 2010-5-26 16:37:00 | 显示全部楼层

感谢各位高手提供

发表于 2010-12-29 11:55:04 | 显示全部楼层
学习了,谢谢!
发表于 2013-1-7 18:19:36 | 显示全部楼层
学习了 应该不错
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-6-2 11:22 , Processed in 0.194607 second(s), 27 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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