明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 10242|回复: 40

[讨论]如何快速获得当前所有图元的左下角和右上角

  [复制链接]
发表于 2004-5-6 17:06:00 | 显示全部楼层 |阅读模式
与系统变量limmin和limmax无关
"觉得好,就打赏"
还没有人打赏,支持一下
发表于 2004-5-6 17:13:00 | 显示全部楼层

(defun C:BOUND (/ BLK_BOUND PT1 PT2)

(setq BLK_BOUND (ACET-GEOM-SS-EXTENTS (ssget) t))

(setq PT1 (car BLK_BOUND))

(setq PT2 (cadr BLK_BOUND))

(command "_.RECTANG" PT1 PT2)

)

发表于 2004-5-6 17:18:00 | 显示全部楼层
(defun c:test(/ ss AX:GETBOUNDINGBOX n PT_LIST )
(setq PT_LIST '())
(setq SS (ssget "X"(list '(-4 . "<not")(cons 0 "xline,rays")'(-4 . "not>"))))
(defun AX:GETBOUNDINGBOX (ENT / LL UR pt1 pt2)
(vla-getboundingbox (vlax-ename->vla-object ENT) 'LL 'UR)
(mapcar 'vlax-safearray->list (list LL UR)))
(setq N 0)
(repeat (sslength SS)
(setq PT_LIST (append PT_LIST (list (AX:GETBOUNDINGBOX (ssname SS N)))))
(setq N (1+ N)))
PT_LIST)
发表于 2004-5-6 17:24:00 | 显示全部楼层
二樓龍龍仔您好 ACET-GEOM-SS-EXTENTS 這個是什麼涵數? 我這里用 Command: BOUND
Select objects: 1 found Select objects: ; error: no function definition: ACET-GEOM-SS-EXTENTS
发表于 2004-5-6 18:01:00 | 显示全部楼层
本帖最后由 作者 于 2004-5-6 18:37:42 编辑

ACET-GEOM-SS-EXTENTS 是expresstools 的函数,功能相对于下面的(test),不过龙龙仔 那个t参数是怎么解释的?
  1.   
  2. (defun test ( / n e ll ur xlst ylst)
  3.    (setq ss (ssget "x" '((0 . "~xline,~ray"))))
  4.    (repeat (setq n (sslength ss))
  5.        (setq e (ssname ss (setq n (1- n))))
  6.        (vla-getboundingbox (vlax-ename->vla-object e) 'll 'ur)
  7.        (mapcar '(lambda (x) (setq lst (cons (vlax-safearray->list x) lst))) (list ll ur))
  8.    )
  9.    (setq xlst (vl-sort (mapcar 'car lst) '< )
  10.   ylst (vl-sort (mapcar 'cadr lst) '< ))
  11.    (list (list (car xlst) (car ylst))(list (last xlst) (last ylst)))
  12. );;测试:
  13. (setq lst (test))
  14. (vl-cmdf ".rectangle" (car lst)(cadr lst))
  15.   
 楼主| 发表于 2004-5-6 18:01:00 | 显示全部楼层
把两位斑竹的程序合在一起可以解决我的问题 (defun C:BOUND (/ BLK_BOUND PT1 PT2)
(setq BLK_BOUND (ACET-GEOM-SS-EXTENTS (ssget "X"(list '(-4 . "<not")(cons 0 "xline,rays")'(-4 . "not>"))) t))
(setq PT1 (car BLK_BOUND))
(setq PT2 (cadr BLK_BOUND))
(command "_.RECTANG" PT1 PT2)
) 怎样把PT1和PT2放在Userr系统变量里? Lisp我实在不懂
 楼主| 发表于 2004-5-6 18:19:00 | 显示全部楼层
谢了
发表于 2004-5-6 18:37:00 | 显示全部楼层
怎样把PT1和PT2放在Userr系统变量里?


       


樓上的 這個用來做什麼來的?
 楼主| 发表于 2004-5-6 18:43:00 | 显示全部楼层
我在VBa里做好了 Public Sub test()
Dim ss As AcadSelectionSet
Dim i As AcadEntity
Set ss = ThisDrawing.ActiveSelectionSet
ss.Select acSelectionSetAll
ss(0).GetBoundingBox pmin, pmax
For Each i In ss
i.GetBoundingBox p1, p2
If p1(0) < pmin(0) Then pmin(0) = p1(0)
If p1(1) < pmin(1) Then pmin(1) = p1(1)
If p2(0) > pmax(0) Then pmax(0) = p2(0)
If p2(1) > pmax(1) Then pmax(1) = p2(1)
Next i
ThisDrawing.SendCommand "_.RECTANG " & pmin(0) & "," & pmin(1) & vbCr & pmax(0) & "," & pmax(1) & vbCr
End Sub
用龙斑竹的办法16240个实体大概用了8秒 我的程序用了2秒 我要的是快速
发表于 2004-5-6 19:04:00 | 显示全部楼层
嘩. 真讓我大開眼界哦. 這麼快的速度.
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-11-28 08:37 , Processed in 0.210094 second(s), 28 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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