QQ登录

只需一步,快速开始

登录 | 注册 | 找回密码

三维网

 找回密码
 注册

QQ登录

只需一步,快速开始

展开

通知     

查看: 3101|回复: 6
收起左侧

[求助] 关于CAD VBA的问题

[复制链接]
发表于 2008-10-17 19:07:45 | 显示全部楼层 |阅读模式 来自: 中国黑龙江哈尔滨

马上注册,结识高手,享用更多资源,轻松玩转三维网社区。

您需要 登录 才可以下载或查看,没有帐号?注册

x
请问怎样在VBA代码中设置活动的图层,比如当前的活动图层为“层1”,怎样在代码中使活动图层变为“层2”。- o% f$ f/ n+ p: k
前一段时间我问了个堆叠的问题,有两位的回答非常好,在此再次表示感谢!!
* R+ ]! t5 Y" Q* c9 x
1 {2 Y# @8 F- p8 l还有,能不能预设置MTEXT的对齐方法,比如:先预设Mtext的对齐方法为MC,然后所有的Mtext对象的默认对齐都是居中方式。(在代码中预设)" U5 W# _- g) F  l8 J+ n

! s0 \* w  p/ g- P0 y0 Y[ 本帖最后由 imwey 于 2008-10-17 19:55 编辑 ]
发表于 2008-10-17 20:10:11 | 显示全部楼层 来自: 中国浙江宁波
楼主的问题acad的帮助中就有例程:1 ~8 u' W* n  P
Sub Example_ActiveLayer()   6 T2 w, X9 k) q
' This example returns the current layer    ) x1 T/ o2 u0 V% b1 C6 Z: P
' and then adds a new layer.    2 S2 j5 J( @6 U5 A3 L6 J$ t- z" f
' Finally, it returns the layer to the previous setting.    0 w/ y- q/ U- i
Dim currLayer As AcadLayer   
/ I4 V: ~3 M+ D, z8 v! aDim newLayer As AcadLayer        ' Return the current layer of the active document    3 u, T8 L% g% S* W: ]* a# Y& I# f
Set currLayer = ThisDrawing.ActiveLayer    " x% h0 b* \0 t) {) f% p
MsgBox "The current layer is " & currLayer.name, vbInformation, "ActiveLayer Example"        " O: W. \6 Z2 E) \7 Y  w
' Create a Layer and make it the active layer   
% v7 j+ X/ h5 _1 G! m; I3 YSet newLayer = ThisDrawing.Layers.Add("TestLayer")   
6 e/ S4 `+ f- f6 [ThisDrawing.ActiveLayer = newLayer   
! @  n! l) ?9 v) CMsgBox "The new layer is " & newLayer.name, vbInformation, "ActiveLayer Example"   
! m$ |, ~$ q8 g' Reset the layer to its previous setting   
8 q2 ^  @3 ]& d- U9 W# F# L9 H9 ^ThisDrawing.ActiveLayer = currLayer    " ?1 h+ E  M4 u+ @3 x1 h5 h
MsgBox "The active layer is reset to " & currLayer.name, vbInformation, "ActiveLayer Example"
: ~( N& B6 M  f" a/ p# k' c/ j$ Z1 iEnd Sub( D1 N. N" Z1 h' q
第二个问题建议使用acadText对象,而不是mtext对象,具体参考alignment属性;
0 }* G2 J4 S6 }7 q* {
+ P0 D1 Y8 ~4 k1 E[ 本帖最后由 sealive_leafage 于 2008-10-17 20:14 编辑 ]

评分

参与人数 1三维币 +5 收起 理由
woaishuijia + 5 应助

查看全部评分

 楼主| 发表于 2008-10-19 09:58:24 | 显示全部楼层 来自: 中国黑龙江哈尔滨
谢谢楼上的回答,上次我提的问提也是你回答的吧,谢谢。& N) s6 p7 X  Z
1,层的问题,你上面的代码新建一个“TextLayer”,再把它设为活动层。我的本意是问怎么样把一个已存在的层设置问活动,不过我试着把Set newLayer = ThisDrawing.Layers.Add("TestLayer")    中的 testlayer 改为已存在的层的名称,就可以了。这是不是正确的用法?如果不是,应该怎样做?* B6 l4 i8 }; _* m$ ~: l, @( Y# |. @
2,因为我要在不同的地方显示文字,而且都要用中间对齐方式,因为mtext和text的默认对齐不是中间,所以我想一次性给设置好,不用每个文字对象都分别设置,嫌麻烦啊。另外,TEXT里面能显示公差吗,因为我要显示公差所以才想起用MTEXT的。
5 H5 O& t3 i* R) V. x) T6 P" Q1 ^1 Z' E2 w5 F
我是前些天看CAD的开发人员帮助才学的ACAD VBA,所以很菜的,问了这么些菜问题,还请包涵。
发表于 2008-10-19 11:23:00 | 显示全部楼层 来自: 中国辽宁营口

回复 3# imwey 的帖子

一.错误. 2楼的例程中设置活动图层是这行
0 I7 I1 V# U7 w4 d' F5 B* Z* r
  1. ThisDrawing.ActiveLayer = newLayer
    # C' }" x8 P0 n7 i$ U, O
复制代码
在此之前,在
  1. Set newLayer = ThisDrawing.Layers.Add("TestLayer" )
复制代码
这一行(新建"TestLayer"图层)已经将该图层赋值给变量newLayer,所以newLayer就代表"TestLayer"图层对象,所以ThisDrawing.ActiveLayer = newLayer就使"TestLayer"图层成为了活动图层.. h& K' P% ~, g! J" E4 H0 u
把已存在的图层设为活动图层应该这样:& G. B$ S6 h- j* s/ I8 @
  1. ThisDrawing.ActiveLayer = ThisDrawing.Layers.Item(图层名称字符串)5 G3 n3 z, J- W% \+ p& ~
复制代码
当然,如果该图层已经被赋予某个变量,也可以像前面用变量设置活动图层.比如,原有一个名为"实线"的图层:
- F; g, R: u- F2 M# y$ @
  1. Set 图层1 = ThisDrawing.Layers.Item("实线" )
    . K9 m4 h* W! n' ^' I& l
  2. ThisDrawing.ActiveLayer = 图层1* \# E% t: W+ t- d! M+ e
复制代码

2 o6 B$ D" y" o& Q$ u4 L* y二.不能5 l& t6 t, i! m% s3 K
属性是从属于对象的,必须分别给每一个mtext或text对象设置属性--如果需要的话
; ]  k5 r, `' _* j: y2 h2 U) x
& K( s, x& m" f% _; n- ?[ 本帖最后由 woaishuijia 于 2008-10-19 11:29 编辑 ]
 楼主| 发表于 2008-10-19 17:54:38 | 显示全部楼层 来自: 中国黑龙江哈尔滨
' ?) Q: ~9 C  m8 o
ThisDrawing.ActiveLayer = ThisDrawing.Layers.Item(图层名称字符串) 正是我想要的,哈哈。  @/ A3 t! d, M. ]
假设层“实线”已存在,那么
& ^; Z% G1 k' p6 n; M2 `Set 图层1 = ThisDrawing.Layers.Add("实线" ), w9 e( X6 E( v% R
6 B- |0 T5 L" d/ P: ]  }
Set 图层1 = ThisDrawing.Layers.Item("实线" )0 _$ a# B4 N( A5 ~
的效果是不是一样的呢,“图层1”是不是都是指向“实线”?
0 p; i; W) C% T. |2 A: r# D
, \! L# E2 @2 c' E; a可惜mtext和text的默认对齐不是中间对齐,一个一个设置对齐麻烦啊,真的没办法也就只能一个一个设置了。
发表于 2008-10-19 20:38:41 | 显示全部楼层 来自: 中国

