找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 978|回复: 2

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

[复制链接]
发表于 2009-5-23 11:35:00 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

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

×
;有很多这样的属性块,提示有“标高_1:10”、“标高_1:20”“标高_1:40”“标高_1:50”“标高_1:100”“标高_1:150”“标高_1:200”。。。
;下面这个程序是选择图中符合条件的块,然后进行缩放。

(Defun c:tt (/ DATA II OS SN SS STR)
   (setq os (getvar "osmode"))
   (setvar "osmode" 0)
   (vlax-for BLK (vla-get-blocks
     (vla-get-activedocument (vlax-get-acad-object))
   )
     (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
     (if (setq ii -1
        ss (ssget (list (cons 0 "insert") (cons 2 (car blk)))
    )
  )
       (repeat (sslength ss)
  (setq sn (ssname ss (setq ii (1+ ii))))
  (command "_.Scale"
    sn
    ""
    (cdr (assoc 10 (entget sn)))
    (/ 50.0 (cdr blk))
  )
       )
     )
   )
   (setvar "osmode" os)
   (princ)
)
;哪位高手帮忙看看这个程序错在了哪里?附件中有测试文件。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!

已领礼包: 345个

财富等级: 日进斗金

发表于 2009-5-24 10:46:20 | 显示全部楼层
(Defun c:tt ( / blk bnn bnx data ii scl sn ss ssi str)
(princ "\n 请选择图块 <退出>:")
(setq ss (ssget '((0 . "INSERT"))))
    (vlax-for BLK (vla-get-blocks
     (vla-get-activedocument (vla-get-objectname ss))
   );在此如何对已有选择对象SS进行判断呢?这里这样好像不行
     (vlax-for ss BLK
       (if (and (= (vla-get-objectname ss) "AcDbAttributeDefinition")
         (wcmatch (setq str (vla-get-promptstring ss))
    "标高*"
         )
    )
  (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)
)
我想要的是:对已有选择对象SS进行判断呢?
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

 楼主| 发表于 2009-5-25 07:41:22 | 显示全部楼层
哪位高手帮忙解决一下?急。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

QQ|申请友链|Archiver|手机版|小黑屋|辽公网安备|晓东CAD家园 ( 辽ICP备15016793号 )

GMT+8, 2024-11-18 05:53 , Processed in 0.414996 second(s), 35 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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