明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 13271|回复: 68

一个用来刷相同的刷子源码

    [复制链接]
发表于 2011-12-20 00:21:03 | 显示全部楼层 |阅读模式
本帖最后由 langjs 于 2011-12-22 22:17 编辑



;;;          《相同刷》v1.0
;;; ========================================================
;;; 功能:将目标文字内容刷成源文字内容,将目标圆大小刷成源圆
;;;       的大小,将目标块刷成源块一样,将目标线、圆、圆弧、
;;;       多段线等刷成源多段线相同的线宽。源为线、尺寸、填充
;;;       圆弧则目标特性匹配
;;; 使用:命令:xts,选择一个源对象,程序自动判断,再选择集
;;; 作者:langjs     qq:59509100        日期:2011年12月19日
;;; ========================================================
(defun c:xts (/ ent i lst mame na pt ss tp ty u1 u2 u3 u4 uu)
  (setvar "cmdecho" 0)
  (vl-load-com)
  (defun #err (s)
    (redraw mame 4)
    (setvar "nomutt" 0)
    (command ".UNDO" "E")
    (setq *error* $orr)
    (princ)
  )
  (setq $orr *error*)
  (setq *error* #err)
  (command ".UNDO" "BE")
  (while (not (and
  (setq mame (car (entsel "\n选择源对象:")))
  (setq ent (entget mame))
  (setq ty (cdr (assoc 0 ent)))
  (member ty '("TEXT" "MTEXT"
    "LWPOLYLINE" "CIRCLE"
    "INSERT" "LINE"
    "ARC" "HATCH"
    "DIMENSION"
   )
  )
       )
  )
    (if (= 52 (getvar "errno"))
      (vl-exit-with-error "")
    )
  )
  (redraw mame 3)
  (setvar "nomutt" 1)
  (if (member ty '("TEXT" "MTEXT"))
    (progn
      (setq uu (cdr (assoc 1 ent)))
      (princ "\n选择目标对象:<文字相同>")
      (setq ss (ssget '((0 . "TEXT,MTEXT"))))
      (repeat (setq i (sslength ss))
(setq ent (entget (ssname ss (setq i (1- i)))))
(entmod (subst
    (cons 1 uu)
    (assoc 1 ent)
    ent
  )
)
      )
    )
  )
  (if (= ty "CIRCLE")
    (progn
      (setq uu (cdr (assoc 40 ent)))
      (princ "\n选择目标对象:<圆相同>")
      (setq ss (ssget '((0 . "CIRCLE"))))
      (repeat (setq i (sslength ss))
(setq ent (entget (ssname ss (setq i (1- i)))))
(entmod (subst
    (cons 40 uu)
    (assoc 40 ent)
    ent
  )
)
      )
    )
  )
  (if (= ty "INSERT")
    (progn
      (setq u1 (cdr (assoc 2 ent)))
      (setq u2 (cdr (assoc 41 ent)))
      (setq u3 (cdr (assoc 42 ent)))
      (setq u4 (* (/ (cdr (assoc 50 ent)) pi) 180))
      (princ "\n选择目标对象:<块相同>")
      (setq ss (ssget '((0 . "INSERT"))))
      (repeat (setq i (sslength ss))
(setq ent (entget (ssname ss (setq i (1- i)))))
(setq lst (cons (cdr (assoc 10 ent)) lst))
      )
      (command "erase" ss "")
      (repeat (setq i (length lst))
(setq pt (nth (setq i (1- i))
        lst
   )
)
(command "insert" u1 pt u2 u3 u4)
      )
    )
  )
  (if (= ty "LWPOLYLINE")
    (progn
      (if (setq uu (cdr (assoc 43 ent)))
(princ)
(setq uu (cdr (assoc 40 ent)))
      )
      (princ "\n选择目标对象:<线宽相同>")
      (setq ss (ssget '((0 . "LINE,ARC,POLYLINE,LWPOLYLINE,CIRCLE"))))
      (repeat (setq i (sslength ss))
(setq na (ssname ss (setq i (1- i))))
(setq ent (entget na))
(setq tp (cdr (assoc 0 ent)))
(if (member tp '("LINE" "ARC"))
   (command "pedit" na "Y" "w" uu "x")
)
(if (member tp '("POLYLINE" "LWPOLYLINE"))
   (command "pedit" na "w" uu "x")
)
(if (= tp "CIRCLE")
   (progn
     (setq u1 (cdr (assoc 10 ent)))
     (setq u2 (cdr (assoc 40 ent)))
     (setq u3 (- (* u2 2) uu))
     (setq u4 (+ (* u2 2) uu))
     (command "donut" u3 u4 u1 "")
     (entdel na)
   )
)
      )
    )
  )
  (if (member ty '("LINE" "ARC"
        "HATCH" "DIMENSION"
       )
      )
    (progn
      (princ "\n选择目标对象:<特性匹配>")
      (setq ss (ssget (list (cons 0 ty))))
      (command "matchprop" mame ss "")
    )
  )
  (redraw mame 4)
  (setvar "nomutt" 0)
  (command ".UNDO" "E")
  (setq *error* $orr)
  (princ)
)

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?注册

x

点评

不错,这想法好,支持这样,一个命令替代4个命令!  发表于 2011-12-20 08:11

评分

参与人数 4明经币 +2 金钱 +80 收起 理由
T_T + 1
xjf + 50 支持源码,用得着
669423907 + 1 很给力!
【KAIXIN】 + 30 赞一个!

查看全部评分

"觉得好,就打赏"
还没有人打赏,支持一下
发表于 2023-10-24 20:23:12 | 显示全部楼层
这个刷子不简单,太牛了!
发表于 2018-3-21 14:52:25 | 显示全部楼层
确实好用!感谢楼主
发表于 2011-12-20 07:53:00 | 显示全部楼层
不错,挺实用的。
发表于 2011-12-20 08:16:11 | 显示全部楼层
个人建议:楼主可以另做程序(同样是一个命令)
1.刷图层   2.颜色  3.线型  4.样式  
发表于 2011-12-20 08:18:55 | 显示全部楼层
再用一下caoying在拜年贴中那把刷子,就更好。

点评

想加但没加,主要是那个子程序长了一点  发表于 2011-12-20 10:34
发表于 2011-12-20 10:07:08 | 显示全部楼层
太强大了,谢谢楼主分享
 楼主| 发表于 2011-12-20 10:18:52 | 显示全部楼层
【KAIXIN】 发表于 2011-12-20 08:16
个人建议:楼主可以另做程序(同样是一个命令)
1.刷图层   2.颜色  3.线型  4.样式

难道是Cad 自带的“特性匹配”?
发表于 2011-12-20 20:07:17 | 显示全部楼层
感谢楼主,太实用了!
发表于 2011-12-20 20:21:21 | 显示全部楼层
楼主的程序非常好用啊!
发表于 2011-12-20 20:34:52 | 显示全部楼层
请问楼主,刷相同块时,为什么所有相同块会重贴在一起?

点评

可能是你图纸本身有问题吧,是不是Z轴不为0?在我这边是好用的。更新块的位置和原位置相同(块的插入点相同)  发表于 2011-12-20 20:41
发表于 2011-12-20 20:47:44 | 显示全部楼层
程序很强大,。
而且程序的前面没带序号,很容易复制下来。
带序号的程序,真让人头疼。为啥非得带序号呢?

点评

什么叫带序号?是不是这样:KX_SBZ 如果是这样,就是为了防止程序健命令相同引起冲突!  发表于 2011-12-24 08:05
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-11-15 01:30 , Processed in 0.415955 second(s), 33 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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