langjs 发表于 2012-1-29 13:13:39

一个假尺寸检查工具源码

本帖最后由 langjs 于 2012-2-4 15:39 编辑

参考这两个帖子,做了一个假尺寸(手动修改过的尺寸)检查工具。假尺寸数值显示红色,再次运行恢复不显示,连续运行闪烁
http://bbs.mjtd.com/forum.php?mod=viewthread&tid=89808。http://bbs.mjtd.com/forum.php?mod=viewthread&tid=87563




;;; ==========================================
;;; 名称: 《假尺寸检查》
;;; 功能:假尺寸(手动修改过的尺寸)数值显示红色
;;; 操作:运行JCC显示假尺寸,再次运行恢复不显示
;;;                                     langjs
;;; ==========================================
(defun C:JCC (/ i ss)
(vl-load-com)
(setvar "cmdecho" 0)
(if (setq ss (ssget "X" '((0 . "DIMENSION") (-3 ("ACAD")))))
    (repeat (setq i (sslength ss))
      (entmod (list (cons -1 (ssname ss (setq i (1- i)))) (list -3 (list "ACAD"))))
    )
    (if (setq ss (ssget "X" '((0 . "DIMENSION") (-4 . "<AND")(-4 . "<NOT")(1 . "")(-4 . "NOT>")(-4 . "<NOT")(1 . "*<>*")(-4 . "NOT>")(-4 . "AND>"))))
      (repeat (setq i (sslength ss))
          (vlax-put-property (vlax-ename->vla-object (ssname ss (setq i (1- i)))) "textcolor" 1)
      )
      (alert "本图没有找到假尺寸!")
    )
)
(princ)
)


13楼建议:"执行过之后标注文字和箭头的大小会还原到当前环境设置的大小,建议修改成文字和箭头大小不变,只变颜色"
做了一下修改,不过代码不精简了,有点罗嗦
;;; ==========================================
;;; 名称: 《假尺寸检查》
;;; 功能:假尺寸(手动修改过的尺寸)数值显示红色
;;; 操作:运行jcc显示假尺寸,再次运行恢复不显示
;;;                                     langjs
;;; ==========================================
(defun c:jcc (/ col ent i ss ss0 ss1)
(vl-load-com)
(setvar "cmdecho" 0)
(if (progn
(setq ss (ssadd) ss1 (ssadd))
(if (setq ss0 (ssget "X" '((0 . "DIMENSION"))))
   (progn
   (repeat (setq i (sslength ss0))
       (setq ent (ssname ss0 (setq i (1- i))))
       (if (= (vla-get-textcolor (vlax-ename->vla-object ent)) 1) ; 查找红色的假尺寸
(setq ss (ssadd ent ss))
(setq ss1 (ssadd ent ss1))
       )
   )
   (if (> (sslength ss) 0)
       (if (> (sslength ss1) 0)
(setq col (vla-get-textcolor (vlax-ename->vla-object (ssname ss1 0))))
(progn
    (setq col (getint "\n输入尺寸恢复颜色:<3>"))
    (if (null col)
      (setq col 3)
    )
)
       )
   )
   )
)
(> (sslength ss) 0)
      )
    (progn
      (princ (strcat "\n" (itoa (sslength ss)) "个假尺寸恢复颜色。"))
      (repeat (setq i (sslength ss))
(vlax-put-property (vlax-ename->vla-object (ssname ss (setq i (1- i)))) "textcolor" col) ; 颜色恢复
      )
    )
    (if (setq ss (ssget "X" '((0 . "DIMENSION") (-4 . "<AND")(-4 . "<NOT")(1 . "")(-4 . "NOT>")(-4 . "<NOT")(1 . "*<>*")(-4 . "NOT>")(-4 . "AND>"))))
      (progn
(princ (strcat "\n" (itoa (sslength ss)) "个假尺寸数值显示红色。"))
(repeat (setq i (sslength ss))
   (vlax-put-property (vlax-ename->vla-object (ssname ss (setq i (1- i)))) "textcolor" 1) ; 显示红色
)
      )
      (alert "\n本图没有找到假尺寸!")
    )
)
(princ)
)



cXtzui 发表于 2022-11-8 19:23:24

友情提示:标注只能是< 一个尺寸 + 一段标注线 >的块,大多数图纸的轴线及标注都是一个整体块,需要先炸开,甚至多次炸开!!!

cXtzui 发表于 2022-11-8 15:27:45

好用,感谢分享!!!
技巧提示:疯狂按空格,在显示/不显示之间疯狂切换,配合鼠标中键到处缩放,可以迅速找到假尺寸位置。

迷失1786 发表于 2019-12-25 15:13:03

第二个代码出现,输入中含有多余的闭括号
????

cxs259 发表于 2012-1-30 10:00:21

若能统计更改后的数量,则更完美了

flytoday 发表于 2012-1-30 10:19:05

天正适用不………

flytoday 发表于 2012-1-30 10:21:34

应该找到假的标上真的才好

skynoon 发表于 2012-1-30 10:29:50

很不错,拿到条件图可以先处理一下

429014673 发表于 2012-1-30 12:06:44

提示:插入中的点位置不正确

goubeishu 发表于 2012-1-30 14:34:10

插入点的位置对吗?

goubeishu 发表于 2012-1-30 14:35:38

插入的位置对吗,楼主!

ps122hb 发表于 2012-1-30 16:21:34

不错,谢谢分享

fergus1987 发表于 2012-1-31 08:37:20

这个厉害~ 看下大大们的答案
页: [1] 2 3 4
查看完整版本: 一个假尺寸检查工具源码