明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 1888|回复: 2

[求助龙版]标注程序

[复制链接]
发表于 2010-2-22 11:33:00 | 显示全部楼层 |阅读模式

我想用你以前编的这个程序,但是捕捉设置会被清空,

能否帮忙修改一下。谢

;;;;;;;;;;;;;;;;;;;;;;

;;这是一个很久以前的程序,写得不太好,也很少用(因现在有double_click功能)!!
(defun C:D (/    HOLDOSMODE      HOLDECHO HOLDBLIP P340
    P340ENTGET10     A1      AAA1     A        AAA
    AAL    AAPT     Q%Q      Q%Q1     Q%Q11
   )
  (setq HOLDECHO (getvar "cmdecho"))
  (setq HOLDBLIP (getvar "blipmode"))
  (setq HOLDOSMODE (getvar "osmode"))
  (setvar "cmdecho" 0)
  (setvar "blipmode" 0)
  (setvar "osmode" 0)
  (while (null AAA1)
    (setq AAA1 (nentsel))
  )
  (setq AAL (length AAA1))
  (cond
    ((/= AAL 2)
     (setq AAL (length (last AAA1)))
     (if (/= AAL 1)
       (progn
  (setq A1 (car AAA1))
  (setq AAPT (cadr AAA1))
  (setq AAA (entget A1))
  (setq Q%Q (cdr (assoc 0 AAA)))
  (setq Q%Q11 (cdr (assoc 0 (entget (car (last AAA1))))))
  (if (= Q%Q11 "DIMENSION")
    (setq Q%Q NIL)
  )
  (setq Q%Q1 (cdr (assoc 0 (entget (car AAA1)))))
  (cond
    ((and (/= Q%Q1 "LINE")
   (/= Q%Q1 "CIRCLE")
   (/= Q%Q1 "ARC")
   (/= Q%Q1 "MLINE")
   (/= Q%Q1 "VERTEX")
     )
     (setq Q%Q NIL)
    )
  )
       )
       (progn
  (setq A1 (car (last AAA1)))
  (setq AAPT (cdr AAA1))
  (setq AAA (entget A1))
  (setq Q%Q (cdr (assoc 0 AAA)))
       )
     )
    )
    ((= AAL 2)
     (setq A1 (car AAA1))
     (setq AAPT (cadr AAA1))
     (setq AAA (entget A1))
     (setq Q%Q (cdr (assoc 0 AAA)))
    )
  )
  (cond
    ((or (= Q%Q "LINE") (= Q%Q "MLINE"))
     (command "_.DIMLINEAR" "" AAPT)
    )
    ((= Q%Q "CIRCLE") (command "_.DIMDIAMETER" AAPT))
    ((= Q%Q "ARC") (command "_.DIMRADIUS" AAPT))
    ((= Q%Q "DIMENSION") (command "_.DIMTEDIT" A1))
    ((= Q%Q "LEADER")
     (setq P340 (cdr (assoc 340 (entget A1))))
     (setq P340ENTGET10 (cdr (assoc 10 (entget P340))))
     (command "_.move" P340ENTGET10 "")
    )
    ((= Q%Q "MTEXT") (command "_.DDEDIT" AAPT))
    ((= Q%Q "TEXT") (command "_.DDEDIT" AAPT))
    ((= Q%Q "HATCH")
     (initdia 1)
     (command "_.HATCHEDIT" AAPT)
     (initdia 0)
    )
    ((= Q%Q "ATTDEF") (command "_.DDEDIT" AAPT))
    ((= Q%Q "ATTRIB") (command "_.DDATTE" AAPT))
    ((= Q%Q "SPLINE") (command "_.SPLINEDIT" AAPT))
    ;|
    ((= Q%Q "TOLERANCE")
     (if (wcmatch (getvar "acadver") "15*")
       (progn
  (if (not DDMODIFYY)
    (load "ddmodifyy")
  )
  (DDMODIFYY A1)
       )
       (progn
  (if (not DDMODIFY)
    (load "ddmodify")
  )
  (DDMODIFY A1)
       )
     )
    )|;
    ((or (= Q%Q "VERTEX")
  (= Q%Q "LWPOLYLINE")
  (= Q%Q "POLYLINE")
     )
     (setq AA (entget (car AAA1)))
     (setq AAPT (cadr AAA1))
     (setq AAA (cdr (assoc 42 AA)))
     (if (= AAA 0)
       (command "_.DIMLINEAR" "" AAPT)
       (command "_.DIMRADIUS" AAPT)
     )
    )
    ((= Q%Q "INSERT")
     (setq AA (entget (car AAA1)))
     (setq AAPT (cadr AAA1))
     (setq Q%Q (cdr (assoc 0 AA)))
     (cond
       ((or (= Q%Q "LINE") (= Q%Q "MLINE"))
 (command "_.DIMLINEAR" "" AAPT)
       )
       ((= Q%Q "CIRCLE") (command "_.DIMDIAMETER" AAPT))
       ((= Q%Q "ARC") (command "_.DIMRADIUS" AAPT))
       ((or (= Q%Q "VERTEX")
     (= Q%Q "LWPOLYLINE")
     (= Q%Q "POLYLINE")
 )
 (setq AA (entget (car AAA1)))
 (setq AAPT (cadr AAA1))
 (setq AAA (cdr (assoc 42 AA)))
 (if (= AAA 0)
   (command "_.DIMLINEAR" "" AAPT)
   (command "_.DIMRADIUS" AAPT)
 )
       )
       (t
 (prompt "\n不能编辑及标注区块中之非线类")
       )
     )
    )
    (t
     (prompt "\n不能编辑及标注区块中之非线类")
    )
  )
  (setvar "blipmode" HOLDBLIP)
  (setvar "osmode" HOLDBLIP)
  (setvar "cmdecho" HOLDECHO)
  (princ)
)

发表于 2010-2-22 13:13:00 | 显示全部楼层

  (setvar "osmode" HOLDOSMODE)
  (setvar "cmdecho" HOLDECHO)
  (princ)
)

把程序结尾修改一下

 楼主| 发表于 2010-2-22 21:01:00 | 显示全部楼层

原来是这样的,谢了。

发一个几年前的经典作品,适用于从未体验过批量处理快乐的新手。

高手不要看了。

本帖子中包含更多资源

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

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

本版积分规则

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

GMT+8, 2024-10-1 23:42 , Processed in 0.173538 second(s), 27 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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