明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 1447|回复: 13

[源码] 框内选择

[复制链接]
发表于 2021-9-24 15:09 | 显示全部楼层 |阅读模式
50明经币
本帖最后由 孙玉坤 于 2021-9-24 15:14 编辑

框内选择 轮廓线内的可以选择到,但和轮廓线有重合的边就不行。
(defun c:ta (/ ADD DXF-10 ENT GET GET2 LEN LEN2 NN NN2)  
  (princ "\n功能 [批量选择多段内所有对象]")
  (if (setq get (ssget '((0 . "LWPOLYLINE"))))
    (progn
      (setq Len        (sslength get)
            add        (ssadd)
      )
      (repeat Len
        (setq nn  (ssname get (setq Len (1- Len)))
              ent (entget nn)
        )
        (setq dxf-10 (vl-remove-if '(lambda (x) (/= (car x) 10)) ent)
              get2   (ssget "_WP" (mapcar 'cdr dxf-10))
              Len2   (sslength get2)
        )
        (repeat        Len2
          (setq nn2 (ssname get2 (setq Len2 (1- Len2))))
          (ssadd nn2 add)
        )                                
      )
    )                                       
  )                                       
  (sssetfirst nil add)
  (princ)
)


最佳答案

查看完整内容

;;;;部分子程序取自本网站http://bbs.mjtd.com/forum.php?mo ... hlight=%D4%B2%BB%A1 (defun c:tq (/ ADD DXF-10 ENT GET GET2 LEN LEN2 NN NN2 ENAME n pc r plist) (princ "\n功能 [批量选择多段内所有对象]") (if (setq get (ssget '((0 . "LWPOLYLINE,CIRCLE,ARC")))) (progn (setq Len (sslength get) add (ssadd) ) (repeat Len (setq nn (ssname get (set ...
发表于 2021-9-24 15:09 | 显示全部楼层
本帖最后由 845245015 于 2021-9-25 10:24 编辑
孙玉坤 发表于 2021-9-24 16:33
很长的好用啦  圆和圆弧的能修改支持一下吗 感谢

;;;;部分子程序取自本网站http://bbs.mjtd.com/forum.php?mo ... hlight=%D4%B2%BB%A1
(defun c:tq (/ ADD DXF-10 ENT GET GET2 LEN LEN2 NN NN2 ENAME n pc r plist)
  (princ "\n功能 [批量选择多段内所有对象]")
  (if (setq get (ssget '((0 . "LWPOLYLINE,CIRCLE,ARC"))))
    (progn
      (setq Len (sslength get)
            add (ssadd)
            )
      (repeat Len
        (setq nn (ssname get (setq Len (1- Len)))
              ent (entget nn)
              )
        (cond
          ((= (cdr (assoc 0 ent)) "CIRCLE")
           (setq n 0)
           (SETQ PC (cdr (assoc 10 ent))
                 r (cdr (assoc 40 ent))
                 )
           (repeat 180
             (setq dxf-10 (cons (list 10 (car (polar pc (/(* 2 n pi)180) r)) (cadr (polar pc (/(* 2 n pi)180) r))) dxf-10))
             (setq n (+ n 1))
             )
           )
          ((= (cdr (assoc 0 ent)) "ARC")
           (setq plist (arc_3point nn));;;;子程序arc_3point取自http://bbs.mjtd.com/forum.php?mo ... hlight=%D4%B2%BB%A1
           (print plist)
           (foreach x plist
             (setq dxf-10 (cons (list 10 (car x) (cadr x)) dxf-10))
             )
           )
          ((= (cdr (assoc 0 ent)) "LWPOLYLINE")
           (setq dxf-10 (vl-remove-if '(lambda (x) (/= (car x) 10)) ent))
           )
          )
        (setq get2   (ssget "_CP" (mapcar 'cdr dxf-10))
              Len2   (sslength get2)
              )
        (repeat Len2
          (setq nn2 (ssname get2 (setq Len2 (1- Len2))))
          (ssadd nn2 add)
          )
        )
      )
    )
  (repeat (sslength get)
    (Setq ENAME (SsName get 0))
    (SsDel ENAME get)
    (SsDel ENAME add)
  )
  (sssetfirst nil add)
  (princ)
)
;;;;子程序arc_3point取自http://bbs.mjtd.com/forum.php?mo ... hlight=%D4%B2%BB%A1
(defun arc_3point (a / cenp radius STP ENPmp arcmidpoint)
(setq cenp (cdr (assoc 10 (entget a))))
(setq radius (cdr (assoc 40 (entget a))))
(setq STP (vlax-curve-getPointAtParam A (vlax-curve-getstartparam A)))
(setq ENP (vlax-curve-getPointAtParam A (vlax-curve-getEndParam A)))
(setq arcmidpoint (polar (polar stp (angle stp enp) (/ (distance STP ENP) 2.0))
(angle cenp (polar stp (angle stp enp) (/ (distance STP ENP) 2.0)))
(- radius (distance (polar stp (angle stp enp) (/ (distance STP ENP) 2.0)) cenp))))
(list stp enp arcmidpoint)
)
回复

使用道具 举报

发表于 2021-9-24 15:26 | 显示全部楼层
本帖最后由 cqu20104225 于 2021-9-24 15:28 编辑

把(ssget "_WP" (mapcar 'cdr dxf-10))改成(ssget "_CP" (mapcar 'cdr dxf-10))应该就可以了。



回复

使用道具 举报

发表于 2021-9-24 15:31 | 显示全部楼层
(defun c:ta (/ ADD DXF-10 ENT GET GET2 LEN LEN2 NN NN2 ENAME)
  (princ "\n功能 [批量选择多段内所有对象]")
  (if (setq get (ssget '((0 . "LWPOLYLINE"))))
    (progn
      (setq Len (sslength get)
            add (ssadd)
            )
      (repeat Len
        (setq nn  (ssname get (setq Len (1- Len)))
              ent (entget nn)
              )
        (setq dxf-10 (vl-remove-if '(lambda (x) (/= (car x) 10)) ent)
              get2   (ssget "_CP" (mapcar 'cdr dxf-10))
              Len2   (sslength get2)
              )
        (repeat Len2
          (setq nn2 (ssname get2 (setq Len2 (1- Len2))))
          (ssadd nn2 add)
          )
        )
      )
    )
  (repeat (sslength get)
    (Setq ENAME (SsName get 0))
    (SsDel ENAME get)
    (SsDel ENAME add)
  )
  (sssetfirst nil add)
  (princ)
)
回复

使用道具 举报

 楼主| 发表于 2021-9-24 16:33 | 显示全部楼层
845245015 发表于 2021-9-24 15:31
(defun c:ta (/ ADD DXF-10 ENT GET GET2 LEN LEN2 NN NN2 ENAME)
  (princ "\n功能 [批量选择多段内所有 ...

很长的好用啦  圆和圆弧的能修改支持一下吗 感谢
回复

使用道具 举报

 楼主| 发表于 2021-9-25 08:34 | 显示全部楼层
845245015 发表于 2021-9-24 20:35
(defun c:ta (/ ADD DXF-10 ENT GET GET2 LEN LEN2 NN NN2 ENAME)
  (princ "\n功能 [批量选择多段内所 ...

圆和圆弧还是不能识别
回复

使用道具 举报

发表于 2021-9-25 08:56 | 显示全部楼层
孙玉坤 发表于 2021-9-25 08:34
圆和圆弧还是不能识别

您是要选出圆弧和圆,还是点选圆弧和圆获取其内部的图元
回复

使用道具 举报

 楼主| 发表于 2021-9-25 09:46 | 显示全部楼层
845245015 发表于 2021-9-25 08:56
您是要选出圆弧和圆,还是点选圆弧和圆获取其内部的图元

点选圆弧和圆获取其内部的图元
回复

使用道具 举报

发表于 2021-9-25 10:05 | 显示全部楼层
本帖最后由 845245015 于 2021-9-25 10:23 编辑
孙玉坤 发表于 2021-9-25 09:46
点选圆弧和圆获取其内部的图元

;;;;部分子程序取自本网站http://bbs.mjtd.com/forum.php?mo ... hlight=%D4%B2%BB%A1(defun c:tq (/ ADD DXF-10 ENT GET GET2 LEN LEN2 NN NN2 ENAME n pc r plist)
  (princ "\n功能 [批量选择多段内所有对象]")
  (if (setq get (ssget '((0 . "LWPOLYLINE,CIRCLE,ARC"))))
    (progn
      (setq Len (sslength get)
            add (ssadd)
            )
      (repeat Len
        (setq nn (ssname get (setq Len (1- Len)))
              ent (entget nn)
              )
        (cond
          ((= (cdr (assoc 0 ent)) "CIRCLE")
           (setq n 0)
           (SETQ PC (cdr (assoc 10 ent))
                 r (cdr (assoc 40 ent))
                 )
           (repeat 180
             (setq dxf-10 (cons (list 10 (car (polar pc (/(* 2 n pi)180) r)) (cadr (polar pc (/(* 2 n pi)180) r))) dxf-10))
             (setq n (+ n 1))
             )
           )
          ((= (cdr (assoc 0 ent)) "ARC")
           (setq plist (arc_3point nn));;;;子程序arc_3point取自http://bbs.mjtd.com/forum.php?mo ... hlight=%D4%B2%BB%A1
           (print plist)
           (foreach x plist
             (setq dxf-10 (cons (list 10 (car x) (cadr x)) dxf-10))
             )
           )
          ((= (cdr (assoc 0 ent)) "LWPOLYLINE")
           (setq dxf-10 (vl-remove-if '(lambda (x) (/= (car x) 10)) ent))
           )
          )
        (setq get2   (ssget "_CP" (mapcar 'cdr dxf-10))
              Len2   (sslength get2)
              )
        (repeat Len2
          (setq nn2 (ssname get2 (setq Len2 (1- Len2))))
          (ssadd nn2 add)
          )
        )
      )
    )
  (repeat (sslength get)
    (Setq ENAME (SsName get 0))
    (SsDel ENAME get)
    (SsDel ENAME add)
  )
  (sssetfirst nil add)
  (princ)
)
;;;;子程序arc_3point取自http://bbs.mjtd.com/forum.php?mo ... hlight=%D4%B2%BB%A1
(defun arc_3point (a / cenp radius STP ENPmp arcmidpoint)
(setq cenp (cdr (assoc 10 (entget a))))
(setq radius (cdr (assoc 40 (entget a))))
(setq STP (vlax-curve-getPointAtParam A (vlax-curve-getstartparam A)))
(setq ENP (vlax-curve-getPointAtParam A (vlax-curve-getEndParam A)))
(setq arcmidpoint (polar (polar stp (angle stp enp) (/ (distance STP ENP) 2.0))
(angle cenp (polar stp (angle stp enp) (/ (distance STP ENP) 2.0)))
(- radius (distance (polar stp (angle stp enp) (/ (distance STP ENP) 2.0)) cenp))))
(list stp enp arcmidpoint)
)


回复

使用道具 举报

 楼主| 发表于 2021-9-25 10:23 | 显示全部楼层
845245015 发表于 2021-9-25 10:05
;;;;部分子程序取自本网站http://bbs.mjtd.com/forum.php?mo ... hlight=%D4%B2%BB%A1(defun c:tq (/ ADD ...

可以啦 感谢
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-9 02:47 , Processed in 0.522010 second(s), 23 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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