QQ登录

只需一步,快速开始

登录 | 注册 | 找回密码

三维网

 找回密码
 注册

QQ登录

只需一步,快速开始

展开

通知     

查看: 1968|回复: 3
收起左侧

[讨论] 如何用二次开发方法定义块

[复制链接]
发表于 2008-10-28 08:02:35 | 显示全部楼层 |阅读模式 来自: 中国山东烟台

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

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

x
思路是这样的:在二次开发的程序中,对正画的实体想定义成块,如何实现呢
发表于 2008-10-28 11:23:17 | 显示全部楼层 来自: 中国辽宁营口
楼主的意思是否可以这样理解:模仿CAD的“BLOCK”命令用现有实体创建块?
3 H! ?, y: {2 |( I! E在VBA中可以这样做:- T& ]1 b3 c; `  i
一、用对话框要求用户输入要创建的块对象的属性(包括块名称、基点等等)、原有实体的处理方法(包括保留、删除、转换为块等)3 u: b1 |( L" |! V* m
二、在用户按下“确定”按钮时判断当前空间是否有选择集,如果有则使用现有选择集;如没有则新建一个选择集并要求用户选择对象
3 X, D* W: \- x/ w& j三、如果选择集为空则删除选择集后退出;如选择集不为空则继续向下进行! N# r; }5 d+ F/ V/ M
四、遍历选择集,把其中的实体对象赋值给一个对象类型动态数组
: j4 K# O* `# Z五、删除选择集2 P  W. ^0 q6 P% B9 U9 F2 H  K, e
六、按用户的设置创建块对象并修改其属性$ l" n* u1 F! {; t1 X
七、用“Document”对象的“CopyObjects”方法,把动态数组中的实体对象集复制到块对象中
5 _! V% r3 A& G6 U5 \4 A八、按用户设置删除原有实体或删除原有实体后在原位置插入块参照或什么也不做(保留)- L$ l! H9 G  H9 s- E9 b- d( ^- U

6 Z; z. \3 }3 V9 a下面的代码是一个最简单的例子
  1. Dim Objs() As AcadEntity, B As AcadBlock, P(2) As Double, SS As AcadSelectionSet, I As Integer
    6 B; R2 ~/ z# G" Y3 A
  2. With ThisDrawing% O) q% i" {, t1 z) [' A& ^, q) Y
  3.     Set SS = .SelectionSets.Add("SS" ) '新建选择集" E( t) z8 I, e- t2 J" `
  4.     SS.SelectOnScreen '由用户在屏幕上选择对象
    $ {; X/ S: G" @; X/ Q2 i- Y! h5 k
  5.     If SS.Count > 0 Then '如果选择集不为空* m$ V$ d" Q5 U) Y8 P# x# |
  6.         ReDim Objs(SS.Count - 1) '按选择集中元素数量重定义动态数组元素个数6 q8 k% V" U$ L; X9 ^9 b" G
  7.         For I = 0 To SS.Count - 1 '把选择集中的实体赋值给数组
    2 b4 Z; `5 [" ^' M6 u) V
  8.             Set Objs(I) = SS.Item(I)
    % p* c- ^" g4 L% X
  9.         Next4 X* l$ W3 i+ I  }' H" l6 f4 e
  10.         Set B = .Blocks.Add(P, "A" ) '创建块
    " s8 S: g$ h) V7 s# L4 w8 j# }
  11.         .CopyObjects Objs, B '把实体复制到块中
    / J0 O8 G2 q8 F/ u' x: D
  12.     End If
    9 y8 q4 Q8 F1 M: f+ i  f# M+ Q3 z
  13.     SS.Delete '删除选择集- U/ F8 J+ f2 Y& T
  14. End With
    - ?# v9 x6 i/ _- C) o7 H
复制代码
1 K: D; z( |2 O1 W7 X1 r
[ 本帖最后由 woaishuijia 于 2008-10-28 11:24 编辑 ]
 楼主| 发表于 2008-10-28 14:13:34 | 显示全部楼层 来自: 中国山东烟台
本人找到了一个这样的例子,但改写成函数却行不通,到底问题出在什么地方呢& d. r. M; d" {1 V& q
产生“V”字型的样例:
2 L7 @- b+ J. h# Wvoid  defineBlock()
- q0 E8 C4 l# p" h$ x! v4 q{' b  b! s0 b0 E; S4 X
AcDbBlockTableRecord *pBTableRec1=new AcDbBlockTableRecord();/ C3 x" Z! P8 g' q- I
pBTableRec1->setName("VSBlock");- K% H( h6 E% C
AcDbBlockTable *pBTable=NULL;
: \; h$ T+ J8 V! j( w2 J$ G- ~ acdbCurDwg()->getBlockTable(pBTable,AcDb::kForWrite);
$ x9 F4 b0 }" D( `7 |3 G+ e( y AcDbObjectId id1;- C& G& V, F( [, f; K) `
pBTable->add(id1,pBTableRec1);- c  p4 p  M, {4 V& f2 f( w  g7 m
pBTable->close();
( ?9 F5 X! i7 ]& ]: ]: } AcGePoint3dArray ptArr1;
4 ~2 G  c" A+ ]( I" q2 H9 ~6 m ptArr1.setLogicalLength(3);
5 }, n% P4 S  r6 _, [. b# ]3 Z ptArr1[0].set(-2,3,0);9 U2 ^; I: p+ R$ e
ptArr1[1].set( 0,0,0);3 o  B: S; B1 x/ U  ^
ptArr1[2].set( 2,3,0);5 P% E5 h4 Z9 Z* K8 x( y3 H
AcDb2dPolyline *pPline1=new AcDb2dPolyline(AcDb::k2dSimplePoly,ptArr1,0.0,Adesk::kFalse);% M! Y. b! P7 j1 E& W
pBTableRec1->appendAcDbEntity(pPline1);
& h6 t8 {0 P# \1 c2 K- K( [ pBTableRec1->close();
# z' V& k: J" f$ ?2 z% O7 s+ L pPline1->close();
3 S9 R# a  A3 x; m}
 楼主| 发表于 2008-10-28 14:16:01 | 显示全部楼层 来自: 中国山东烟台
改写成函数后,调试结果还未成功) d7 w9 ~5 X6 m
AcDbObjectId DefineBlock(char* pBlockname,AcDbObjectId EntityId,AcGePoint3d basePoint)
2 G+ G" A. T: p. T{
$ `/ G2 i9 b. ~& v4 } AcDbBlockTableRecord *pBTableRec=new AcDbBlockTableRecord();8 s4 }  x  [& l6 L# z% E
pBTableRec->setName(pBlockname);) Q2 V  ^, _7 ^( I, U2 j3 W* A
pBTableRec->setOrigin(basePoint);! c6 h, |; V6 g5 b
AcDbBlockTable *pBlockTable=NULL;
* c# ?3 H  Y; ~4 e, v4 V% G! [ acdbCurDwg()->getBlockTable(pBlockTable,AcDb::kForWrite);
* _& C; T. j- `; J6 x- R AcDbObjectId ObjId;
+ k6 N: l; y4 f2 D pBlockTable->add(ObjId,pBTableRec);
" H, w" v, G9 m! v0 O" z& j7 w0 f pBlockTable->close();
7 [. C9 q7 G- z1 h4 s+ Z AcDbEntity *pEntity;0 q: f; ^0 B# y" t
acdbOpenObject(pEntity,EntityId,AcDb::kForWrite);
& `) w  O2 U5 x, T; S3 p) o
9 w- E. L: [5 i# ~! p pBTableRec->appendAcDbEntity(pEntity);
' \4 Z( O! V" r  H" U6 K5 T' w pBTableRec->close();
- `9 C8 Y' X2 z7 D+ [4 I pEntity->close();+ R4 |8 h; B* s
return ObjId;
5 k6 O! _' K8 @}
发表回复
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

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

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