回复 5# imwey 的帖子

一、结果是一样的,但前者的写法不规范。图层是命名对象,使用命名对象时不要重名,以避免不必要的错误。( H% z# E3 t+ X$ M; u* }: O
二、如果你的文字都是中间对齐,可以在最后用循环遍历的方法统一设置它们的对齐属性,这样能减少编程量。比如下面的代码就可以把所有现有的多行文字对象的对正方式设为正中:
  1. Dim SS As AcadSelectionSet, FT(0) As Integer, FD(0) As Variant, MT As AcadMText
    . B( x: Z# \8 {3 J$ n7 N
  2. Set SS = ThisDrawing.SelectionSets.Add("AAAAAA") '新建选择集
    : Z2 U: s0 N/ j+ ^# {' n$ i! G
  3. FT(0) = 0 '定义过滤器为多行文字' w" B1 _+ W1 E6 k1 q, w( C+ J
  4. FD(0) = "mtext"
    : u8 F$ V- T! r( p, F( ^
  5. SS.Select acSelectionSetAll, , , FT, FD '选择屏幕上全部多行文字对象
    ) T8 r/ {$ T/ d* t4 u
  6. For Each MT In SS '遍历多行文字对象
    ' Y: ~/ H( t! S. ^% }8 W, E
  7.     MT.AttachmentPoint = acAttachmentPointMiddleCenter '正中对齐( e% {9 c% P0 d# \0 x6 n0 l$ O% _
  8. Next/ @4 i% d7 p4 }
  9. SS.Delete '及时删除用过的选择集
复制代码
 楼主| 发表于 2008-10-21 17:11:50 | 显示全部楼层 来自: 中国黑龙江哈尔滨
谢谢 我爱谁家 和 sealive ,我是现用现学,说不定今后还会有什么问题请教.
发表回复
您需要登录后才可以回帖 登录 | 注册

本版积分规则

Licensed Copyright © 2016-2020 http://www.3dportal.cn/ All Rights Reserved 京 ICP备13008828号

小黑屋|手机版|Archiver|三维网 ( 京ICP备2023026364号-1 )

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