明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

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

[源码] 求助各位大佬们

[复制链接]
发表于 2024-10-28 14:27:20 | 显示全部楼层
全图所有标注都改
  1. (vlax-for blk (vla-get-blocks
  2.                 (vla-get-activedocument (vlax-get-acad-object))
  3.               )
  4.   (vlax-for dim        blk
  5.     (and (= (substr (vla-get-name dim) 1 2) "*D")
  6.          (= (vla-put-ExtensionLineColor dim 1)
  7.             (vla-put-DimensionLineColor dim 2)
  8.          )
  9.     )
  10.   )
  11. )
发表于 2024-10-30 17:00:41 | 显示全部楼层
修改框选中的所有标注(含块内标注)的线的颜色,借荐了另一个老师的部分代码
  1. (defun c:tt()
  2.   (vl-load-com)
  3.   (setq bnlst nil)
  4.   (setq ss(ssget '((0 . "insert,*Dimension"))))
  5.   (setq col(acad_colordlg 1))
  6.   (setq i 0)
  7.   (repeat (sslength ss)
  8.   (setq obj(ssname ss i) v_obj(vlax-ename->vla-object obj))
  9.   (setq blks(vla-get-blocks(vla-get-activedocument(vlax-get-acad-object))))
  10.   
  11.   (If (= (cdr (assoc 0 (entget obj))) "INSERT")
  12.     (chblkcolor blks v_obj col)
  13.     (progn
  14.      (if (and  (/= (vla-get-objectname v_obj) "AcDbDiametricDimension")
  15.                (/= (vla-get-objectname v_obj) "AcDbRadialDimension")
  16.                )
  17.      (vla-put-ExtensionLineColor v_obj col)
  18.        )
  19.      (vla-put-DimensionLineColor v_obj col)
  20.       )
  21.     )
  22.     (setq i(1+ i))
  23.     )
  24.       
  25.   
  26.   )

  27. (defun ChBlkColor (Blks Obj Color / BlkName oName)
  28.     ;; 定义一个内部递归函数 ChBlkColor,用于处理块的颜色和图层设置
  29.     (setq BlkName (vla-get-name obj))                          ;; 获取块的名称
  30.     (if (not (member BlkName bnlst))                           ;; 如果块名称不在已处理的列表中
  31.       (progn
  32.         (setq bnlst (cons BlkName BnLst))                      ;; 将块名称添加到已处理列表中
  33.         (vlax-for X (vla-item Blks BlkName)                    ;; 遍历块中的所有对象
  34.           (setq oName (vla-get-ObjectName X))                  ;; 获取对象的名称
  35.           (cond
  36.             ((wcmatch oName "*Dimension,AcDbLeader,AcDbFcf")   ;; 如果对象是尺寸、引线或填充字符
  37.               (vla-put-DimensionLineColor X Color)             ;; 设置尺寸线颜色
  38.               (if (wcmatch oName "*Dimension")                 ;; 如果对象是尺寸
  39.                 (progn
  40.                 (if (and  (/= oname "AcDbDiametricDimension")
  41.                    (/= oname "AcDbRadialDimension")
  42.                  )
  43.                   (vla-put-ExtensionLineColor X Color)         ;; 设置延伸线颜色
  44.                   )
  45.                   (if (setq BlkName (assoc 2 (entget (vlax-vla-object->ename X)))) ;; 获取尺寸关联的块名称
  46.                     (vlax-for X (vla-item Blks (cdr BlkName)) ;; 遍历关联块中的所有对象
  47.                       (if (wcmatch (vla-get-objectname x) "*Line")
  48.                       (vla-put-color X Color)                 ;; 设置对象颜色
  49.                         )
  50.                     )
  51.                   )
  52.                 )
  53.               )
  54.             )
  55.             ((= oName "AcDbBlockReference")                    ;; 如果对象是块引用
  56.               (ChBlkColor Blks X Color)                        ;; 递归调用 ChBlkColor 处理嵌套块
  57.             )
  58.           )
  59.         )
  60.       )
  61.     )

  62.    
  63. ;;;    (vla-UpDate obj)                                           ;; 更新对象以反映更改
  64.   (command "regen")
  65.   )
 楼主| 发表于 2024-10-31 14:28:53 | 显示全部楼层
多谢大佬分享
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-11-22 20:00 , Processed in 0.154464 second(s), 19 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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