乐筑天下

搜索
欢迎各位开发者和用户入驻本平台 尊重版权,从我做起,拒绝盗版,拒绝倒卖 签到、发布资源、邀请好友注册,可以获得银币 请注意保管好自己的密码,避免账户资金被盗
查看: 33|回复: 5

[编程交流] 如何使用Lisp“激活”

[复制链接]

14

主题

54

帖子

40

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

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

使用道具 举报

35

主题

2471

帖子

2447

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
174
发表于 2022-7-6 08:07:25 | 显示全部楼层
每个视口的ID存储在DXF代码69中(使用ENTGET函数列出)。
接下来,使用CVPORT系统变量激活特定视口。
  1. (command "_MSPACE")
  2. (setvar "CVPORT" 2)
回复

使用道具 举报

35

主题

2471

帖子

2447

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
174
发表于 2022-7-6 08:28:01 | 显示全部楼层
还有VPORTS函数,它将列出布局中定义的视口(1始终是图纸空间)。
  1. ;;; Cycle Through Viewports (05-VI-2012)
  2. (defun c:CTV( / oldCmdEcho listVPorts itemVPort )
  3. (vl-load-com)
  4. (setq oldCmdEcho (getvar "CMDECHO"))
  5. (setvar "CMDECHO" 0)
  6. (if (/= (getvar "CTAB") "Model")
  7. (progn
  8.   (setq listVPorts (vl-sort (vports) '(lambda(v1 v2) (< (car v1) (car v2)))))
  9.   (if (> (length listVPorts) 1)
  10.    (progn
  11.     (command "_MSPACE")
  12.     (foreach itemVPort (cdr listVPorts)
  13.      (setvar "CVPORT" (car itemVPort))
  14.      (getkword "\nPress <ENTER> to go to next viewport")
  15.     )
  16.     (command "_PSPACE")
  17.    )
  18.    (prompt "\nThere are no viewports defined in this Layout!")
  19.   )
  20. )
  21. (prompt "\nThis routine works only in Layout!")
  22. )
  23. (setvar "CMDECHO" oldCmdEcho)
  24. (princ)
  25. )
回复

使用道具 举报

14

主题

54

帖子

40

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
70
发表于 2022-7-6 08:36:15 | 显示全部楼层
太好了,它应该能解决我的问题!!!
 
非常感谢Msasu
回复

使用道具 举报

35

主题

2471

帖子

2447

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
174
发表于 2022-7-6 08:43:29 | 显示全部楼层
不客气!
回复

使用道具 举报

114

主题

1万

帖子

1万

银币

中流砥柱

Rank: 25

铜币
543
发表于 2022-7-6 08:59:24 | 显示全部楼层
另一种方法:
 
  1. (defun c:vpon ( / d s )
  2.    (vl-load-com)
  3.    (if (setq s (ssget "_+.:S:E:L" '((0 . "VIEWPORT"))))
  4.        (progn
  5.            (setq d (vla-get-activedocument (vlax-get-acad-object)))
  6.            (vla-put-mspace d :vlax-true)
  7.            (vla-put-activeviewport d (vlax-ename->vla-object (ssname s 0)))
  8.        )
  9.    )
  10.    (princ)
  11. )

 
以及“停用”:
 
  1. (defun c:vpoff ( )
  2.    (vla-put-mspace (vla-get-activedocument (vlax-get-acad-object)) :vlax-false)
  3.    (princ)
  4. )
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

QQ|关于我们|小黑屋|乐筑天下 繁体中文

GMT+8, 2025-3-9 20:44 , Processed in 0.620158 second(s), 64 queries .

© 2020-2025 乐筑天下

联系客服 关注微信 帮助中心 下载APP 返回顶部 返回列表