明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

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

[求助]哪位高手帮忙看看这个程序错在了哪里?

    [复制链接]
 楼主| 发表于 2009-5-25 08:07:00 | 显示全部楼层
而且,此程序如果标高值是“%%P0.000”的话,会选不中的,不知什么原因。
 楼主| 发表于 2009-5-25 11:11:00 | 显示全部楼层

;; ▓ (ltax:ss->axss ss)
;; [功能] 将 ALISP 选择集转换为 VLA 选择集
;; [参数] ss---选择集
(defun ltax:ss->axss (ss / ssp axss)
  (setq ssp (ssget "_p"))
  (sssetfirst nil ss)
  (ssget "_I")
  (setq axss (vla-get-activeselectionset (vla-get-activedocument (vlax-get-acad-object))))
  (if (cadr (sssetfirst nil ssp)) (ssget "_I"))
  (sssetfirst)
  axss
)

(Defun c:tt ( / blk bnn bnx data ii scl sn ss ssi str)
(princ "\n 请选择图块 <退出>:")
(setq ss (ssget '((0 . "INSERT,TEXT"))))
    (vlax-for BLK (ltax:ss->axss ss)
     (vlax-for X BLK
       (if (and (= (vla-get-objectname X) "AcDbAttributeDefinition")
         (wcmatch (setq str (vla-get-promptstring X))
    "标高*"
         )
    )
  (setq data (cons (cons (vla-get-name BLK)
           (read (vl-string-subst
            ""
            "标高_1:"
            str
          )
           )
     )
     data
      )
  )
       )
     )
   )
   (foreach blk data
     (setq bnn (car blk)
    bnn (if (= (substr bnn 1 1) "*")
   (strcat "`" bnn)
   bnn
        )
     )
     (if (null bnx)
       (setq bnx bnn)
       (setq bnx (strcat bnx "," bnn))
     )
   )
   (if (and (/= nil bnn) (setq ii -1))
(progn
(vl-cmdf "select" ss "")
(setq ssi (ssget "p" (list (cons 0 "INSERT") (cons 2 bnn))))
     (repeat (sslength ssi)
       (setq sn (ssname ssi (setq ii (1+ ii)))
      scl (cdr (assoc (cdr (assoc 2 (entget sn))) data))
       )
       (command "_.Scale"
         sn
         ""
         (cdr (assoc 10 (entget sn)))
         (/ 50.0 scl)
       )
     )
)
   )
   (princ)
)

这样也不行?

 楼主| 发表于 2009-5-25 17:52:00 | 显示全部楼层
我是这么想的:选择一些物体,对这些物体进行过滤,找出符合条件的,获取这些符合条件的“标高_1:”后面的值,最后进行缩放。
发表于 2009-5-25 22:39:00 | 显示全部楼层
你图里用了大量无名块,所以全部检索肯定是会浪费时间的。
我修改了程序,只检索选到的图块,可能会快一些,但是如果有大量不符合要求的其他图块,速度一样无法真正提高。唯一的办法就只有优化原有的数据或者接受“稍慢”一点的速度。
  1. (Defun c:tt (/ get-scale II OS SCL SN SS *DATA*)
  2.   (Defun get-scale (bname / SCALE STR X)
  3.     (if (null (setq scale (cdr (assoc bname *data*))))
  4.       (vlax-for X
  5.     (vla-item
  6.       (vla-get-blocks
  7.         (vla-get-activedocument (vlax-get-acad-object))
  8.       )
  9.       bname
  10.     )
  11. (if (and (null scale)
  12.    (= (vla-get-objectname X) "AcDbAttributeDefinition")
  13.    (wcmatch (setq str (vla-get-promptstring X))
  14.      "标高_1:*"
  15.    )
  16.      )
  17.    (setq scale  (read (vl-string-subst
  18.           ""
  19.           "标高_1:"
  20.           str
  21.         )
  22.          )
  23.   *data* (cons (cons bname scale) *data*)
  24.    )
  25. )
  26.       )
  27.     )
  28.     scale
  29.   )
  30.   (setq os (getvar "osmode"))
  31.   (if (and (setq ii -1)
  32.     (setvar "osmode" 0)
  33.     (princ "\n 请选择图块 <退出>:")
  34.     (setq ss (ssget (list (cons 0 "insert") (cons 66 1))))
  35.       )
  36.     (repeat (sslength ss)
  37.       (if (and (setq sn (ssname ss (setq ii (1+ ii))))
  38.         (setq scl (get-scale (cdr (assoc 2 (entget sn)))))
  39.    )
  40. (command "_.Scale"
  41.    sn
  42.    ""
  43.    (cdr (assoc 10 (entget sn)))
  44.    (/ 50.0 scl)
  45. )
  46.       )
  47.     )
  48.   )
  49.   (setvar "osmode" os)
  50.   (princ)
  51. )
我没有具体测试,所以可能会有点小问题。
 楼主| 发表于 2009-5-25 23:39:00 | 显示全部楼层

谢谢mmmmmm

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

本版积分规则

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

GMT+8, 2024-9-29 18:21 , Processed in 0.160875 second(s), 19 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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