明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
12
返回列表 发新帖
楼主: iszc

[提问] 求快速修改所有图元颜色的源码

[复制链接]
发表于 2020-4-2 09:26:10 | 显示全部楼层
(defun c:resetcolor (/ c)
  (setq cmd (getvar "cmdecho"))
  (setvar "cmdecho" 0)
  (setq Document (vla-get-ActiveDocument (vlax-get-acad-object)))
  (setq Blocks (vla-get-blocks Document))
  (vla-StartUndoMark Document)

  (setq c  8 )

  (If (progn
          (princ "\n请选择要更改颜色的图元:")
          (setq ssa (ssget))
      )
      (vlax-for Obj (vla-get-ActiveSelectionSet Document)
         (vl-catch-all-apply 'vla-put-color (list Obj c))

         (if (= "AcDbBlockReference" (vla-get-objectname Obj))
             (progn
                 (vlax-for BlkObj (vla-item Blocks (vla-get-name Obj))
                       (vl-catch-all-apply 'vla-put-color (list BlkObj c))
                 )
                 (if (= :vlax-true (vla-get-hasattributes Obj))
                     (foreach AttObj (vlax-safearray->list
                                           (vlax-variant-value (vla-getattributes Obj))
                                     )
                         (vl-catch-all-apply 'vla-put-color (list AttObj c))
                     )
                 )
             )
         )
      )
  )
  (vla-EndUndoMark Document)
  (vlax-release-object Blocks)
  (vlax-release-object Document)
  (setvar "cmdecho" cmd)
  (princ)
)
回复

使用道具 举报

发表于 2020-4-2 09:55:32 | 显示全部楼层
vectra 发表于 2017-9-25 09:03
增加了对属性的支持
不需要选择颜色时可将(setq c (acad_colordlg 8))这行修改为(setq c 8)

能否加入可以选择图元
回复

使用道具 举报

发表于 2020-4-13 20:38:25 | 显示全部楼层
非常感谢
回复

使用道具 举报

发表于 2020-4-16 11:24:42 | 显示全部楼层
非常好用
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-24 22:46 , Processed in 0.171713 second(s), 17 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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