明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 541|回复: 1

[源码] 此代码不支持选择单一图块修改颜色, 求高手把它改为可以选择单一图块修改颜色

[复制链接]
发表于 2020-9-24 11:11 | 显示全部楼层 |阅读模式
3明经币
1、目前此程序对Mtext中颜色无效,求优化  求优化  求优化
2、求高手把它改为可以选择单一图元、图块修改颜色   求优化   求优化  求优化

;;这是一个改全图颜色程序
;; 求高手把它改为对单一图元、图块修改颜色
;;改好了记得上传!!
;;By 龙龙仔(LUCAS)
(defun C:CHGBLKENTCOL (/ BLKCOL DOC OBJ COL)
  (vl-load-com)
  (arxload "acetutil.arx" NIL)
  (defun CHGCOL        (OBJ BCL COL / ATT CATT ENT1 ENT ENTNAME)
    (vlax-for ENT OBJ
      (setq ENTNAME (vla-get-objectname ENT))
      (if (= ENTNAME "AcDbBlockReference")
        (progn
          (if (= (vl-catch-all-apply 'vla-get-hasattributes (list ENT))
                 :vlax-true
              )
            (progn
              (setq ATT         (vlax-variant-value (vla-getattributes ENT))
                    CATT (vlax-variant-value
                           (vla-getconstantattributes ENT)
                         )
              )
              (if (safearray-value ATT)
                (foreach ENT1 (vlax-safearray->list ATT)
                  (vla-put-color ENT1 COL)
                )
              )
              (if (safearray-value CATT)
                (foreach ENT1 (vlax-safearray->list CATT)
                  (vla-put-color ENT1 COL)
                )
              )
            )
          )
          (CHGCOL (vla-item BCL (vla-get-name ENT)) BCL COL)
          ;;(VLA-UPDATE ENT)
        )
        (if (vlax-property-available-p ENT 'COLOR)
          (vla-put-color ENT COL)
        )
      )
      (if (or (= ENTNAME "AcDbLeader") (= ENTNAME "AcDbFcf"))
        (vla-put-dimensionlinecolor ENT COL)
      )
      (if (= ENTNAME "AcDbFcf")
        (vla-put-textcolor ENT COL)
      )
    )
  )
  (setq COL (acad_colordlg 7))
  (setq        BLKCOL (vla-get-blocks
                 (setq DOC (vla-get-activedocument
                             (vlax-get-acad-object)
                           )
                 )
               )
  )
  (acet-ui-progress "颜色转换中..." (vla-get-count BLKCOL))
  (vlax-for OBJ        BLKCOL
    (if        ;;(and
        ;;(= (vla-get-islayout OBJ) :vlax-false)
        (= (vla-get-isxref OBJ) :vlax-false)
      ;;)
      (CHGCOL OBJ BLKCOL COL)
    )
    (acet-ui-progress -1)
  )
  (acet-ui-progress)
  ;;(setvar "DIMCLRD" COL)
  ;;(setvar "DIMCLRE" COL)
  ;;(setvar "DIMCLRT" COL)
  (vla-regen DOC acallviewports)
  (vlax-release-object DOC)
  (vlax-release-object BLKCOL)
  (princ)
)

"觉得好,就打赏"
还没有人打赏,支持一下
发表于 2024-4-1 16:21 | 显示全部楼层
本帖最后由 zhangrunze 于 2024-4-1 16:35 编辑

感谢分享,可惜这个不支持多行文字改色~
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-4-27 15:16 , Processed in 0.402165 second(s), 22 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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