明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 698|回复: 7

[源码] 自动选择图纸空间视口内模型空间图元lsp源码

[复制链接]
发表于 4 天前 | 显示全部楼层 |阅读模式

图纸空间直接选择视口内位于模型空间的图元,视口外的不会选择.
主要应用:结合CHSPACE 可以将模型空间图元移动到图纸空间,
实现图框内容的空间统一便于迁移或者其他需求







本帖子中包含更多资源

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

x
回复

使用道具 举报

发表于 4 天前 | 显示全部楼层
虽然但是 用不上
回复 支持 反对

使用道具 举报

发表于 4 天前 | 显示全部楼层
有用的
比如在布局中
entsel点击一个文字搜寻相同文字
如果目标文字处于模型
那么点击这个动作就得不到想要的目标

所以我的程序中
如果点击为空
会再判断鼠标坐标是否位于某个视口范围内
若是则转换坐标到模型
在模型中再执行一次nentselp

回复 支持 反对

使用道具 举报

发表于 前天 09:55 | 显示全部楼层
本帖最后由 caoyin 于 2025-9-1 10:12 编辑

  1. ;;; 我用更简单的代码实现你的前期功能,既然选择集已经选中,后期功能完全可以随机调用诸如移动、删除等命令
  2. (defun C:TT (/ X C D P1 P2 SS)
  3.   (cond ((= (getvar 'TILEMODE) 1)
  4.          (princ "\n先切换到布局。")
  5.         )
  6.         ((/= (getvar 'CVPORT) 1)
  7.          (princ "\n先切换到图纸空间。")
  8.         )
  9.         ((not (setq X (entsel "\n选择视口: ")))
  10.          (princ "\n没选择任何对象。")
  11.         )
  12.         ((/= (cdr (assoc 0 (setq X  (entget (car X))))) "VIEWPORT")
  13.          (princ "\n所选对象不是视口。")
  14.         )
  15.         (T
  16.          (setq C  (cdr (assoc 10 X))
  17.                D  (list (/ (cdr (assoc 40 X)) 2.0) (/ (cdr (assoc 41 X)) 2.0))
  18.                P1 (mapcar '- C D)
  19.                P2 (mapcar '+ C D)
  20.          )
  21.          (command "_.MSPACE")
  22.          (setvar 'CVPORT (cdr (assoc 69 X)))
  23.          (if (setq SS (ssget "_C" (trans (trans P1 3 2) 2 1) (trans (trans P2 3 2) 2 1)))
  24.            (sssetfirst nil SS)
  25.          )
  26.         )
  27.   )
  28.   (princ)
  29. )


回复 支持 反对

使用道具 举报

发表于 前天 14:11 | 显示全部楼层

感谢大佬分享
回复 支持 反对

使用道具 举报

发表于 昨天 17:25 | 显示全部楼层

有一个问题,那就是如果是被用多段线等图形裁剪过的视口会被提示不是视口。
回复 支持 反对

使用道具 举报

发表于 7 小时前 | 显示全部楼层
本帖最后由 caoyin 于 2025-9-3 00:35 编辑
lxl304712346 发表于 2025-9-2 17:25
有一个问题,那就是如果是被用多段线等图形裁剪过的视口会被提示不是视口。

裁切过的视口,视口是附着在裁切边界上的,也就是说两个对象重合在一起了,用ssget替换entsel就解决问题了,以下是修改后的代码:

  1. (defun C:TT (/ X C D P1 P2 SS)
  2.   (cond ((= (getvar 'TILEMODE) 1)
  3.          (princ "\n先切换到布局。")
  4.         )
  5.         ((/= (getvar 'CVPORT) 1)
  6.          (princ "\n先切换到图纸空间。")
  7.         )
  8.         ((not (setq X (ssget ":S" '((0 . "VIEWPORT")))))
  9.          (princ "\n没选择任何有效对象。")
  10.         )
  11.         ((= (cdr (assoc 0 (setq X (entget (ssname X 0))))) "VIEWPORT")
  12.          (setq C  (cdr (assoc 10 X))
  13.                D  (list (/ (cdr (assoc 40 X)) 2.0) (/ (cdr (assoc 41 X)) 2.0))
  14.                P1 (mapcar '- C D)
  15.                P2 (mapcar '+ C D)
  16.          )
  17.          (command "_.MSPACE")
  18.          (setvar 'CVPORT (cdr (assoc 69 X)))
  19.          (if (setq SS (ssget "_C" (trans (trans P1 3 2) 2 1) (trans (trans P2 3 2) 2 1)))
  20.            (sssetfirst nil SS)
  21.          )
  22.         )
  23.   )
  24.   (princ)
  25. )
回复 支持 反对

使用道具 举报

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

本版积分规则

小黑屋|手机版|CAD论坛|CAD教程|CAD下载|联系我们|关于明经|明经通道 ( 粤ICP备05003914号 )  
©2000-2023 明经通道 版权所有 本站代码,在未取得本站及作者授权的情况下,不得用于商业用途

GMT+8, 2025-9-3 07:36 , Processed in 0.167499 second(s), 25 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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