乐筑天下

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

[编程交流] 从EXCEL获取边界框

[复制链接]

14

主题

28

帖子

14

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
70
发表于 2022-7-6 21:47:26 | 显示全部楼层 |阅读模式
你好
 
我试图得到一个层上所有实体的边界框。
我希望能够从EXCEL中执行此操作。我试图将在AutoCAD VBA中工作的AutoCAD VBA例程修改为在EXCEL中工作,但我似乎错过了一些东西。请看下面我的代码。它在ss(0)处失败。。线
请告知
非常感谢。
  1. Sub Get_BoundingBox()
  2. Dim XNAME As String
  3. 'On Error Resume Next 'This tells VBA to ignore errors
  4. Set ACAD = GetObject(, "AutoCAD.Application") 'Get a running instance of the class AutoCAD.Application
  5. Dim ssetObj As AcadSelectionSet
  6. Dim sset As AcadSelectionSets
  7. Dim acadobj As AcadObject
  8. Dim objname As String
  9. Dim ptllmin As Variant
  10. Dim ptllmax As Variant
  11. Dim HH As Variant
  12. Dim objlayer As String
  13. Dim entItem As AcadEntity
  14. Dim I As Integer
  15. Dim corner1(0 To 2) As Double
  16. Dim corner2(0 To 2) As Double
  17. corner1(0) = -10000000000#: corner1(1) = -10000000000#: corner1(2) = 0
  18. corner2(0) = 10000000000#: corner2(1) = 10000000000#: corner2(2) = 0
  19. I = 0
  20. Set sset = ACAD.ActiveDocument.SelectionSets
  21. For Each ssetObj In sset
  22. If UCase(ssetObj.Name) = "TEST" Then
  23. sset.Item("TEST").Delete
  24. Exit For
  25. End If
  26. Next
  27. Set ssetObj = ACAD.ActiveDocument.SelectionSets.Add("TEST")
  28. ' Add all the objects to the selection set
  29. ssetObj.Select acSelectionSetAll
  30. Q$ = Chr(9)
  31. For Each acadobj In ssetObj
  32. objname = acadobj.ObjectName
  33. objlayer = acadobj.Layer
  34. HH = acadobj.Handle
  35. Const X = 0
  36. Const Y = 1
  37. ss(0).GetBoundingBox ptMin, ptMax
  38. For Each entItem In ss
  39.     ACAD.ActiveDocument.entItem.GetBoundingBox ptllmin, ptllmax
  40.    If ptllmin(X) < ptMin(X) Then ptMin(X) = ptllmin(X)
  41.    If ptllmin(Y) < ptMin(Y) Then ptMin(Y) = ptllmin(Y)
  42.    If ptllmax(X) > ptMax(X) Then ptMax(X) = ptllmax(X)
  43.    If ptllmax(Y) > ptMax(Y) Then ptMax(Y) = ptllmax(Y)
  44. Next
  45. Sheet5.Cells(I, 1).Value = I
  46. Debug.Print objname, Q$, objlayer, Q$, HH
  47. I = I + 1
  48. Sheet5.Cells(I, 1).Value = I
  49. Sheet5.Cells(I, 2).Value = objname
  50. Sheet5.Cells(I, 3).Value = objlayer
  51. Sheet5.Cells(I, 4).Value = HH
  52. Sheet5.Cells(I, 5).Value = ptMin(X)
  53. Sheet5.Cells(I, 6).Value = ptMin(Y)
  54. Sheet5.Cells(I, 7).Value = ptMax(X)
  55. Sheet5.Cells(I, 7).Value = ptMax(Y)
  56. Next acadobj
  57. End Sub
回复

使用道具 举报

106

主题

1万

帖子

101

银币

顶梁支柱

Rank: 50Rank: 50

铜币
1299
发表于 2022-7-6 23:13:37 | 显示全部楼层
我不是VBA方面的专家,但是比较一下lee mac的代码,你会发现调用边界框时缺少了一个对象。
 
  1. (vl-catch-all-apply 'vla-getboundingbox (list obj 'a 'b))

 
同样ss(0)可能只是ss,为什么边界框调用两次?
 
同时查看变量extmax extmin
 
lisp版本
  1. (setq ss (ssget))
  2. (repeat (setq x (sslength ss))
  3. (setq obj (vlax-ename->vla-object (ssname ss (setq x (- x 1))))
  4. (vla-getboundingbox obj 'll 'ur)
  5. (setq ll(vlax-safearray->list ll))
  6. (setq ur (vlax-safearray->list ur))
  7. (princ ll)
  8. )
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

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

GMT+8, 2025-3-4 14:58 , Processed in 0.891692 second(s), 56 queries .

© 2020-2025 乐筑天下

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