CAD设计论坛

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

[求助] 请问大家这个VB怎么写啊?

[复制链接]
发表于 2007-9-16 17:14 | 显示全部楼层 |阅读模式
初学CAD,看到以下的一段宏VB,但是想修改为自己实用的一些功能,但是怎么改都不成功,望各位大虾们指点赐教、最好有详细的说明;)  谢谢啦!
' q+ C' U8 l, L0 V2 A! r按照以下代码的大概意思(偶也看得不太懂~),打开和关闭、解锁和锁定 是针对所有层的操作的,如果我想针对于某个层 例如Bondary层使用如下操作,我该如何修改其代码? 烦劳各位详解  大谢!!!
8 p, ]1 H+ z7 D4 U6 M( R2 J, M代码如下:
5 g- F( I" ?/ E$ E3 v8 Q3 k; p3 d7 C* z  r6 H2 i& k
--------------------------------------------------------------------------------------------------
' Y- a8 V& a7 ]- y( A2 k$ l'打开所有图层
/ p! Z2 ?! o' |2 d'***********************; }# g0 Y; D* i" s) x
Public Sub OpenAll_Layers()
; B+ g4 _& e! a0 l6 q  Call OpenAllLayer(True)0 X+ H5 l* d; n5 p8 ?1 }$ C- f% k7 H
End Sub
& P! r/ B& Q/ B, d) i% w- A! r! a--------------------------------------------------------------------------------------------------
: m; V9 J, Z3 t2 O; q'关闭所有图层7 X/ j! t0 O! A( @! w) A6 u4 W
'**********************  \2 {4 Y% y# F% H  p7 m
Public Sub CloseAll_Layers()$ ^* b6 S% H, E
  Call OpenAllLayer(False)
9 \. s5 r& P+ P6 F" B( N! wEnd Sub) `2 X0 C5 k& n2 Y1 f
--------------------------------------------------------------------------------------------------
. u% M: r, f& D- y* {'锁定所有图层
! G) @7 Z9 `# F9 I- k+ l. t'***********************
1 _" n7 I1 m& e# Q4 I& P, K4 BPublic Sub LockAll_Layers()2 s' p7 P7 a3 d2 a% ?, r+ Q
  Call LockAllLayer(True)8 C8 S# {& ]7 \8 i2 ^
End Sub3 u# ^( ^8 v& ?) o  Y
--------------------------------------------------------------------------------------------------
! d, U0 B/ C$ c$ y9 e# U0 l'解锁所有图层) h7 u1 P% K! x4 ]/ o
'***********************  n! e: N+ r# |& O  x% a  G
Public Sub UnLockAll_Layers()  m$ S( D/ U3 g- D9 E4 @
  Call LockAllLayer(False)5 d8 G( P+ U; X( ]7 h
End Sub
  O+ w: j% z% X9 z) N2 `& r;这些是工具栏按钮显示的名称;" K6 k7 ]* h( L: [7 G: Z" e" r

3 d% ^- m6 T% ^- ~7 J/ ?1 P4 `; C% Y+ b
--------------------------------------------------------------------------------------------------# U% `" \8 j% i* X1 Z5 G2 b: b
'Close on Open All Layer; Y' d: l( x/ g# O; b7 b7 b: V9 h
'*****************************************" N) l6 {/ j- h( H
Public Sub OpenAllLayer(ByVal IsOpen As Boolean)0 v- t" E  m" ?, _$ k6 L1 q- W
  Dim i As Integer
! y5 ]6 h* Y, L6 u  For i = 0 To ThisDrawing.Layers.count - 1
/ E6 F& l; ?/ i! g4 B# o    If ThisDrawing.Layers.Item(i).Name = ThisDrawing.ActiveLayer.Name _
9 }0 j2 p6 i8 M9 X( V        And IsOpen = False Then+ U* D1 T" n3 K& [9 E
      ThisDrawing.Layers.Item(i).LayerOn = Not (IsOpen)
. g2 l3 k% l; x    Else
; J# M" d- h6 b3 O; C- r7 i      ThisDrawing.Layers.Item(i).LayerOn = IsOpen8 I( [$ K2 F$ Q" `
    End If& t' _* @1 X1 }+ u7 R* n
  Next i
. I! }, ~& o3 Q- O+ [( r1 j/ p. oEnd Sub6 t; ]+ x7 e/ _
--------------------------------------------------------------------------------------------------/ J6 S" W5 w0 V6 d' ]7 g
'Lock on UnLock All Layer% n) I& p& k- L4 I+ h
'****************************************** G6 W" e$ o7 m6 i: g6 V' \
Public Sub LockAllLayer(ByVal IsLock As Boolean)
$ x5 P; H5 S* K' R; c9 }  Dim i As Integer
9 p) z. d% o, l6 d  B  For i = 0 To ThisDrawing.Layers.count - 1& `8 u" H  n# B6 k% b
    ThisDrawing.Layers.Item(i).Lock = IsLock% G( k7 u+ a& U- Q* }  v
  Next i8 r- N* }. Q  s# u! f
End Sub4 j5 i. p5 b+ c7 p; `  V
--------------------------------------------------------------------------------------------------/ b& p% f  N/ o' V, j
;这些才是宏语言;
 楼主| 发表于 2007-9-16 17:15 | 显示全部楼层
以上代码  打开和关闭、解锁和锁定  的修改   烦劳各位详解  大谢了!!!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

GMT+8, 2026-6-1 22:32

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

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

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