明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 2195|回复: 5

[源码] 删除指定区域外图元

[复制链接]
发表于 2014-5-22 03:06:58 | 显示全部楼层 |阅读模式
个人习惯保存时先zoom'e
而别人发来的图
经常有天外飞线
于是就有了这个程序
很简单
也没考虑图层锁定
不过还算实用吧


;;指定保留区(矩形框)两点,删除区域外图元。-----这个程序主要用于删除天外飞线
(defun c:delrec()
(command "undo" "g")
(princ "\n 删除保留区域外的所有图元")
(if (and
    (setq p1 (getpoint "\n 指定保留区域的第1点:"))
    (setq p2 (getcorner p1 "\n 指定保留区域的第2点:"))
    ;;()  ;;确认操作
    (setq pa (list (min (car p1) (car p2)) (min (cadr  p1) (cadr  p2))))
    (setq pb (list (max (car p1) (car p2)) (max (cadr  p1) (cadr  p2))))
    (setq insss (ssget "x"  (list
             '(-4 . "<and")
              '(-4 . ">,>,*")(cons 10 pa)
              '(-4 . "<,<,*")(cons 10 pb)
             '(-4 . "and>")
            )
        )
    )
   )
   (progn
    (command "erase" "all" "r" insss "")
    ;;(command "zoom" "w" "non" p1 "non" p2)
    (command "zoom" "e")
   )
)
(command "undo" "e")
(princ)
)
"觉得好,就打赏"
还没有人打赏,支持一下
发表于 2014-5-22 07:48:21 | 显示全部楼层
(setq insss (ssget))是否直接些?
 楼主| 发表于 2014-5-22 09:08:31 | 显示全部楼层
有一点小区别
如果直接采用(ssget)
在选择过程中必须保证
目标物体在屏幕内可见
而程序中所采用的方式
并不需要这样
所以不会发生误删除
发表于 2014-6-23 11:59:08 | 显示全部楼层
试试好用不  谢谢分享
发表于 2014-6-23 13:44:21 | 显示全部楼层
  1. ;; 区域外图元删除
  2. (defun c:tt ()
  3.   (princ "\n 删除保留区域外的所有图元")
  4.   (if (and (setq p1 (getpoint "\n 指定保留区域的第1点: "))
  5.            (setq p2 (getcorner p1 "\n 指定保留区域的第2点: "))
  6.            (setq ss (ssget "c" p1 p2))
  7.            (setq ss1 (ssget "x"))
  8.       )
  9.     (command "erase" ss1 "r" ss "")
  10.   )
  11.   (princ)
  12. )
 楼主| 发表于 2014-6-25 11:09:57 | 显示全部楼层
院长再仔细看下板凳楼
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-5-24 13:41 , Processed in 0.197658 second(s), 30 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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