区域内的文本到文本 - autocad

时间:2017-06-30 15:28:24

标签: autocad autocad-plugin autolisp

我有以下代码。它创建文本到mtext而不移动autocad中的文本块。我希望有这个脚本,但将文本行合并到某个区域内的一个块中。就像在某个图层的文本块的南北方5个单元内创建一个mtext块。

(defun C:T1MJ ; = Text or Attribute Definition to 1-line Mtext, retaining Justification
  (/ *error* cmde doc tss inc tent tobj tins tjust)

  (defun *error* (errmsg)
    (if (not (wcmatch errmsg "Function cancelled,quit / exit abort,console break"))
      (princ (strcat "\nError: " errmsg))
    ); if
    (vla-endundomark doc)
    (setvar 'cmdecho cmde)
    (princ)
  ); defun - *error*

  (setq
    cmde (getvar 'cmdecho)
    doc (vla-get-activedocument (vlax-get-acad-object))
  ); setq
  (vla-startundomark doc)
  (setvar 'cmdecho 0)
  (prompt "\nTo change Text/Attribute to 1-line Mtext, preserving Justification,")
  (if (setq tss (ssget "_:L" '((0 . "TEXT,ATTDEF"))))
    (repeat (setq inc (sslength tss))
      (setq
        tent (ssname tss (setq inc (1- inc)))
        tobj (vlax-ename->vla-object tent)
        tins (vlax-get tobj 'TextAlignmentPoint)
        tjust (vla-get-Alignment tobj)
      ); setq
      (cond
        ((= tjust 0) (setq tjust 7 tins (vlax-get tobj 'InsertionPoint))); Left
        ((< tjust 3) (setq tjust (+ tjust 7))); 1/2 [Center/Right] to 8/9
        ((= tjust 4) (setq tjust 5)); Middle to Middle-Center
        ((member tjust '(3 5)); Aligned/Fit
          (setq
            tjust 8 ; to Bottom-Center
            tins (mapcar '/ (mapcar '+ (vlax-get tobj 'InsertionPoint) tins) '(2 2 2))
              ; with new insertion point
          ); setq
        ); Aligned/Fit
        ((setq tjust (- tjust 5))); all vertical-horizontal pair justifications
      ); cond
      (if (= (vla-get-TextString tobj) "") (vla-put-TextString tobj (vla-get-TagString tobj)))
        ;; if no default content, disappears after TXT2MTXT: impose Tag value for it
        ;; [to use Prompt value instead, change end to (vla-get-PromptString tobj).]
      (command "_.txt2mtxt" tent ""); convert, then
      (setq tobj (vlax-ename->vla-object (entlast))); replace Text as object with new Mtext
      (vla-put-AttachmentPoint tobj tjust); original Text's justification [or equiv.]
      (vlax-put tobj 'InsertionPoint tins); original Text's insertion
    ); repeat
  ); if
  (setvar 'cmdecho cmde)
  (vla-endundomark doc)
  (princ)
); defun -- T1MJ
(vl-load-com)
(prompt "\nType T1MJ to change Text/Attribute-Definitions to 1-line Mtext, preserving Justification.")

1 个答案:

答案 0 :(得分:0)

我不是一个lisp程序员,所以我无法给你一个直接的答案,但我将向你描述一个你应该能够复制的概念。

如果您查看此网络资源,则会讨论其中一个 Express工具TXT2MTXT

TXT2MTXT

现在,这是一个命令行例程,它需要一个选择集并将 TEXT 转换为 MTEX​​T 对象:

MTEXT

因此,我无法理解为什么您不能使用lisp来创建文本对象的本地化选择集,然后将此选择集传递给 TXT2MTXT 命令。我知道有可能用lisp做这种事情。我只是不了解机制。我认识VBA。

我希望这有助于您解决问题。它没有显示代码,但它描述了如何做你想要的概念。

相关问题