找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 558|回复: 0

[LISP函数]:Make the attributes fit

[复制链接]
发表于 2004-7-16 11:18:02 | 显示全部楼层 |阅读模式

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

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

×
[php]
;;; Attributes_fit.lsp
;;; Author : Alvin Lin 16/7/04
;;;
;;; This routine will insert a block with a single attribute in current drawing.
;;; Xdata is attached to the attribute so the text string should has ;;; a maximum length
;;; A simple command reactor is set up to trace the "EATTEDIT" ;;;command ended.
;;; When "EATTEDIT" command ends, it triggers the CAll_BACK function (WHATNEXT),
;;; which will finally call (CHECKFIT) to check the attributes fitness throughout
;;; the modelspace of current drawing.
;;---------------------------------------------------------------------------------------
(defun c:test  (/ ss ts ts0 old_osMode old_cmdEcho en InsPt value blkobj txthgt)
  (setq ts (if (= (setq txthgt (vla-get-height
                                 (vla-get-activeTextStyle
                                   (vla-get-ActiveDocument
                                     (vlax-get-acad-object)
                                     )
                                   )
                                 )
                        )
                  0
                  )
             (getvar "TEXTSIZE")
             txthgt
             )
        )
  (setq ts0         (/ ts 5.0)
        old_osMode  (getvar "OSMODE")
        old_cmdEcho (getvar "CMDECHO")
        ss          (ssadd)
        )
  (setvar "OSMODE" 0)
  (setvar "CMDECHO" 0)
  (if (not (tblsearch "BLOCK" "testblk"))
    (progn
      (if
        (vl-cmdf
          "rectangle"
          '(0 0)
          (strcat "@"
                  (rtos (* ts0 60) 2 2)
                  ","
                  (rtos (* ts0 7) 2 2)
                  )
          )
         (setq ss (ssadd (entlast) ss))
         )

      (vl-cmdf "text"
               (strcat (rtos ts0 2 2) "," (rtos ts0 2 2))
               )

      (if (= txthgt 0)
        (vl-cmdf ts)
        )
      (if (vl-cmdf 0
                   "NAME:"
                   )
        (setq ss (ssadd (entlast) ss))
        )
      (vl-cmdf "-attdef"
               ""
               "NAME"
               "Input name"
               ""
               (strcat (rtos (* ts0 24) 2 2)
                       ","
                       (rtos ts0 2 2)
                       )
               )
      (if (= txthgt 0)
        (vl-cmdf ts)
        )
      (if (vl-cmdf "" 0)
        (progn
          (setq en (entlast))
          (x_data_add
            en
            "TEXTLENGTH"
            (list (cons 1040 (* ts0 35)))
            )
          (setq ss (ssadd en ss))
          )
        )
      (vl-cmdf "-block" "testblk" '(0 0 0) ss "")
      )
    (vl-cmdf "erase" ss "")
    )
  (setq IntPt (getpoint "\nInsertion point: ")
        value (getstring "\nInput name: " t)
        )
  (if (vl-cmdf "-insert" "testblk" IntPt 1 1 0 value)
    (progn
      (setq blkobj (vlax-ename->vla-object (entlast)))
      (Check_Textfit blkobj)
      )
    )
  (VLR-REMOVE-ALL)
  (VLR-COMMAND-REACTOR NIL '((:VLR-COMMANDENDED . WHATNEXT)))
  (setvar "OSMODE" old_osmode)
  (setvar "CMDECHO" old_cmdEcho)
  (princ)
  )
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
(DEFUN WHATNEXT  (REFOBJ CMDLIST)
  (IF (APPLY 'OR
             (MAPCAR '(LAMBDA (X) (WCMATCH X "*EATTEDIT")) CMDLIST)
             )
    (CHECKFIT)
    )
  (PRINC)
  )
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
(defun Checkfit  (/ MSPACE)
  (SETQ MSPACE (VLA-GET-MODELSPACE
                 (VLA-GET-ACTIVEDOCUMENT (VLAX-GET-ACAD-OBJECT))
                 )
        )
  (VLAX-FOR OBJ  MSPACE
    (IF
      (and (= (VLA-GET-OBJECTNAME OBJ) "AcDbBlockReference")
           (= (VLA-GET-HASATTRIBUTES OBJ)
              :VLAX-TRUE
              )
           )
       (Check_Textfit OBJ)
       )
    )
  )
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
(defun Check_Textfit  (blkobj / atts LL UR len len0)
  (setq atts (vlax-safearray->list
               (vlax-variant-value (vla-GetAttributes blkobj))
               )
        )
  (foreach att  atts
    (vla-put-Scalefactor att 1.0)
    (vla-GetBoundingBox att 'LL 'UR)
    (setq LL (vlax-safearray->list LL)
          UR (vlax-safearray->list UR)
          )
    (setq len (abs (- (car LL) (car UR))))

    (IF (SETQ TMP
               (x_data_get (vlax-vla-object->ename att) "TEXTLENGTH")
              )
      (PROGN
        (setq len0 (cdar TMP))
        (if (> len len0)
          (vla-put-Scalefactor att (/ len0 len))
          )
        )
      )
    )
  )
;;;;Written by Bill Kramer
(DEFUN X_DATA_ADD  (EN APID DLST / EL TMP1)
  (REGAPP APID)
  (SETQ EL   (ENTGET EN)
        TMP1 (LIST -3 (CONS APID DLST))
        )
  (IF (< (XDSIZE TMP1) (XDROOM EN))
    (ENTMOD (APPEND EL (LIST TMP1)))
    )
  )
;;;
(DEFUN X_DATA_GET  (EN APID / EL)
  (SETQ EL (ENTGET EN (LIST APID)))
  (IF (ASSOC -3 EL)
    (CDADR (ASSOC -3 EL))
    )
  )
[/php]
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

GMT+8, 2025-9-27 06:55 , Processed in 0.243033 second(s), 32 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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