LauKwokFai 发表于 2022-7-6 07:53:24

如何使用Lisp“激活”

大家好,
 
我想知道是否有任何方法可以使用AutoLisp“激活”选定的视口(而不是VLisp,因为我根本不知道任何VLisp!!!)
 
例如,如果我在图纸空间中的视口上绘制一个矩形,并且我想将该矩形转移到模型空间中,我会使用CAD命令“chspace”,但随后我需要单击特殊视口,以便矩形到达正确的位置。此外,如果我想将视口图像设置为特定比例,例如1:20,我还必须单击视口并键入“zoom”“1/20xp”。
 
我不知道如何使用AutoLisp“激活”选定的视口。
 
 
非常感谢你

MSasu 发表于 2022-7-6 08:07:25

每个视口的ID存储在DXF代码69中(使用ENTGET函数列出)。
接下来,使用CVPORT系统变量激活特定视口。
(command "_MSPACE")
(setvar "CVPORT" 2)

MSasu 发表于 2022-7-6 08:28:01

还有VPORTS函数,它将列出布局中定义的视口(1始终是图纸空间)。
;;; Cycle Through Viewports (05-VI-2012)
(defun c:CTV( / oldCmdEcho listVPorts itemVPort )
(vl-load-com)
(setq oldCmdEcho (getvar "CMDECHO"))
(setvar "CMDECHO" 0)
(if (/= (getvar "CTAB") "Model")
(progn
(setq listVPorts (vl-sort (vports) '(lambda(v1 v2) (< (car v1) (car v2)))))
(if (> (length listVPorts) 1)
   (progn
    (command "_MSPACE")
    (foreach itemVPort (cdr listVPorts)
   (setvar "CVPORT" (car itemVPort))
   (getkword "\nPress <ENTER> to go to next viewport")
    )
    (command "_PSPACE")
   )
   (prompt "\nThere are no viewports defined in this Layout!")
)
)
(prompt "\nThis routine works only in Layout!")
)

(setvar "CMDECHO" oldCmdEcho)
(princ)
)

LauKwokFai 发表于 2022-7-6 08:36:15

太好了,它应该能解决我的问题!!!
 
非常感谢Msasu

MSasu 发表于 2022-7-6 08:43:29

不客气!

Lee Mac 发表于 2022-7-6 08:59:24

另一种方法:
 
(defun c:vpon ( / d s )
   (vl-load-com)
   (if (setq s (ssget "_+.:S:E:L" '((0 . "VIEWPORT"))))
       (progn
         (setq d (vla-get-activedocument (vlax-get-acad-object)))
         (vla-put-mspace d :vlax-true)
         (vla-put-activeviewport d (vlax-ename->vla-object (ssname s 0)))
       )
   )
   (princ)
)
 
以及“停用”:
 
(defun c:vpoff ( )
   (vla-put-mspace (vla-get-activedocument (vlax-get-acad-object)) :vlax-false)
   (princ)
)
页: [1]
查看完整版本: 如何使用Lisp“激活”