CAD设计论坛

 找回密码
 立即注册
论坛新手常用操作帮助系统等待验证的用户请看获取社区币方法的说明新注册会员必读(必修)
查看: 2120|回复: 4

[求助] CAD中VBA给动态数组赋值的问题

[复制链接]
发表于 2009-2-23 11:32 | 显示全部楼层 |阅读模式
如下声明一个选择集及过滤器:- R+ [1 T0 Q* R2 l9 o" f9 o" S
    Dim SZ As AcadSelectionSet, FT(0) As Integer, FD(0) As Variant# O0 r/ q, c4 b0 U" {
再如下声明一个直线临时变量并声明一个直线动态数组,用于存放所选择的直线:+ N/ N' O# ?7 k! y3 K  \# O
    Dim L As AcadLine, L1() As AcadLine
( D" N9 b' L' b$ f0 i  m: g, g1 [3 c5 ^, ^/ g+ k0 ]4 y
With ThisDrawing8 q9 q# y. s% m
    定义选择的对象为直线对象,创建选择集并由用户在屏幕上选择" d, S- s( I  i1 L
     FT(0) = 0. H) M7 N6 |( f
        FD(0) = "line") ^! Z, e: Z( ]/ `' U- _0 Z9 o
        Set SS = .SelectionSets.Add("SS")
6 K4 q/ e% V4 U        SS.SelectOnScreen FT, FD
4 p- C' e4 V# _" R( V( p
! o6 C' C; `# G2 {8 d3 U     在CAD 模型空间选取几条直线后,在以下的遍历选择集中,如何将所选直线分别存入动态数组L1中
, Z8 _: e. v. r0 M/ r: \$ K3 ]        For Each L In SS
3 C" C' N2 g( @+ [6 A
6 X! P7 B( S# m7 @* \3 ~                      ???????????
& h: ]$ ~, |  p( }                      ?????????????
* E8 ^  T# x4 X+ x6 u" n" M0 t' O) e% d( B* `
            Next0 v* L& V; _) g) U' x' o+ ?* w! w# Q" U
End with
6 N. @$ a! J7 C. x# K求高手帮助,谢谢
 楼主| 发表于 2009-2-23 15:48 | 显示全部楼层
希望有人帮助.......
 楼主| 发表于 2009-2-23 17:25 | 显示全部楼层
最后顶一次。。。
发表于 2009-9-26 08:58 | 显示全部楼层
先看看。。。。。。
发表于 2010-1-30 12:12 | 显示全部楼层
在遍历之前根据选择集中对象数量重定义动态数组4 m8 c8 `1 F4 F. M  q6 ?  S
  1.   F0 ?, r2 _5 q& }5 G8 _
  2. If SS.Count>0 Then
    $ o" r8 t+ h* I
  3. Dim I as Integer7 k& k4 H  A. a8 x
  4. Redim L1(SS.Count-1)
    + Y+ T. N# ]6 H2 ?9 [7 ?- R* j
  5. For Each L In SS
    # i& u2 H1 r6 |3 I: a
  6. Set L1(I)=L6 i3 o6 C; N) L- E' e; H& R- w
  7. I=I+1. H' q5 y) A* y- d) ~' R, e
  8. Next
    8 E; [4 }. C* d- _1 S/ [
  9. End If
    ! @, D+ `1 v$ y2 O3 w
复制代码
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关于|免责|隐私|版权|广告|联系|手机版|CAD设计论坛

GMT+8, 2025-2-19 06:35

CAD设计论坛,为工程师增加动力。

© 2005-2025 askcad.com. All rights reserved.

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