明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 1404|回复: 1

lisp转换为vba

[复制链接]
发表于 2012-5-15 13:14 | 显示全部楼层 |阅读模式
求助lisp高手,如何把下面这段lisp写的改块颜色转换为vba

;;终于明白了(以前从来都不知道),得到的结论是:
;;块中的引线和公差颜色为 ByBlock ,不随块本身的颜色的变化而变化。
(defun c:ChBlkColor (/ ss co i obj bn bnlst)
  (if (and (setq ss (ssget '((0 . "insert"))))
           (setq co (acad_colordlg 7))
      )
    (progn
      (repeat (setq i (sslength ss))
        (setq obj (vlax-ename->vla-object (ssname ss (setq i (1- i))))
              bn  (vla-get-name obj)
        )
        (vla-put-color obj co)
        (if (and (= (vla-get-ObjectName obj) "AcDbBlockReference")
                 (= (vla-get-HasAttributes obj) :vlax-true)
            )
          (foreach x (vlax-invoke obj 'getattributes)
            (vla-put-color x 0)
          )
        )
        (if (not (member bn bnlst))
          (setq bnlst (cons bn bnlst))
        )
      )
      (setq blks (vla-get-blocks (vla-get-activedocument (vlax-get-acad-object))))
      (foreach x bnlst
        (vlax-for obj (vla-item blks x)
          (if (member (vla-get-ObjectName obj) '("AcDbFcf" "AcDbLeader"))
            (vla-put-color obj co)
            (vla-put-color obj 0)
          )
        )
      )
    )
  )
  (princ)
)
lisp开发版原帖地址
http://bbs.mjtd.com/thread-68173-1-1.html
发表于 2012-5-26 17:57 | 显示全部楼层
同问            
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-5-21 06:53 , Processed in 0.384707 second(s), 27 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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